1、返回一个键值对或者集合

前端JS请求:

  1. //返回值为map的形式
  2. $(".name").blur(function(){
  3. $.ajax({
  4. type:"Post",//请求类型
  5. url:"/mvc-demo/user/nameProving?t="+new Date().getTime(),//请求的url
  6. data:{name:$(".name").val()},//请求参数
  7. dataType:"json",//ajax接口(请求url)返回的数据类型
  8. success:function(data){//data:返回数据(json对象)
  9. if(data.name == "empty"){//name为空,错误提示
  10. $(".errorFont").text("用户名为不能为空!");
  11. $(".errorFont").css("color","red");
  12. }else if(data.name == "exist"){
  13. $(".errorFont").text("用户名已注册");
  14. $(".errorFont").css("color","green");
  15. }else if(data.name == "noexist"){
  16. $(".errorFont").text("用户名未注册");
  17. $(".errorFont").css("color","red");
  18. }
  19. },
  20. error:function(data){
  21. $(".errorFont").text("发生未知错误,请联系管理员!");
  22. $(".errorFont").css("color","red");
  23. }
  24. });
  25. });

后端逻辑处理:

  1. //验证用户是否存在,返回一个键值对的数据
  2. @RequestMapping("/nameProving")
  3. @ResponseBody
  4. public Object nameProving(String name){
  5. HashMap<String,String> resultMap=new HashMap<String,String>();
  6. if(StringUtils.isEmpty(name)){
  7. resultMap.put("name", "empty");
  8. }else{
  9. Userss user=userService.getUserByName(name);
  10. if(user!=null)
  11. resultMap.put("name", "exist");
  12. else
  13. resultMap.put("name", "noexist");
  14. }
  15. return JSONArray.toJSONString(resultMap);
  16. }

2、返回一个JSON格式的String字符串

前端js请求:

  1. //返回值为String的形式,dataType:"json"
  2. $(".name").blur(function(){
  3. $.ajax({
  4. type:"Post",//请求类型
  5. url:"/mvc-demo/user/nameProving2?t="+new Date().getTime(),//请求的url
  6. data:{name:$(".name").val()},//请求参数
  7. dataType:"json",//ajax接口(请求url)返回的数据类型
  8. success:function(data){//data:返回数据(json对象)
  9. if(data == "empty"){//name为空,错误提示
  10. $(".errorFont").text("用户名为不能为空2!");
  11. $(".errorFont").css("color","red");
  12. }else if(data== "exist"){
  13. $(".errorFont").text("用户名已注册2");
  14. $(".errorFont").css("color","green");
  15. }else if(data == "noexist"){
  16. $(".errorFont").text("用户名未注册2");
  17. $(".errorFont").css("color","red");
  18. }
  19. },
  20. error:function(data){
  21. $(".errorFont").text("发生未知错误,请联系管理员2!");
  22. $(".errorFont").css("color","red");
  23. }
  24. });
  25. });

后端逻辑处理:

  1. //验证用户是否存在,返回一个转成json字符串的数据
  2. @RequestMapping("/nameProving2")
  3. @ResponseBody
  4. public String nameProving2(String name){
  5. String result="";
  6. if(StringUtils.isEmpty(name)){
  7. result= "empty";
  8. }else{
  9. Userss user=userService.getUserByName(name);
  10. if(user!=null)
  11. result= "exist";
  12. else
  13. result= "noexist";
  14. }
  15. return JSONArray.toJSONString(result);
  16. }

3、返回一个字符串

前端js请求:

