IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Java知识库 -> 【Java从0到架构师】个人简历项目实战 -> 正文阅读

[Java知识库]【Java从0到架构师】个人简历项目实战

项目 Gitee 地址:https://gitee.com/szluyu99/mj_java/tree/master/xr2

功能性

登陆流程

在这里插入图片描述
JS 的 MD5 库:https://blueimp.github.io/JavaScript-MD5/

MD5 在线生成:https://www.cmd5.com/

验证码

验证码 (CAPTCHA),可以用于防止大规模注册、暴力破解密码、刷票、论坛灌水等

  • Completely Automated Public Turing test to tell Computers and Humans Apart 的缩写
  • 全自动区分计算机和人类的图灵测试

传统的验证码:由扭曲倾斜的文字、干扰线组成

  • 由服务器端生成验证码图片,返回给客户端展示
    在这里插入图片描述

在 Java 中,可以使用 Kaptcha 库生成验证码

Kaptcha 产自 Google

常用的配置有:字体、内容的范围、尺寸、边框、干扰线、样式等

<dependency>
	<groupId>com.github.penggle</groupId>
	<artificatId>kaptcha</artificatId>
	<version>2.3.2</version>
</dependency>

JavaWeb

Service、Dao 方法名规范

  • 获取单个对象的方法用 get 做前缀
  • 获取多个对象的方法用 list 做前缀
  • 获取统计值的方法用 count 做前缀
  • 插入的方法用 save(推荐)或 insert 做前缀
  • 删除的方法用 remove(推荐)或 delete 做前缀
  • 修改的方法用 update 做前缀

form 文件上传 - 前端、后台、实时预览

form 如果要支持文件上传,必须设置 2 个属性:

  • method="post"
  • enctype="multipart/form-data"
    一旦 form 设置了这一项,Java 后台就无法通过 request.getParameter 获取参数

Java 后台中常用 commons-fileupload 来接收客户端上传的文件

  • 解析 request 为 List<FilteItem>
ServletFileUpload upload = new ServletFileUpload(new DiskFileItemFactory());
List<FileItem> items = upload.parseRequest(request);
for (FilteItem item : items) {
	if (item.isFormField()) { // 非文件

	} else { // 文件

	}
}
  • 解决中文文件名乱码问题
upload.setHeaderEncoding("UTF-8");

刚上传完毕的图片,有可能会出现无法实时预览的问题(要等一会才能预览成功)
在这里插入图片描述
想要实现实时预览,把 Tomcat 的缓存资源功能关掉即可,在 %TOMCAT_HOME%/conf/context.xml 中增加 Resources 标签:

<?xml version="1.0" encoding="UTF-8"?>
<Context>
	<WatchedResource>WEB-INF/web.xml</WatchedResource>
	<WatchedResource>WEB-INF/tomcat-web.xml</WatchedResource>
	<WatchedResource>${catalina.base}/conf/web.xml</WatchedResource>
	<Resources cachingAllowed="false" cacheMaxSize="0" />
</Context>

页面可见性

正常不应该可以直接访问 xx.jsp 页面,因为这是静态页面,必须通过 Servlet 转发访问才能访问到有数据的页面。

为了防止 .jsp 文件被访问到,可以将其放置到 WEB-INF 文件夹下
在这里插入图片描述
网页中的静态资源(.css、img 等)一般是可以直接访问到的,因此可以不用放到 WEB-INF 中

Service 层

  • Servlet:控制器层
  • Service:业务层,用来完成具体的业务
  • Dao:数据访问层

Service 层存在的原因是:有时候某个业务可能会多次调用数据库相关的操作,在项目很简单的情况下(Service 层所做的事情就是直接调用 Dao 层),Service 存在的意义不明显,但是当项目变大以后,Service 所处理的一些业务操作就需要抽取出来比较清晰。

面向接口编程

为什么需要面向接口编程?

  • 接口只是定义了一种规范,比如 Dao 接口规定了访问数据库有哪些操作,具体具体如何实现这些操作是不固定的,例如使用 Hibernate、Mybatis、Spring-JDBC 等,如果没有接口的约束,当切换了数据库的实现方案后需要改变大量的代码;但是如果有接口的约束,只需要去实现各个方案对数据库的具体操作即可。

