原文链接:http://blog.csdn.net/qq_37936542/article/details/79064818

需求描述:ajax向后台发起请求,springmvc在处理完请求后返回的结果类型不能够统一,int/String/Map/List等等,这里我自定义一个类,封装返回结果

一:封装主类 AjaxResponse

  1. package com.debo.common;
  2. import java.util.HashMap;
  3. import java.util.Map;
  4. public class AjaxResponse {
  5. private ReturnState returnState;
  6. private String returnMsg;
  7. private Map<String, Object> returnData = new HashMap<String, Object>();
  8. public AjaxResponse() {
  9. this(ReturnState.OK, "");
  10. }
  11. public AjaxResponse(String returnMsg) {
  12. this(ReturnState.OK, returnMsg);
  13. }
  14. public AjaxResponse(ReturnState returnState, String returnMsg) {
  15. this.returnState = returnState;
  16. this.returnMsg = returnMsg;
  17. }
  18. public AjaxResponse(String attributeName, Object attributeValue) {
  19. this();
  20. addAttribute(attributeName, attributeValue);
  21. }
  22. public static AjaxResponse getInstanceByResult(boolean result) {
  23. if (result) {
  24. return new AjaxResponse(Constant.OPERATE_SUCCESS);
  25. } else {
  26. return new AjaxResponse(ReturnState.ERROR, Constant.OPERATE_ERROR);
  27. }
  28. }
  29. public ReturnState getReturnState() {
  30. return returnState;
  31. }
  32. public void setReturnState(ReturnState returnState) {
  33. this.returnState = returnState;
  34. }
  35. public String getReturnMsg() {
  36. return returnMsg;
  37. }
  38. public void setReturnMsg(String returnMsg) {
  39. this.returnMsg = returnMsg;
  40. }
  41. public Map<String, Object> getReturnData() {
  42. if (returnData == null) {
  43. returnData = new HashMap<String, Object>();
  44. }
  45. return returnData;
  46. }
  47. public void setReturnData(Map<String, Object> returnData) {
  48. this.returnData = returnData;
  49. }
  50. public AjaxResponse addAttribute(String attributeName, Object attributeValue) {
  51. getReturnData().put(attributeName, attributeValue);
  52. return this;
  53. }
  54. }

二:返回状态枚举 ReturnState

  1. package com.debo.common;
  2. /**
  3. * Ajax返回状态
  4. *
  5. * @author lzg
  6. */
  7. public enum ReturnState {
  8. OK,
  9. WARNING,
  10. ERROR
  11. }

三:系统常用常量 Constant

  1. package com.debo.common;
  2. public class Constant {
  3. public static final int ZERO = 0;
  4. public static final String SUCCESS = "success";
  5. public static final String ERROR = "error";
  6. public static final String OPERATE_SUCCESS = "操作成功!";
  7. public static final String OPERATE_ERROR = "操作失败!";
  8. public static final String NOT_PERMITTED = "权限不足!";
  9. public static final String STATE1 = "1";
  10. public static final String STATE2 = "2";
  11. public static final int AFFECTED_LINE_0 = 0;
  12. public static final int AFFECTED_LINE_1 = 1;
  13. }

四:后台测试代码

  1. package com.debo.common;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.web.bind.annotation.RequestMapping;
  4. import org.springframework.web.bind.annotation.ResponseBody;
  5. @Controller
  6. public class Test {
  7. @RequestMapping("/test")
  8. @ResponseBody
  9. public AjaxResponse demo(){
  10. //操作正确时,返回正确信息
  11. //return new AjaxResponse(ReturnState.OK,"操作成功");
  12. //return new AjaxResponse("操作成功");
  13. //return AjaxResponse.getInstanceByResult(true);
  14. //操作失败,返回失败信息
  15. //return new AjaxResponse(ReturnState.ERROR,"登录名已存在");
  16. //return AjaxResponse.getInstanceByResult(false);
  17. //返回一个对象、集合或map
  18. //return new AjaxResponse("returnDate", map/List/对象);
  19. //返回多个对象、map、集合
  20. //AjaxResponse ajaxResponse = new AjaxResponse();
  21. //ajaxResponse.addAttribute("aaa", map);
  22. //ajaxResponse.addAttribute("bbb", list);
  23. //ajaxResponse.addAttribute("ccc", 对象);
  24. //默认操作成功,无返回信息
  25. return new AjaxResponse();
  26. }
  27. }

五:前端ajax代码

  1. $.ajax({
  2. url : "test",
  3. type : "get",
  4. dataType : "json",
  5. success : function(data) {
  6. //返回状态
  7. //alert(data.returnState);
  8. //返回信息
  9. //alert(data.returnMsg)
  10. //返回的对象/集合/map
  11. alert(data.returnData.aaa)
  12. }
  13. });

文末福利:

福利一:前端,Java,产品经理,微信小程序,Python等8G资源合集大放送:https://www.jianshu.com/p/e8197d4d9880

福利二:微信小程序入门与实战全套详细视频教程

领取方式:
如果需要学习视频,欢迎关注 【编程微刊】微信公众号,回复【领取资源】一键领取以下所有干货资源,获取更多有用技术干货、文档资料。所有文档会持续更新,欢迎关注一起成长!

