首页 > Web开发 > 详细

@RequestBody和@RequestParam注解以及返回值,ajax相关知识点

时间:2020-03-18 09:58:46      阅读:128      评论:0      收藏:0      [点我收藏+]

  关于前后端传递json数据这块查了好多资料,好多地方还是不清楚,先记录一下清楚的地方。

  如果我们前端使用ajax发json数据,一般都加上contentType:‘application/json;charset=utf-8‘,如果加上这个,那么后端一定得使用@RequestBody接收,这俩是成对出现的,然后@ResponseBody只能接收请求体的数据所以只能接post请求,然后使用了application/json这种形式只能发送json字符串。

  同样的,如果不加application/json那么后端一般使用@RequestParam接收,@RequestParam接收的是地址栏的数据所以只能接get请求,这个时候前台不能发json字符串,可以发json对象。

  ajax有三种传递data的方式:json对象{“username”:”chen”,”nickname”:”alien”}、json字符串’{“username”:”chen”,”nickname”:”alien”}‘,只能用单引号、标准参数name=chen&id=3,感觉json形式用的多点。

  如果后端要跳页面的时候返回值类型必须是String,这个时候不能加@ResponseBody或者@RestController注解,因为这两个注解会将返回数据解析成字符串,如果返回值是对象会返回json对象。如果不想在后端跳页面,可以在前端利用ajax,在回调函数中使用window.location.href="xxx.html";跳转页面。

  后端接收未使用@RequestBody注解,只有对象作为参数接收,打印出来是引用地址,如果是@RequestBody,打印出来是json对象。在后台service层都可以直接做参数使用,没有区别,具体有啥区别不清楚。

  

  

@RequestBody和@RequestParam注解以及返回值,ajax相关知识点

原文:https://www.cnblogs.com/coderxiaobai/p/12514786.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!