Java精品项目瑞吉外卖之员工信息管理篇

作者:爪哇斗罗 时间:2023-07-29 07:43:36 

上一篇:

瑞吉外卖项目:新增员工

一. 员工信息分页查询

1. 需求分析

当系统中的用户越来越多页面展示不完整,我们需要通过实现分页的方式去展示员工的信息:

Java精品项目瑞吉外卖之员工信息管理篇

2. 代码开发

在开发代码之前,需要理清楚程序的执行过程与业务逻辑:

  • 页面发送Ajax请求,将分页查询参数(page,pagesize,name)提交到服务端服务端

  • Controller接收页面提交的数据并调用查询的数据

  • Service调用Mapper操作数据库,查询分页数据

  • Controller将查询到的分页数据响应到页面

  • 页面接收到分页的数据并通过ElementUI的Table组件展示到页面上

Java精品项目瑞吉外卖之员工信息管理篇

其实页面的分页参数是通过JSON的格式传值后端,但是为何是图中是以这种问号的方式拼接的呢,原因是前端将请求进行一个拦截后重新拼接后的结果(前端代码不再叙述)。

配置分页插件

package com.itheima.reggie.config;
import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;
import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
/**
* 配置Mybatis-plus分页插件
* @author jektong
* @date 2022年05月01日 0:08
*/
@Configuration
public class MybatisPlusConfig {
   @Bean
   public MybatisPlusInterceptor mybatisPlusInterceptor(){
       MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
       mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor());
       return mybatisPlusInterceptor;
   }
}

Controller层

/**
    * 员工信息分页查询
    *
    * @param page 当前页
    * @param pageSize 页码
    * @param name 关键字查询
    * @return
    */
   @GetMapping("/page")
   public R<Page> page(int page, int pageSize, String name) {
       log.info("page={},pageSize={},name={}", page, pageSize, name);
       // 构造分页构造器
       Page pageInfo = new Page(page, pageSize);
       // 构造条件
       LambdaQueryWrapper<Employee> queryWrapper = new LambdaQueryWrapper();
       queryWrapper.like(StringUtils.isNotEmpty(name), Employee::getName, name).or()
               .like(StringUtils.isNotEmpty(name),Employee::getUsername,name);
       // 添加排序
       queryWrapper.orderByDesc(Employee::getUpdateTime);
       // 执行查询
       employeeService.page(pageInfo, queryWrapper);
       return R.success(pageInfo);
   }

二. 启用或禁用员工状态

1 需求分析

员工管理列表页,可以对某个员工状态进行启用或者禁用的操作。账号禁用的与员工不可登录系统,启用过后可以正常登录。这一操作只允许管理员进行操作。

2 代码开发

前端核心代码

页面中是如何做到只有管理员admin可以看到禁用按钮的,其实在前端只需获取到登录的账号,然后进行一个用户名判断即可:

页面初始化的时候就获取登录账号:

created() {
         this.init()
         this.user = JSON.parse(localStorage.getItem('userInfo')).username
       },

显示账号状态的那一列:

<el-table-column label="账号状态">
   <template slot-scope="scope">
       {{ String(scope.row.status) === '0' ? '已禁用' : '正常' }}
   </template>
</el-table-column>

向后端传递JSON的数据,将需要禁用员工的账号的ID与状态传值后端,前端主要代码:

//状态修改
statusHandle (row) {
this.id = row.id
this.status = row.status
this.$confirm('确认调整该账号的状态?', '提示', {
'confirmButtonText': '确定',
'cancelButtonText': '取消',
'type': 'warning'
}).then(() => {
enableOrDisableEmployee({ 'id': this.id, 'status': !this.status ? 1 : 0 }).then(res => {
console.log('enableOrDisableEmployee',res)
if (String(res.code) === '1') {
this.$message.success('账号状态更改成功!')
this.handleQuery()
}
}).catch(err => {
this.$message.error('请求出错了:' + err)
})
})
},

后端核心代码

/**
* 根据用户ID去修改用户状态
*  @param request
*  @param employee
*  @return
*/
@PostMapping
public R<String> update(HttpServletRequest request, @RequestBody Employee employee){
// 获取员工ID
Long empId = (Long) request.getSession().getAttribute("employee");
employee.setUpdateTime(LocalDateTime.now());
employee.setUpdateUser(empId);
employeeService.updateById(employee);
return R.success("员工信息修改成功");
}