重点:datatype:"text"

  1. //返回值为String的形式,dataType:"text"
  2. $(".name").blur(function(){
  3. $.ajax({
  4. type:"Post",//请求类型
  5. url:"/mvc-demo/user/nameProving3?t="+new Date().getTime(),//请求的url
  6. data:{name:$(".name").val()},//请求参数
  7. dataType:"text",//ajax接口(请求url)返回的数据类型
  8. success:function(data){//data:返回数据(json对象)
  9. if(data == "\"empty\""){//name为空,错误提示
  10. $(".errorFont").text("用户名为不能为空3!");
  11. $(".errorFont").css("color","red");
  12. }else if(data== "\"exist\""){
  13. $(".errorFont").text("用户名已注册3");
  14. $(".errorFont").css("color","green");
  15. }else if(data == "\"noexist\""){
  16. $(".errorFont").text("用户名未注册3");
  17. $(".errorFont").css("color","red");
  18. }
  19. },
  20. error:function(data){
  21. $(".errorFont").text("发生未知错误,请联系管理员3!");
  22. $(".errorFont").css("color","red");
  23. }
  24. });
  25. });

后端逻辑处理:

  1. //验证用户是否存在,返回一个字符串的数据
  2. /**
  3. * 此方法中有多个注解 method:指定请求方式
  4. * required:表示参数是否必须 默认为必须 fslse为不是必须
  5. * @param name
  6. * @return
  7. */
  8. @RequestMapping(value="/nameProving3",method=RequestMethod.POST,params="name")
  9. @ResponseBody
  10. public String nameProving3(@RequestParam(value="name",required=false)String name){
  11. String result="";
  12. if(StringUtils.isEmpty(name)){
  13. result= "empty";
  14. }else{
  15. Userss user=userService.getUserByName(name);
  16. if(user!=null)
  17. result= "exist";
  18. else
  19. result= "noexist";
  20. }
  21. return result;
  22. }

4、返回一个类对象的数据

前端js请求:

  1. //返回值为类对象的形式,dataType:"json"
  2. $(".name").blur(function(){
  3. $.ajax({
  4. type:"Post",//请求类型
  5. url:"/mvc-demo/user/nameProving4?t="+new Date().getTime(),//请求的url
  6. data:{name:$(".name").val()},//请求参数
  7. dataType:"json",//ajax接口(请求url)返回的数据类型
  8. success:function(data){//data:返回数据(json对象)
  9. if(data == null){//name为空,错误提示
  10. $(".errorFont").text("用户名为空或者用户名不存在4!");
  11. $(".errorFont").css("color","red");
  12. }else{
  13. $(".errorFont").text("用户名"+data.name+"已注册4");
  14. $(".errorFont").css("color","green");
  15. }
  16. },
  17. error:function(data){
  18. $(".errorFont").text("发生未知错误,请联系管理员2!");
  19. $(".errorFont").css("color","red");
  20. }
  21. });
  22. });

后端逻辑处理:

  1. //返回一个类对象
  2. @RequestMapping("/nameProving4")
  3. @ResponseBody
  4. public Userss nameProving4(String name){
  5. System.out.println("进来了4");
  6. Userss user=userService.getUserByName(name);
  7. if(user==null){
  8. return null;
  9. }
  10. return user;
  11. }

