> 文章列表 > RESTful

RESTful

RESTful

REST风格

是一种风格,而不是编码规范,一种心照不宣的请求参数的方式,按照以下来写访问路径,会更规范,即使下图中有些路径名一样,但是后面缀的GETPUT``POST也会变成区分最终路径的依据
@RequestMapping中加参数method = RequestMethod.PUT/GET/POST/DELETE等
下面的users可以为books也可以为别的,别忘了都要加s
RESTful
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

几种用在方法中的注解:
RESTful

在上面的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)//返回给浏览器的响应数据@ResponseBodypublic 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'}";}