苍穹外卖——day2

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);
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值