RESTful

REST风格

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

在上面的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'}";
    }

你可能感兴趣的:(restful,java,spring)