Rest风格

Rest风格

一、Rest风格概论

Rest,表先形式状态转化

传统风格资源描述形式:

  • http://localhost/user/getById?id=1

而Rest风格描述形式:

  • http://localhost/user/1

显而易见,Rest风格有以下优势:

  • 隐藏资源的访问行为,无法通过地址得知对资源是哪种操作
  • 简化书写

二、Rest风格入门

Rest风格访问资源时使用行为动作区分对资源进行了哪种操作

url作用请求方式
http://localhost/user查询全部用户的信息GET(查询)
http://localhost/user/1查询指定用户的信息GET(查询)
http://localhost/users添加用户信息POST(新增/保存)
http://localhost/users修改用户信息PUT(修改/更新)
http://localhost/user/1删除用户信息DELETE(删除)

以上的行为均为约定方式

所谓约定方式就是大家说好了的,不是规范可以打破,所以称为REST风格,而不是REST规范

描述模块的名称通常使用复数,也就是加s的格式描述,表示该类资源,而并非单个资源,例如users、books…

根据Rest风格对资源的访问称为Restful


三、Rest代码操作

案例:将以下代码改装为Rest风格


@Controller
public class bookController {

    @RequestMapping("/save")
    @ResponseBody
    public String save(){
        System.out.println("user save....");
        return "{'module':'user save'}";
    }

    @RequestMapping("/delete")
    @ResponseBody
    public String delete(int id){
        System.out.println("user delete...." + id);
        return "{'module':'user delete'}";
    }

    @RequestMapping("/update")
    @ResponseBody
    public String update(@RequestBody User user){
        System.out.println("user update...." + user);
        return "{'module':'user update'}";
    }

    @RequestMapping("/getById")
    @ResponseBody
    public String getById(int id){
        System.out.println("user getById...." + id);
        return "{'module':'user getById'}";
    }

}

注意:

  • @RequestBody接受的是一个json格式的字符串,一定是一个json对象字符串。
  • 在使用springmvc的做项目时,将JSON字符串和JSON对象混淆了。
  • .@RequestParam接受单个参数,参数位置位于链接后。@RequestBody接受JSON对象字符串,参数位置位于请求体。

初步修改

@Controller
public class bookController {

    @RequestMapping(value = "/books", method = RequestMethod.POST)
    @ResponseBody
    public String save(){
        System.out.println("user save....");
        return "{'module':'user save'}";
    }

    @RequestMapping(value = "/books/{id}", method = RequestMethod.DELETE)
    @ResponseBody
    public String delete(@PathVariable int id){
        System.out.println("user delete...." + id);
        return "{'module':'user delete'}";
    }

    @RequestMapping(value = "/books", method = RequestMethod.PUT)
    @ResponseBody
    public String update(@RequestBody User user){
        System.out.println("user update...." + user);
        return "{'module':'user update'}";
    }

    @RequestMapping(value = "/books/{id}", method = RequestMethod.GET)
    @ResponseBody
    public String getById(@PathVariable int id){
        System.out.println("user getById...." + id);
        return "{'module':'user getById'}";
    }

}

这里的修改主要是制定了是请求方式和进行参数绑定

但是这里的重复代码依然是很多

简化操作:

  • 将/books提到外面去
  • 每个方法都有@ResponseBody,将@ResponseBody也提到外面(注意如果里面有某个方法不带@ResponseBody,则不可提到外面去)
  • 这时候外面有三个注解@Controller、@ResponseBody、 @RequestMapping,则可以用@RestController代替@Controller和@ResponseBody
  • 将Post等请求改为相应注解
// @Controller
// @ResponseBody
@RestController
@RequestMapping("/books")
public class bookController {

    // @RequestMapping(method = RequestMethod.POST)
    @PostMapping
    public String save(){
        System.out.println("user save....");
        return "{'module':'user save'}";
    }

    // @RequestMapping("/{id}", method = RequestMethod.DELETE)
    @DeleteMapping("/{id}")
    public String delete(@PathVariable int id){
        System.out.println("user delete...." + id);
        return "{'module':'user delete'}";
    }

    // @RequestMapping( method = RequestMethod.PUT)
    @PutMapping
    public String update(@RequestBody User user){
        System.out.println("user update...." + user);
        return "{'module':'user update'}";
    }

    // @RequestMapping(value = "/{id}", method = RequestMethod.GET)
    @GetMapping("/{id}")
    public String getById(@PathVariable int id){
        System.out.println("user getById...." + id);
        return "{'module':'user getById'}";
    }

}


  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

起名方面没有灵感

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值