后端技巧

利用 Jackson 将 Java 对象转成 Json 字符串

Person person = new Person(1, "张三", 12);
ObjectMapper mapper = new ObjectMapper();
String jsonString = mapper.writeValueAsString(person);
// {"id":"1", "name":"张三", "age":"12"}

利用反射获取泛型的类型

使用场景是自动生成表名,根据泛型的类型获取类名,然后转为数据库的表名

public class Student extends Person<String, Integer>
implements Test1<Integer, Double>, Test2<Double, Long, StringBuilder> {

    // 获取泛型的类型
    public void printGenericType() {
        // 父类
        ParameterizedType superClassType  = (ParameterizedType) getClass().getGenericSuperclass();
        Type[] args = superClassType.getActualTypeArguments();
        for (Type arg : args) {
            System.out.println(arg);
        }

        System.out.println("-----------------------------");

        // 接口
        Type[] interfaceTypes = (Type[]) getClass().getGenericInterfaces();
        for (Type type : interfaceTypes) {
            ParameterizedType interfaceType = (ParameterizedType) type;
            Type[] interfaceArgs = interfaceType.getActualTypeArguments();
            for (Type arg : interfaceArgs) {
                System.out.println(arg);
            }
        }
        
    }
}
java.lang.String
java.lang.Integer
-----------------------------
java.lang.Integer
java.lang.Double
java.lang.Double
java.lang.Long
java.lang.StringBuilder

大驼峰 (MyAge)小驼峰 (myAge) 转为 下划线(my_age)

/**
 * 将大驼峰(MyAge)、小驼峰(myAge) 转为 下划线(my_age)
 **/
public static String underlineCased(String str) {
    if (str == null) return null;
    int len = str.length();
    if (len == 0) return str;

    StringBuilder sb = new StringBuilder();
    sb.append(Character.toLowerCase(str.charAt(0)));
    for (int i = 1; i < len; i++) {
        char c = str.charAt(i);

        if (Character.isUpperCase(c)) {
            sb.append("_");
            sb.append(Character.toLowerCase(c));
        } else {
            sb.append(c);
        }
    }
    return sb.toString();
}

前端技巧

利用 reset 清空 form 表单

jQuery 获取的并不是原生的 DOM 对象,通过 jQuery 拿到表单无法调用 reset,需要转成原生 DOM:

document.querySelector('#add-form-box form').reset() // 原生的表单DOM对象有reset方法
// $('#add-form-box form').reset() // 报错,jQuery获取的不是原生DOM,没有reset方法
$('#add-form-box form')[0].reset()

注意:调用 reset 方法不会重置 type="hidden" 的 input 输入框,需要使用 js 单独处理

图片的 MIMEType

选择文件的 input 可以通过 accept 来控制接收的文件类型,image/* 即所有图片类型

<input type="file" name="image" accept="image/*" />

验证码功能发送不同的参数防止缓存

点击验证码应当会刷新图片,但是如果每次请求的地址是相同的,那么浏览器会从缓存中取而不会实现刷新,通过在后面拼接一些不同的参数使得每次发送的请求不同。

$("#captcha").click(function() {
	$(this).attr('src', '${ctx}/user/catcha?time=' + new Date().getTime())
})
  Java知识库 最新文章
计算距离春节还有多长时间
系统开发系列 之WebService(spring框架+ma
springBoot+Cache(自定义有效时间配置)
SpringBoot整合mybatis实现增删改查、分页查
spring教程
SpringBoot+Vue实现美食交流网站的设计与实
虚拟机内存结构以及虚拟机中销毁和新建对象
SpringMVC---原理
小李同学: Java如何按多个字段分组
打印票据--java
上一篇文章      下一篇文章      查看所有文章
加:2021-07-29 11:30:08  更:2021-07-29 11:31:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年4日历 -2024/4/28 11:38:56-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码