@ResponseBody返回4种数据格式的数据的更多相关文章

  1. Springboot @ResponseBody返回中文乱码

    最近我在把Spring 项目改造Springboot,遇到一个问题@ResponseBody返回中文乱码,因为response返回的content-type一直是application/json;ch ...

  2. Python实现接口测试中的常见四种Post请求数据

    前情: 在日常的接口测试工作中,模拟接口请求通常有两种方法, 利用工具来模拟,比如fiddler,postman,poster,soapUI等 利用代码来模拟,使用到一些网络模块,比如HttpClie ...

  3. @ResponseBody 返回json字符串的核心类是org.springframework.http.converter.json.MappingJacksonHttpMessageConverter,它使用了Jackson 这个开源的第三方类库。主要是以下两个jar包:jackson-core-asl-1.6.4.jar;jackson-mapper-asl-1.6.4.jar

    @ResponseBody 返回json字符串的核心类是org.springframework.http.converter.json.MappingJacksonHttpMessageConvert ...

  4. 计算机系统之汇编---IA32处理器数据格式及数据操作

    计算机系统之汇编---IA32处理器数据格式及数据操作 IA32数据格式: Intel用术语"字"表示16位数据类型,因此.称32位数为"双字",称64位数为& ...

  5. 解决SpringMVC的@ResponseBody返回中文乱码

    SpringMVC的@ResponseBody返回中文乱码的原因是SpringMVC默认处理的字符集是ISO-8859-1,在Spring的org.springframework.http.conve ...

  6. ArcGIS几种数据格式

    ArcGIS几种数据格式 ArcInfo常用以下格式的数据:shp.Coverage..Raster CAD和Geodatabase.各种数据的组织形式不一样,其中shp.Coverage.Raste ...

  7. iOS五种本地缓存数据方式

    iOS五种本地缓存数据方式   iOS本地缓存数据方式有五种:前言 1.直接写文件方式:可以存储的对象有NSString.NSArray.NSDictionary.NSData.NSNumber,数据 ...

  8. SpringMVC3的ResponseBody返回字符串(JSON)乱码问题解决

    近日做一个小项目,用spring mvc 做到ajax请求获取jquery ztree 异步获取树返回json对象时出现了乱码,试了各种办法,查了各种资料,一开始以为是数据库的编码有问题,经测试没问题 ...

  9. [svc]二三层数据格式&&三层数据如何匹配路由

    网络知识拾遗 tcpip的4&7层模型 PDU数据包在不同层的不同称呼 物理层(一层)PDU指数据位(Bit). 数据链路层(二层)PDU指数据帧(Frame). 网络层(三层)PDU指数据包 ...

随机推荐

  1. 洛谷P1347 排序

    这个题看到很多人写Topo排序,其实这道题第一眼看更像是一个差分约束的裸题QWQ... 令dis[x]表示x的相对大小(1是最小,n是最大),显然,对于一个关系A<B,我们有dis[A]< ...

  2. Nginx代理自动上线下线

    Nginx基于连接探测,如果发现后端异常,在单位周期为fail_timeout设置的时间,中达到max_fails次数,这个周期次数内,如果后端同一个节点不可用,那么接将把节点标记为不可用,并等待下一 ...

  3. promise和async/await的用法

    promise和async都是做异步处理的, 使异步转为同步 1.promise 它和Promise诞生的目的都是为了解决“回调地狱”, promise使用方法: <button @click= ...

  4. getchar、putchar、puts、gets

    getchar(字符)  输入获取一个字符 putchar(字符)  输出控制台一个字符 scanf()格式化输入 printf() 格式化输出 gets(arr) 输入一个字符串给已经声明的数组ar ...

  5. 剑指offer 打印从1到最大的n位数

    题目描述: 输入数字n,按顺序打印出从1到最大的n位十进制数.比如输入3,则打印出1.2.3一直到最大的3位数999. 分析:注意不能直接输入最大的n位十进制数,因为可能属于大数,这个数无法用int或 ...

  6. Centos克隆虚拟机后配置网络

    修改网卡相关信息,复制第二个网卡的mac地址. vim /etc/udev/rules.d/70-persistent-net.rules 修改网卡的信息 vim /etc/sysconfig/net ...

  7. 一、.net core 集成vue

    一.npm安装WebPack (这种情况就会出现在项目外部,只不过借用VS的程序包管理器控制台获取而已) 右击新建项目创建webpack

  8. 解决tcp粘包

    粘包现象:只有tcp协议才会产生粘包,udp协议不会产生粘包 1.tcp协议下,发送端会采用一个优化算法(Nagle算法),把间隔时间短,数据比较小的包合并到一起,再一起发送过去,造成粘包 2.发送端 ...

  9. linux如何在shell中自动生成1到100的数组

    之前自己在写shell脚本的时候,需要自动创建1-100的文本确不知道该如何去创建.百度一翻终于知道了创建的方法. 在shell脚本中创建1-100的方法很多,那我在这里主要就说两种容易理解且方便的方 ...

  10. 配置本地yum仓库

        前言 我们知道yum工具是基于rpm的,其一个重要的特性就是可以自动解决依赖问题,但是yum的本质依旧是把后缀名.rpm的包下载到本地,然后按次序安装之.但是每次执行yum install x ...