封装springmvc处理ajax请求结果的更多相关文章

  1. SpringMVC的AJAX请求报406错误

    SpringMVC的AJAX请求报406错误原因有两种:1.jackson包没有引入 2.如果已经引入jackson包了还报406的错误,那么就有可能是请求的url路径是.html结尾,但是返回的数据 ...

  2. SpringMVC响应Ajax请求(@Responsebody注解返回页面)

    项目需求描述:page1中的ajax请求Controller,Controller负责将service返回的数据填充到page2中,并将page2整个页面返回到page1中ajax的回调函数. 一句话 ...

  3. SpringMVC下Ajax请求的方法,@Responsebody如果返回的是布尔值,ajax不会接到任何回传数据

    SpringMVC框架下,如果用ajax向后台请求得方法如果使用@Responsebody返回布尔值的话,ajax得不到任何的回传数据. 但是如果返回String类型,就是正常的. 测试了下代码写得没 ...

  4. SpringMVC进行Ajax请求页面显示乱码

    最近在项目的使用过程中发现在springmvc的项目中,使用返回页面的请求方式,数据都能正常显示,但是对于ajax的请求,始终显示乱码. 首先第一种是因为我们在web.xml中配置了spring的字符 ...

  5. SpringMVC 03: 请求和响应的乱码解决 + SpringMVC响应Ajax请求

    请求或响应的中文乱码问题 tomcat9解决了get请求和响应的中文乱码问题,但是没有解决post请求或响应的中文乱码问题 tomcat10解决了get和post请求以及响应的中文乱码问题 考虑到实际 ...

  6. SpringMVC经典系列-13使用SpringMVC处理Ajax请求---【LinusZhu】

    注意:此文章是个人原创,希望有转载须要的朋友们标明文章出处,假设各位朋友们认为写的还好,就给个赞哈,你的鼓舞是我创作的最大动力,LinusZhu在此表示十分感谢,当然文章中如有纰漏,请联系linusz ...

  7. SpringMVC处理ajax请求的注意事项

    .首先要知道ajax请求的核心是JavaScrip对象和XmlHttpRequest,而浏览器请求的核心是浏览器 ajax请求 浏览器请求 场景一:使用ajax获取session中的user 从上图可 ...

  8. 使用es6的then()方法封装jquery的ajax请求

    使用场景: jsp页面中使用jquery的ajax请求比较频繁,以前vue框架的项目用过axios,所以就想着用then()封装一个公共请求的方法,这样每次请求就不用那么麻烦的写一大堆请求参数了. 示 ...

  9. SpringMVC处理ajax请求的跨域问题和注意事项

    .首先要知道ajax请求的核心是JavaScrip对象和XmlHttpRequest,而浏览器请求的核心是浏览器我的个人博客(基于SSM,Redis,Tomcat集群的后台架构) github:htt ...

随机推荐

  1. Android连接socket服务器上传下载多个文件

    android连接socket服务器上传下载多个文件1.socket服务端SocketServer.java public class SocketServer { ;// 端口号,必须与客户端一致 ...

  2. Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一

    Base64是网络上最常见的用于传输8Bit字节代码的编码方式之一,大家可以查看RFC2045-RFC2049,上面有MIME的详细规范.Base64编码可用于在HTTP环境下传递较长的标识信息.例如 ...

  3. JavaScript 进度条重复加载

    <!DOCTYPE HTML> <html> <head> <meta charset ="utf-8"> <title> ...

  4. BZOJ4196: [Noi2015]软件包管理器(树链剖分)

    Description Linux用户和OSX用户一定对软件包管理器不会陌生.通过软件包管理器,你可以通过一行命令安装某一个软件包,然后软件包管理器会帮助你从软件源下载软件包,同时自动解决所有的依赖( ...

  5. 【2017"百度之星"程序设计大赛 - 复赛】Arithmetic of Bomb

    [链接]http://bestcoder.hdu.edu.cn/contests/contest_showproblem.php?cid=777&pid=1001 [题意] 在这里写 [题解] ...

  6. 第二遍回顾--①前端flex布局

    1.flex: 弯曲,收缩 2.概念 2条主轴,main axis,cross axis; 每个单元为flex item,主轴空间main size,交叉轴空间cross size; 3.容器 .co ...

  7. IOS的UIWebView中JS点击事件,需要加入cursor:pointer;属性才可以

    IOS的UIWebView中JS点击事件,需要加入cursor:pointer;属性才可以. Android的WebView可以支持外链样式,js文件:IOS则需要改为内嵌样式和JS文件.

  8. 软件——protel 的pcb电路图制作

    近期一直在学习PCB板的绘制.

  9. 前端切图|点击按钮div变色

    <!DOCTYPE html> <html> <head> <title>点击按钮div变色.html</title> <meta c ...

  10. 芯片SA58672(功放芯片)

    1::下面的中文图可能不准: 针对上面的图,数据手册中有一些参数的推导:      这个式子是电压增益的   这个式子是关于截止频率的  典型原理图: 需要电源去耦,能够提高效率. PVDD引脚处的电 ...