不用jsp怎么实现前后端交互?给萌新后端的ajax教程(2)

一、上一篇文章留下的问题

  上一篇文章我们讲了一个AJAX请求的写法,还使用AJAX请求进行了前端向后端发送数据、后端向前端发送数据的演示。

  但小伙伴还记不记得我们上次把dataType:”json”;这句话注释掉了呢?不妨试试去掉注释符号,看看加上这句话是什么结果。

  我们可以发现前端的注释可以顺利传到后端,也打印出了该有的结果,但是前端的弹窗消失了,甚至打开浏览器的控制台也看不到报错信息,但是就是没有弹窗,这是为什么呢?

  其实ajax请求不止包含一个success函数,还包含一个error函数。

  我们去掉dataType前面的注释符号,然后在ajax请求里面加上一个error函数,并且测试一下弹窗:

function testajax() {

  var text=document.getElementById("txt").value;

  $.ajax({

    url:"test",

    contentType:"application/json;charset=UTF-8",

    type:"post",

    data:JSON.stringify({

      "k":"123",

      "heihei":text

    }),

    dataType:"json",

    async:true,

    success:function(data){

      alert(data);

    },

    error(data){

      alert("进入了error......");

  }

});

  运行我们的项目,会发现出现了这个弹窗

  那么为什么明明没有报错,它却进入了error方法呢?

  我们之前讲过,dataType规定的是后端向前端传递的是什么数据,那这是不是说明,我们回传的数据不符合json格式呢?

  打开我们的Controller方法,我们发现我们写的返回值是String

  原来,在ajax里,基本类型和String是不会被当成json来传递的,只有自定义的对象、List或Map等集合类才会被当成json传递。

  我们来修改一下我们的代码:

public @ResponseBody List<String> testAJAX(@RequestBody TestDomain t){

  System.out.println(t.getHeihei());

  System.out.println(t.getK());

  System.out.println(t);

  List<String>L=new ArrayList<>();

  L.add("ok");

  return L;

}

  我们修改了什么内容呢?我们把返回值变成了一个List,并且把“ok”这个字符串添加到了List里来返回了,哪怕它只有一个元素,它也是个List

我们来运行一下看看结果:

我们的success函数果然执行了,又出现了熟悉的ok弹窗。

因此如果你想返回一个基本类型的数据,想在success中执行,可以不加dataType。

二、非json传值方式的中文编码问题

可是此时如果我们把return “ok”改成return “好的”,给前端回传一个中文字符串呢?

我们试试。

  诶,怎么变成问号了?大概是没能识别编码吧?该怎么做呢?

错误演示:

  给dataType写成dataType:”charset=UTF-8”,然后你会发现它进入了error函数,甚至传给error的还是俩问号。

  原因是dataType并不能帮助我们转换编码,它只是起到一个判断的作用,此处如果编码是UTF-8就执行success函数,如果不是UTF-8就执行error函数,显然这里的字符串不是UTF-8编码。

正确演示:

  我们应该在后端设置返回的字符串的编码。设置方式是在@RequstMapping中加上produces属性,produces属性可以设置返回值的类型和返回的编码,修改后变成

@RequestMapping(value = "/test",produces = "text/html;charset=UTF-8")

执行后正确显示汉字:

另:调用response的setContentType方法和要返回的字符串通过getBytes()方式设置不可行。原因是返回的数据经过了@ResponseBody的处理又变成了ISO编码

另外返回json时中文编码是正常的,所以也可以选择返回一个只有一个字符串的List,然后设置dataType:”json”

三、后端获取AJAX从前端传递数据的其他方式

  如果我们想做一个登录模块,就需要获取Session,或者我们仅仅只是想给Controller层的函数加上其他参数。那我们应该怎么做呢?我们只需要在Controller层的函数参数里加上request,然后调用request.getSession()方法就可以了。

如图,我们在给函数加上参数,并且打印一下获得的Session:

运行一下,点击前端的按钮:

  我们成功获取到Session了

  那我们每次接收数据,如果数据超过一对键值对,就要封装成对象,好麻烦啊,可不可以不用封装成对象直接接收呢?

  答案当然是可以的。

  @RequestBody,看名字就是请求体,如果你了解一点Http的相关知识(不了解也没关系,可以听我简要讲讲或者自己动动小手搜索一下),会知道Http请求由请求头、请求行、请求体三部分组成。我们从前端传回来的数据是装在请求体里的,而这个注解就是获取了请求的请求体,并且转换成已有的对象啦。

  那我们在上上张图已经获取到了请求(request),可以自己从请求体里面拿到发送的数据呀!

  我们再修改一下Controller函数:

@RequestMapping("/test")

public @ResponseBody List<String> testAJAX( HttpServletRequest request) {

  System.out.println(request.getParameter("k"));

  System.out.println(request.getParameter("heihei"));

  List<String>L=new ArrayList<>();

  L.add("ok");

  return L;

}

  request.getParmameter(“k”)是用于获取key的名字为“k”的值的函数。

  同时我们再修改一下前端的ajax请求,把contentType去掉,顺便把data里用来把键值对json化的Json.stringfy去掉,代码会变成如下:

$.ajax({

    url:"test",

    type:"post",

    data:{

        "k":"123",

        "heihei":text

    },

    dataType:"json",

    async:true,

    success:function(data){

        alert(data);

    },

    error(data){

        alert("进入了error......");

    }

});

  我们可以发现值也被传过来了

  那我们为什么要修改前端的ajax请求呢?目的是让前端不再以把数据变成json再发送,在有@RequestBody的时候,这个注解会帮助我们解析json。可是如今我们没有这个注解了,自己无法解析json,应该让前端传过来普通的数据。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容