其实测试发现这段代码是不会被修改成功的,因为涉及一个JS的精度问题,JS识别Long类型只精确到16位,而ID是雪花算法生成的ID有19位,导致ID精度丢失。

代码修复

如何解决上述问题,将页面的Long类型转为字符串。具体步骤:

  • 使用JacksonObjectMapper对JSON数据进行转换

  • 在WebConfig配置类中扩展SringMVC的消息转换器,镜像Java对象到JSON数据的转换

JacksonObjectMapper:

package com.itheima.reggie.common;
import com.fasterxml.jackson.databind.DeserializationFeature;
import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.module.SimpleModule;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateDeserializer;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalDateTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.deser.LocalTimeDeserializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateSerializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalDateTimeSerializer;
import com.fasterxml.jackson.datatype.jsr310.ser.LocalTimeSerializer;
import org.springframework.stereotype.Component;
import java.math.BigInteger;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.time.format.DateTimeFormatter;
import static com.fasterxml.jackson.databind.DeserializationFeature.FAIL_ON_UNKNOWN_PROPERTIES;
/**
* 对象映射器:基于jackson将Java对象转为json,或者将json转为Java对象
* 将JSON解析为Java对象的过程称为 [从JSON反序列化Java对象]
* 从Java对象生成JSON的过程称为 [序列化Java对象到JSON]
*/
@Component
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_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(BigInteger.class, ToStringSerializer.instance)
               .addSerializer(Long.class, ToStringSerializer.instance)
               .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);
   }
}

WebMVCConfig:

/**
    * 扩展MVC消息转换器
    * @param converters
    */
   @Override
   protected void extendMessageConverters(List<HttpMessageConverter<?>> converters) {
       log.info("扩展消息转换器");
       // 创建消息转换器
       MappingJackson2HttpMessageConverter messageConverter = new MappingJackson2HttpMessageConverter();
       // 设置对象转换器,底层使用Jackson将Java对象转为json
       messageConverter.setObjectMapper(new JacksonObjectMapper());
       // 将上面的消息转换器对象追加到MVC框架的转换器集合中
       converters.add(0,messageConverter);
   }

修复之后员工状态可以正常修改,ID也改变为字符串格式了:

Java精品项目瑞吉外卖之员工信息管理篇

来源:https://tongbing.blog.csdn.net/article/details/124521092

标签:Java,瑞吉,外卖,员工,信息管理
0
投稿

猜你喜欢

  • Java中的3种输入方式实现解析

    2021-10-04 00:16:47
  • Java数组与堆栈相关知识总结

    2023-11-12 06:12:18
  • Kotlin List与Set和Map实例讲解

    2023-03-01 01:29:57
  • Mybatis批量插入index out of range错误的解决(较偏的错误)

    2022-06-11 01:11:51
  • Android ListView position详解及实例代码

    2023-10-29 03:33:15
  • unity scrollRect实现按页码翻页效果

    2021-10-11 11:52:43
  • Android Studio实现简单音乐播放功能的示例代码

    2021-09-14 19:51:45
  • 解决Kotlin 类在实现多个接口,覆写多个接口中相同方法冲突的问题

    2023-01-31 23:07:59
  • Dubbo服务校验参数的解决方案

    2023-06-09 14:30:10
  • SpringBoot2.x 集成 Thymeleaf的详细教程

    2021-07-31 18:18:23
  • Android实现蒙板效果

    2021-08-30 16:06:04
  • 如何在C#9 中使用顶级程序 (top-level)

    2023-08-20 04:13:24
  • spring boot 图片上传与显示功能实例详解

    2021-07-02 09:46:02
  • JAVA OutputStreamWriter流的实现

    2021-08-12 19:45:47
  • C#编程总结(一)序列化总结

    2022-04-07 04:25:19
  • C#读取二进制文件方法分析

    2022-04-23 11:17:43
  • 2022最新Java泛型详解(360度无死角介绍)

    2022-03-08 15:13:42
  • Java之ThreadLocal使用常见和方式案例讲解

    2023-08-28 13:54:09
  • java Iterator.remove()实例方法分析

    2022-05-01 15:56:01
  • 使用JMF实现java视频播放器

    2022-12-26 00:28:25
  • asp之家 软件编程 m.aspxhome.com