1.TODO
我们在标注里面写上TODO,如
//TODO
记住后面一定要打空格,不然和后面的字符连在一起会被以为是字符串
这个字符串的作用是:提醒我们
就比如这里代功能尚未完善,我们可以在这里写上TODO,防止之后忘记
2.统一请求头
在我们编写接口文档要测试接口功能的时候发现提交不进去,其实是因为我们提交的申请没有携带JWT令牌,所以被拦截下来了
所以我们要在那里设置一下,
然后我们每次提交的申请都可以带上JWT令牌,这样我们提交的申请就可以通过
3.Threadlocal
我们一般把它封装成一个工具类来使用
由于有些功能我们需要知道哪个人用了这个功能
如修改,新增等等
即我们需要知道id
而这个id是我们在登陆时可以获得的
每一次申请都是创建一个新的线程,所以我们取不到登陆时候的id
所以我们要在那里将id的值取出来
就要创建一个新的线程来单独存储我们要获得的数据,先不销毁,直到将数据提交给我们需要这个数据的线程之后,再执行销毁
下面代码的最后一行就是取出id的操作
//2、校验令牌
try {
log.info("jwt校验:{}", token);
Claims claims = JwtUtil.parseJWT(jwtProperties.getAdminSecretKey(), token);
Long empId = Long.valueOf(claims.get(JwtClaimsConstant.EMP_ID).toString());
log.info("当前员工id:", empId);
BaseContext.setCurrentId(empId);
public class BaseContext {
public static ThreadLocal<Long> threadLocal = new ThreadLocal<>();
public static void setCurrentId(Long id) {
threadLocal.set(id);
}
public static Long getCurrentId() {
return threadLocal.get();
}
public static void removeCurrentId() {
threadLocal.remove();
}
}
Employee employee=new Employee();
//对象属性拷贝,属性名必须一致
BeanUtils.copyProperties(employeeDTO,employee);
//设置剩余的属性
employee.setStatus(StatusConstant.ENABLE);//括号里是我们的自己定义的常量类,
// 之后类似这种颜色的字体都基本都是自定义的常量类
employee.setPassword(DigestUtils.md5DigestAsHex(PasswordConstant.DEFAULT_PASSWORD.getBytes()));
employee.setCreateTime(LocalDateTime.now());
employee.setUpdateTime(LocalDateTime.now());
employee.setCreateUser(BaseContext.getCurrentId());
employee.setUpdateUser(BaseContext.getCurrentId());
employeeMapper.insert(employee);
总之就是,如果想获得的数据在另一个申请中获得,也就是另一个线程,我们就可以通过这个Threadlocal,自定义一个工具类(代码内容固定,不用去特有记,直接复制),利用set存数据,get取数据
4.消息转换器
看下面的图片,下面时间一栏的格式有点问题,不是我们所需要看到的年月日分隔开来的形式
这是由于我们后端传到前端的数据格式发生了改变
我们要改成我们想要的形式,就要使用到消息转换器
解决方法其实有两个,但是第一个我们不推荐,要是代码量大,每个时间参数都要加上注释,这样太麻烦了,推荐方式二
它的代码格式比较固定
所以也不要去强行记忆
我们只需要知道用就行
代码如下
下面一个代码写入在
WebMvcConfiguration类的方法中
protected void extendMessageConverters(List<HttpMessageConverter<?>> converters){
log.info("扩展消息转换器...");
//创建一个消息转换器对象
MappingJackson2CborHttpMessageConverter converter=new MappingJackson2CborHttpMessageConverter();
//需要为消息转换器设置为一个对象转换器,对象转换器可以将Javaduix序列化为json数据
converter.setObjectMapper(new JacksonObjectMapper());
converters.add(0,converter);
}
下面一个是关键代码
是我们自定的对象映射器
/**
* 对象映射器:基于jackson将Java对象转为json,或者将json转为Java对象
* 将JSON解析为Java对象的过程称为 [从JSON反序列化Java对象]
* 从Java对象生成JSON的过程称为 [序列化Java对象到JSON]
*/
public class JacksonObjectMapper extends ObjectMapper {
public static final String DEFAULT_DATE_FORMAT = "yyyy-MM-dd";
//public static final String DEFAULT_DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm:ss";
public static final String DEFAULT_DATE_TIME_FORMAT = "yyyy-MM-dd HH:mm";
public static final String DEFAULT_TIME_FORMAT = "HH:mm:ss";
public JacksonObjectMapper() {
super();
//收到未知属性时不报异常
this.configure(FAIL_ON_UNKNOWN_PROPERTIES, false);
//反序列化时,属性不存在的兼容处理
this.getDeserializationConfig().withoutFeatures(DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES);
SimpleModule simpleModule = new SimpleModule()
.addDeserializer(LocalDateTime.class, new LocalDateTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
.addDeserializer(LocalDate.class, new LocalDateDeserializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
.addDeserializer(LocalTime.class, new LocalTimeDeserializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)))
.addSerializer(LocalDateTime.class, new LocalDateTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_TIME_FORMAT)))
.addSerializer(LocalDate.class, new LocalDateSerializer(DateTimeFormatter.ofPattern(DEFAULT_DATE_FORMAT)))
.addSerializer(LocalTime.class, new LocalTimeSerializer(DateTimeFormatter.ofPattern(DEFAULT_TIME_FORMAT)));
//注册功能模块 例如,可以添加自定义序列化器和反序列化器
this.registerModule(simpleModule);
}