REST风格
是一种风格,而不是编码规范,一种心照不宣的请求参数的方式,按照以下来写访问路径,会更规范,即使下图中有些路径名一样,但是后面缀的GET
、PUT``POST
也会变成区分最终路径的依据
@RequestMapping中加参数method = RequestMethod.PUT/GET/POST/DELETE等
下面的users
可以为books
也可以为别的,别忘了都要加s
PUT:根据"/users/{id}"
来传递参数id,从而指定用户,方法中应当也有参数名id,别忘了id前加注解@PathVariable,表示从路径获得
@RequestMapping(value = "/users/{id}",method = RequestMethod.PUT)
//返回给浏览器的响应数据
@ResponseBody
//参数id应该与上面的{id}一致,这样上面的就直接找过来并且传参了
public String save(String name ,@PathVariable int id){
System.out.println("spring.......mvc.."+name+"的id是"+id);
return "{'name':'zhangsan'}}"+id;
}
POST:只有post可以接触中文乱码,因为我这里只写了过滤器来解决post请求中文乱码问题
@RequestMapping(value = "/users",method = RequestMethod.POST)
@ResponseBody
//请求参数作为数据与下面注解中的参数应当一致,
//下面注解表示请求参数name和username关联起来
//后面的age没有指定的话,应当是默认注解@。。。。。。。("age")
public String save1(@RequestParam("name") String username, int age){
System.out.println("save....1....."+username+"的年龄"+age);
return "{'name':'lisi'}";
}
GET:
@RequestMapping(value = "/users",method = RequestMethod.GET)
@ResponseBody
//请求参数名应当与实体类中的属性名一致
public String save2(User user){
System.out.println("save....2....."+user.toString());
return "{'name':'wangwu'}";
}
总结一下:
- @RequestMapping有路径和
method
参数 - 指定一个用户等,@RequestMapping中的路径添加
/{参数7}
,且当前方法中参数应该至少有一个参数名叫参数7
,且在其前加注解@PathVariable
几种用在方法中的注解:
在上面的REST格式下,可以进一步简化,首先用到之前学的拼接路径,即,将每一个路径前面相同的部分进行抽取,放在类的注解@RequestMapping
中,不一样的部分留下即可,所以有些方法中的@value就可以直接删除了:
package com.itjh.servletmvc;
import com.itjh.pojo.User;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
@Controller
@RequestMapping("/users")
//控制器
public class sermvc {
//请求时的访问路径
@RequestMapping(value = "/{id}",method = RequestMethod.PUT)
//返回给浏览器的响应数据
@ResponseBody
public String save(String name ,@PathVariable int id){
System.out.println("spring.......mvc.."+name+"的id是"+id);
return "{'name':'zhangsan'}}"+id;
}
@RequestMapping(method = RequestMethod.POST)
@ResponseBody
//请求参数作为数据与下面注解中的参数应当一致,
//下面注解表示请求参数name和username关联起来
//后面的age没有指定的话,应当是默认注解@。。。。。。。("age")
//postman传两个参数进来
public String save1(@RequestParam("name") String username, int age){
System.out.println("save....1....."+username+"的年龄"+age);
return "{'name':'lisi'}";
}
@RequestMapping(method = RequestMethod.GET)
@ResponseBody
//请求参数名应当与实体类中的属性名一致
public String save2(User user){
System.out.println("save....2....."+user.toString());
return "{'name':'wangwu'}";
}
这时候会发现每一个方法上面都有注解@ResponseBody,于是可以抽出来和上面的做法一样,放在类上面,表示当前类中每一个方法都是响应方法
@Controller
@ResponseBody
@RequestMapping("/users")
//控制器
public class sermvc {
这时候又可以将@Controller和@ResponseBody合并起来得到注解@RestController
@RestController
@RequestMapping("/users")
//控制器
public class sermvc {
然后又发现每一个方法上面的@RequestMapping里面参数method
只有一点点不同,所以根据那一点不同(.GET``.POST
等)重新写一个注解,表示出这个不同即可
package com.itjh.servletmvc;
import com.itjh.pojo.User;
import org.springframework.web.bind.annotation.*;
@RestController
@RequestMapping("/users")
//控制器
public class sermvc {
//请求时的访问路径
@PutMapping(value = "/{id}")
//返回给浏览器的响应数据
public String save(String name ,@PathVariable int id){
System.out.println("spring.......mvc.."+name+"的id是"+id);
return "{'name':'zhangsan'}}"+id;
}
@PostMapping
//请求参数作为数据与下面注解中的参数应当一致,
//下面注解表示请求参数name和username关联起来
//后面的age没有指定的话,应当是默认注解@。。。。。。。("age")
//postman传两个参数进来
public String save1(@RequestParam("name") String username, int age){
System.out.println("save....1....."+username+"的年龄"+age);
return "{'name':'lisi'}";
}
@GetMapping
//请求参数名应当与实体类中的属性名一致
public String save2(User user){
System.out.println("save....2....."+user.toString());
return "{'name':'wangwu'}";
}