目录
一:@RequestBody
二:@RequestBody获取json格式的请求参数
三:@ResponseBody
四:@ResponseBody响应浏览器json数据
五:@RestController注解
准备工作:
①创建maven工程
②添加相关依赖,和添加web模块
③配置web.xml,如配置处理1.编码过滤器,2.请求方式的过滤器,3.前端控制器
④创建springmvc.xml,并进行配置
⑤创建控制层controller
一:@RequestBody
index.html
axios({
url:"",//请求路径
method:"",//请求方式
//以name=value&name=value的方式发送的请求参数
//不管使用的请求方式是get或post,请求参数都会被拼接到请求地址后
//此种方式的请求参数可以通过request.getParameter()获取
params:{},
//以json格式发送的请求参数
//请求参数会被保存到请求报文的请求体传输到服务器
//此种方式的请求参数不可以通过request.getParameter()获取
data:{}
}).then(response=>{
console.log(response.data);
});
<div id="app">
<h1>index.html</h1>
<input type="button" value="测试SpringMVC处理ajax" @click="testAjax()">
</div>
<script type="text/javascript" th:src="@{/js/vue.js}"></script>
<script type="text/javascript" th:src="@{/js/axios.min.js}"></script>
<script type="text/javascript">
var vue = new Vue({
el:"#app",
methods:{
testAjax() {
axios.post(
"/SpringMVC/test/ajax?id=1001",
{username:"admin",password:"123456"}
).then(response=>{
console.log(response.data);
});
}
}
});
</script>
没有ajax就只能使用超链接和form表单跟后端交互数据,很不方便而且很多功能实现不了
@RequestBody可以获取请求体信息,使用@RequestBody注解标识控制器方法的形参,当前请求的请求体就会为当前注解所标识的形参赋值
注:
1.@RequestBody:将请求体中的内容和控制器方法的形参进行绑定
@RequestMapping("/test/ajax")
public void testAjax(Integer id, @RequestBody String requestBody, HttpServletResponse response) throws IOException {
System.out.println("requestBody:" + requestBody);
System.out.println("id:" + id);
response.getWriter().write("hello,axios");
}
二:@RequestBody获取json格式的请求参数
index.html
<input type="button" value="使用@RequestBody注解处理json格式的请求参数" @click="testRequestBody()">
在使用了axios发送ajax请求之后,浏览器发送到服务器的请求参数有两种格式:
1、name=value&name=value...,此时的请求参数可以通过request.getParameter()获取,对应 SpringMVC中,可以直接通过控制器方法的形参获取此类请求参数
2、{key:value,key:value,...},此时无法通过request.getParameter()获取,之前我们使用操作 json的相关jar包gson或jackson处理此类请求参数,可以将其转换为指定的实体类对象或map集 合。在SpringMVC中,直接使用@RequestBody注解标识控制器方法的形参即可将此类请求参数 转换为java对象
testRequestBody() {
axios.post(
"/SpringMVC/test/RequestBody/json",
{username:"admin",password:"123456",age:23,gender:"男"}
).then(response=>{
console.log(response.data);
});
}
然后来控制层处理一下
注:使用@RequestBody获取json格式的请求参数的条件:
2.使用@RequestBody注解将json格式的请求参数转换为java对象
a>导入jackson的依赖
b>在SpringMVC的配置文件中设置<mvc:annotation-driven/>
c>在处理请求的控制器方法的形参位置,直接设置json格式的请求参数要转换的java类型的形参,使用@RequestBody注解标识即可
jackson依赖
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.12.1</version>
</dependency>
开启注解驱动
<mvc:annotation-driven />
方式一:接收成实体类
@RequestMapping("/test/RequestBody/json")
public void testRequestBody(@RequestBody User user, HttpServletResponse response) throws IOException {
System.out.println(user);
response.getWriter().write("hello,RequestBody");
}
方式二:接收成map集合
@RequestMapping("/test/RequestBody/json")
public void testRequestBody(@RequestBody Map<String,Object> map, HttpServletResponse response) throws IOException {
System.out.println(map);
response.getWriter().write("hello,RequestBody");
}
三:@ResponseBody
@ResponseBody用于标识一个控制器方法,可以将该方法的返回值直接作为响应报文的响应体响应到浏览器
<a th:href="@{/test/ResponseBody}">测试@ResponseBody注解响应浏览器数据</a>
@RequestMapping("/test/ResponseBody")
@ResponseBody
public String testResponseBody() {
return "success";
}
四:@ResponseBody响应浏览器json数据
4.使用@ResponseBody注解响应浏览器json格式的数据
a>导入jackson的依赖
b>在SpringMVC的配置文件中设置<mvc:annotation-driven/>
c>将需要转换成json字符串的java对象直接作为控制器方法的返回值,使用@ResponseBody注解来标识控制器方法就可以将java对象直接转换为json字符串,并响应到浏览器
实体类-->json对象
@RequestMapping("/test/ResponseBody/json")
@ResponseBody
public User testResponseBodyJson() {
User user = new User(1001,"admin","123456",20,"男");
return user;
}
map-->json对象
@RequestMapping("/test/ResponseBody/json")
@ResponseBody
public Map<String,Object> testResponseBodyJson() {
User user1 = new User(1001,"admin1","123456",20,"男");
User user2 = new User(1001,"admin2","123456",20,"男");
User user3 = new User(1001,"admin3","123456",20,"男");
Map<String,Object> map = new HashMap<>();
map.put("1001",user1);
map.put("1002",user2);
map.put("1003",user3);
return map;
}
list-->json数组
@RequestMapping("/test/ResponseBody/json")
@ResponseBody
public List<User> testResponseBodyJson() {
User user1 = new User(1001,"admin1","123456",20,"男");
User user2 = new User(1001,"admin2","123456",20,"男");
User user3 = new User(1001,"admin3","123456",20,"男");
List<User> list = Arrays.asList(user1, user2, user3);
return list;
}
常用的Java对象转换为json的结果:
实体类-->json对象
map-->json对象
list-->json数组
五:@RestController注解
@RestController注解是springMVC提供的一个复合注解,标识在控制器的类上,就相当于为类添加了 @Controller注解,并且为其中的每个方法添加了@ResponseBody注解