@ResponseBody返回4种数据格式的数据
1、返回一个键值对或者集合
前端JS请求:
- //返回值为map的形式
- $(".name").blur(function(){
- $.ajax({
- type:"Post",//请求类型
- url:"/mvc-demo/user/nameProving?t="+new Date().getTime(),//请求的url
- data:{name:$(".name").val()},//请求参数
- dataType:"json",//ajax接口(请求url)返回的数据类型
- success:function(data){//data:返回数据(json对象)
- if(data.name == "empty"){//name为空,错误提示
- $(".errorFont").text("用户名为不能为空!");
- $(".errorFont").css("color","red");
- }else if(data.name == "exist"){
- $(".errorFont").text("用户名已注册");
- $(".errorFont").css("color","green");
- }else if(data.name == "noexist"){
- $(".errorFont").text("用户名未注册");
- $(".errorFont").css("color","red");
- }
- },
- error:function(data){
- $(".errorFont").text("发生未知错误,请联系管理员!");
- $(".errorFont").css("color","red");
- }
- });
- });
后端逻辑处理:
- //验证用户是否存在,返回一个键值对的数据
- @RequestMapping("/nameProving")
- @ResponseBody
- public Object nameProving(String name){
- HashMap<String,String> resultMap=new HashMap<String,String>();
- if(StringUtils.isEmpty(name)){
- resultMap.put("name", "empty");
- }else{
- Userss user=userService.getUserByName(name);
- if(user!=null)
- resultMap.put("name", "exist");
- else
- resultMap.put("name", "noexist");
- }
- return JSONArray.toJSONString(resultMap);
- }
2、返回一个JSON格式的String字符串
前端js请求:
- //返回值为String的形式,dataType:"json"
- $(".name").blur(function(){
- $.ajax({
- type:"Post",//请求类型
- url:"/mvc-demo/user/nameProving2?t="+new Date().getTime(),//请求的url
- data:{name:$(".name").val()},//请求参数
- dataType:"json",//ajax接口(请求url)返回的数据类型
- success:function(data){//data:返回数据(json对象)
- if(data == "empty"){//name为空,错误提示
- $(".errorFont").text("用户名为不能为空2!");
- $(".errorFont").css("color","red");
- }else if(data== "exist"){
- $(".errorFont").text("用户名已注册2");
- $(".errorFont").css("color","green");
- }else if(data == "noexist"){
- $(".errorFont").text("用户名未注册2");
- $(".errorFont").css("color","red");
- }
- },
- error:function(data){
- $(".errorFont").text("发生未知错误,请联系管理员2!");
- $(".errorFont").css("color","red");
- }
- });
- });
后端逻辑处理:
- //验证用户是否存在,返回一个转成json字符串的数据
- @RequestMapping("/nameProving2")
- @ResponseBody
- public String nameProving2(String name){
- String result="";
- if(StringUtils.isEmpty(name)){
- result= "empty";
- }else{
- Userss user=userService.getUserByName(name);
- if(user!=null)
- result= "exist";
- else
- result= "noexist";
- }
- return JSONArray.toJSONString(result);
- }
3、返回一个字符串
前端js请求:
重点:datatype:"text"
- //返回值为String的形式,dataType:"text"
- $(".name").blur(function(){
- $.ajax({
- type:"Post",//请求类型
- url:"/mvc-demo/user/nameProving3?t="+new Date().getTime(),//请求的url
- data:{name:$(".name").val()},//请求参数
- dataType:"text",//ajax接口(请求url)返回的数据类型
- success:function(data){//data:返回数据(json对象)
- if(data == "\"empty\""){//name为空,错误提示
- $(".errorFont").text("用户名为不能为空3!");
- $(".errorFont").css("color","red");
- }else if(data== "\"exist\""){
- $(".errorFont").text("用户名已注册3");
- $(".errorFont").css("color","green");
- }else if(data == "\"noexist\""){
- $(".errorFont").text("用户名未注册3");
- $(".errorFont").css("color","red");
- }
- },
- error:function(data){
- $(".errorFont").text("发生未知错误,请联系管理员3!");
- $(".errorFont").css("color","red");
- }
- });
- });
后端逻辑处理:
- //验证用户是否存在,返回一个字符串的数据
- /**
- * 此方法中有多个注解 method:指定请求方式
- * required:表示参数是否必须 默认为必须 fslse为不是必须
- * @param name
- * @return
- */
- @RequestMapping(value="/nameProving3",method=RequestMethod.POST,params="name")
- @ResponseBody
- public String nameProving3(@RequestParam(value="name",required=false)String name){
- String result="";
- if(StringUtils.isEmpty(name)){
- result= "empty";
- }else{
- Userss user=userService.getUserByName(name);
- if(user!=null)
- result= "exist";
- else
- result= "noexist";
- }
- return result;
- }
4、返回一个类对象的数据
前端js请求:
- //返回值为类对象的形式,dataType:"json"
- $(".name").blur(function(){
- $.ajax({
- type:"Post",//请求类型
- url:"/mvc-demo/user/nameProving4?t="+new Date().getTime(),//请求的url
- data:{name:$(".name").val()},//请求参数
- dataType:"json",//ajax接口(请求url)返回的数据类型
- success:function(data){//data:返回数据(json对象)
- if(data == null){//name为空,错误提示
- $(".errorFont").text("用户名为空或者用户名不存在4!");
- $(".errorFont").css("color","red");
- }else{
- $(".errorFont").text("用户名"+data.name+"已注册4");
- $(".errorFont").css("color","green");
- }
- },
- error:function(data){
- $(".errorFont").text("发生未知错误,请联系管理员2!");
- $(".errorFont").css("color","red");
- }
- });
- });
后端逻辑处理:
- //返回一个类对象
- @RequestMapping("/nameProving4")
- @ResponseBody
- public Userss nameProving4(String name){
- System.out.println("进来了4");
- Userss user=userService.getUserByName(name);
- if(user==null){
- return null;
- }
- return user;
- }
@ResponseBody返回4种数据格式的数据的更多相关文章
- Springboot @ResponseBody返回中文乱码
最近我在把Spring 项目改造Springboot,遇到一个问题@ResponseBody返回中文乱码,因为response返回的content-type一直是application/json;ch ...
- Python实现接口测试中的常见四种Post请求数据
前情: 在日常的接口测试工作中,模拟接口请求通常有两种方法, 利用工具来模拟,比如fiddler,postman,poster,soapUI等 利用代码来模拟,使用到一些网络模块,比如HttpClie ...
- @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 ...
- 计算机系统之汇编---IA32处理器数据格式及数据操作
计算机系统之汇编---IA32处理器数据格式及数据操作 IA32数据格式: Intel用术语"字"表示16位数据类型,因此.称32位数为"双字",称64位数为& ...
- 解决SpringMVC的@ResponseBody返回中文乱码
SpringMVC的@ResponseBody返回中文乱码的原因是SpringMVC默认处理的字符集是ISO-8859-1,在Spring的org.springframework.http.conve ...
- ArcGIS几种数据格式
ArcGIS几种数据格式 ArcInfo常用以下格式的数据:shp.Coverage..Raster CAD和Geodatabase.各种数据的组织形式不一样,其中shp.Coverage.Raste ...
- iOS五种本地缓存数据方式
iOS五种本地缓存数据方式 iOS本地缓存数据方式有五种:前言 1.直接写文件方式:可以存储的对象有NSString.NSArray.NSDictionary.NSData.NSNumber,数据 ...
- SpringMVC3的ResponseBody返回字符串(JSON)乱码问题解决
近日做一个小项目,用spring mvc 做到ajax请求获取jquery ztree 异步获取树返回json对象时出现了乱码,试了各种办法,查了各种资料,一开始以为是数据库的编码有问题,经测试没问题 ...
- [svc]二三层数据格式&&三层数据如何匹配路由
网络知识拾遗 tcpip的4&7层模型 PDU数据包在不同层的不同称呼 物理层(一层)PDU指数据位(Bit). 数据链路层(二层)PDU指数据帧(Frame). 网络层(三层)PDU指数据包 ...
随机推荐
- 洛谷P1347 排序
这个题看到很多人写Topo排序,其实这道题第一眼看更像是一个差分约束的裸题QWQ... 令dis[x]表示x的相对大小(1是最小,n是最大),显然,对于一个关系A<B,我们有dis[A]< ...
- Nginx代理自动上线下线
Nginx基于连接探测,如果发现后端异常,在单位周期为fail_timeout设置的时间,中达到max_fails次数,这个周期次数内,如果后端同一个节点不可用,那么接将把节点标记为不可用,并等待下一 ...
- promise和async/await的用法
promise和async都是做异步处理的, 使异步转为同步 1.promise 它和Promise诞生的目的都是为了解决“回调地狱”, promise使用方法: <button @click= ...
- getchar、putchar、puts、gets
getchar(字符) 输入获取一个字符 putchar(字符) 输出控制台一个字符 scanf()格式化输入 printf() 格式化输出 gets(arr) 输入一个字符串给已经声明的数组ar ...
- 剑指offer 打印从1到最大的n位数
题目描述: 输入数字n,按顺序打印出从1到最大的n位十进制数.比如输入3,则打印出1.2.3一直到最大的3位数999. 分析:注意不能直接输入最大的n位十进制数,因为可能属于大数,这个数无法用int或 ...
- Centos克隆虚拟机后配置网络
修改网卡相关信息,复制第二个网卡的mac地址. vim /etc/udev/rules.d/70-persistent-net.rules 修改网卡的信息 vim /etc/sysconfig/net ...
- 一、.net core 集成vue
一.npm安装WebPack (这种情况就会出现在项目外部,只不过借用VS的程序包管理器控制台获取而已) 右击新建项目创建webpack
- 解决tcp粘包
粘包现象:只有tcp协议才会产生粘包,udp协议不会产生粘包 1.tcp协议下,发送端会采用一个优化算法(Nagle算法),把间隔时间短,数据比较小的包合并到一起,再一起发送过去,造成粘包 2.发送端 ...
- linux如何在shell中自动生成1到100的数组
之前自己在写shell脚本的时候,需要自动创建1-100的文本确不知道该如何去创建.百度一翻终于知道了创建的方法. 在shell脚本中创建1-100的方法很多,那我在这里主要就说两种容易理解且方便的方 ...
- 配置本地yum仓库
前言 我们知道yum工具是基于rpm的,其一个重要的特性就是可以自动解决依赖问题,但是yum的本质依旧是把后缀名.rpm的包下载到本地,然后按次序安装之.但是每次执行yum install x ...