SpringBoot分頁的實現與long型id精度丟失問題的解決方案介紹
一.分頁查詢的實現
在做分頁查詢時流程如下:
頁面發(fā)送ajax請求,將分頁查詢參數(page、pageSize、name)提交到服務端,服務端Controller層接收頁面提交的數據并調用Service層查詢數據,Service調用Mapper操作數據庫,查詢分頁數據,Controller層將查詢到的分頁數據響應給頁面
具體實現:
1.設置分頁攔截器,拿到對象當作Bean交給Spring管理
@Configuration public class MyBatisPlusConfig { @Bean public MybatisPlusInterceptor mybatisPlusInterceptor(){ MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor(); mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor()); return mybatisPlusInterceptor; } }
2.Controller層中創(chuàng)建分頁對象,編寫分頁條件
@GetMapping("/page") public R<Page> page(int page,int pageSize,String name){ log.info("page={}, pageSize={}, name={}",page,pageSize,name); //構造分頁構造器 Page page1 = new Page(page, pageSize); //構造條件構造器 LambdaQueryWrapper<Employee> lqw = new LambdaQueryWrapper<>(); //分頁條件 lqw.like(StringUtils.isNotEmpty(name),Employee::getName,name); //添加排序 lqw.orderByDesc(Employee::getUpdateTime); //執(zhí)行查詢 employeeService.page(page1,lqw); //返回分頁頁面信息 return R.success(page1); }
返回的分頁信息響應結果(response)如下:
推薦一個json格式轉換神器:JSON轉換神器
{<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->"code":1,"msg":null,"data":{<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->"records":[{<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->"id":"1576900298836086785","username":"15072564960","name":"懶羊羊","passsword":"e10adc3949ba59abbe56e057f20f883e","phone":"15072564960","sex":"1","idNumber":"420528200201151015","status":0,"createTime":"2022-10-03 19:41:43","updateTime":"2022-10-06 23:01:27","createUser":"1","updateUser":"1"},{<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->"id":"1576934844579266561","username":"24553880","name":"懶羊羊","passsword":"e10adc3949ba59abbe56e057f20f883e","phone":"15072564960","sex":"1","idNumber":"420528200201151015","status":1,"createTime":"2022-10-03 21:59:00","updateTime":"2022-10-06 23:01:17","createUser":"1","updateUser":"1"}],"total":4,"size":2,"current":1,"orders":[],"optimizeCountSql":true,"hitCount":false,"countId":null,"maxLimit":null,"searchCount":true,"pages":2},"map":{<!--{cke_protected}{C}%3C!%2D%2D%20%2D%2D%3E-->}}
二.禁/啟用員工賬號
在員工管理列表頁面,可以對某個員工賬號進行啟用或者禁用操作。賬號禁用的員工不能登錄系統,啟用后的員工可以正常登錄,只有管理員(admin用戶)可以對其他普通用戶進行啟用、禁用操作,所以普通用戶登錄系統后啟用、禁用按鈕不顯示。
分析流程不難發(fā)現,修改員工狀態(tài)是管理員的權限,對狀態(tài)的操作實際就是對employee表中的status字段進行update操作,在Controller層中我們需要編寫相關的方法來處理來自前端的這一請求,就像這樣:
@PutMapping public R<String> update(HttpServletRequest request, @RequestBody Employee employee) { log.info(employee.toString()); employee.setUpdateTime(LocalDateTime.now()); Long empID=(Long) request.getSession().getAttribute("employee"); employee.setUpdateUser(empID); employeeService.updateById(employee); return R.success("員工信息修改成功"); }
Controller層中的update方法處理了請求,但是當我再次刷新頁面發(fā)現其狀態(tài)并沒有改變!
通過Debug一步一步調試時,發(fā)現從Session里拿到的empID和數據庫里的字段id并不對應分別是(1576934844579266561–1576934844579266600),而二者對應起來才是能夠準確執(zhí)行update方法的關鍵
于是,進行排查,查看后端給頁面響應的數據(response),發(fā)現與表中的id是對應的,這說明后端沒問題
總的來說,后端傳給前端的id沒問題且與表中對應,但是前端返回給后端的id卻與之不一致了,問題出在哪?肯定是前端啊
原來啊我們傳提的是一個Long型的數值(19位),JS接收數據并進行處理后發(fā)生了精度丟失!JS只能精確處理前16位,后面的數字做了四舍五入處理
而把后端響應的數值轉換成字符串即可避免這種現象,具體則是通過數值轉換器來實現!
三.數值轉換器的使用
提供對象轉換器JacksonobjectMapper,基于Jackson進行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_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)//將Long轉換成String .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); } }
而我們要做的就是要把他寫到配置類里,擴展mvc框架的消息轉換器組件,用來將方法中返回的R對象結果轉換成字符串,以輸出流的方式返回給頁面
在配置類中確定好自己使用的轉換器類型并設置順序:
/** * 擴展mvc框架的消息轉換器組件 */ @Override protected void extendMessageConverters(List<HttpMessageConverter<?>> converters) { //創(chuàng)建消息轉換器對象 MappingJackson2HttpMessageConverter mj2mc = new MappingJackson2HttpMessageConverter(); //設置對象轉換器,底層使用Jackson將Java對象轉為json mj2mc.setObjectMapper(new JacksonObjectMapper()); //將上述的消息轉換器對象追加到mvc框架的轉換器集合中 converters.add(0,mj2mc);//確定順序,將自己使用的轉換器放在最前面來優(yōu)先使用 }
當我們再次啟動項目調試頁面發(fā)現后端響應的數據變成了以字符串的形式
而且可以成功修改員工狀態(tài):
又是一個小技巧??!
到此這篇關于SpringBoot分頁的實現與long型id精度丟失問題的解決方案介紹的文章就介紹到這了,更多相關SpringBoot分頁內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java并發(fā) CompletableFuture異步編程的實現
這篇文章主要介紹了Java并發(fā) CompletableFuture異步編程的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01servlet之cookie簡介_動力節(jié)點Java學院整理
Cookie技術誕生以來,它就成了廣大網絡用戶和Web開發(fā)人員爭論的一個焦點。下面這篇文章主要給大家介紹了關于servlet之cookie簡介的相關資料,文中介紹的非常詳細,需要的朋友可以參考借鑒,下面來一起看看吧。2017-07-07