[SpringMVC]3.RestFul风格

概念

Restful就是一个资源定位及资源操作的风格。不是标准也不是协议,只是一种风格。基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制。

功能

资源:互联网所有的事物都可以被抽象为资源

资源操作:使用POST、DELETE、PUT、GET,使用不同方法对资源进行操作,分别对应 添加、 删除、修改、查询。

传统方式操作资源 :通过不同的参数来实现不同的效果!方法单一,post 和 get

http://127.0.0.1/item/queryItem.action?id=1 查询,GET

http://127.0.0.1/item/saveItem.action 新增,POST

http://127.0.0.1/item/updateItem.action 更新,POST

http://127.0.0.1/item/deleteItem.action?id=1 删除,GET或POST

使用RESTful操作资源 :可以通过不同的请求方式来实现不同的效果!如下:请求地址一样,但是功能可以不同!

http://127.0.0.1/item/1 查询,GET

http://127.0.0.1/item 新增,POST

http://127.0.0.1/item 更新,PUT

http://127.0.0.1/item/1 删除,DELETE

测试

1.新创建一个类RestFulController
2.在SpringMVC中可以使用 @PathVariable 注解,让方法参数的值对应绑定到一个URI模板变量。

@Controller
public class RestFulController {


    //原来的 : http://localhost:8080/springmvc_04_controller_war_exploded/add?a=1&b=1

    //RestFul : http://localhost:8080/springmvc_04_controller_war_exploded/add/a/b

    @RequestMapping(value = "/add/{a}/{b}")
    public String test1(@PathVariable int a,@PathVariable int b, Model model){

        int res = a + b;

        model.addAttribute("msg","结果为"+res);

        return "test";
    }

3.测试请求
add/1/2
在这里插入图片描述

4.我们修改一下对应的参数类型

@Controller
public class RestFulController {


    //原来的 : http://localhost:8080/springmvc_04_controller_war_exploded/add?a=1&b=1

    //RestFul : http://localhost:8080/springmvc_04_controller_war_exploded/add/a/b

    @RequestMapping(value = "/add/{a}/{b}")
    //@GetMapping("/add/{a}/{b}")
    public String test1(@PathVariable int a,@PathVariable String b, Model model){

        String res = a + b;

        model.addAttribute("msg","结果为"+res);

        return "test";
    }

}

在这里插入图片描述

使用路径变量的好处:

  • 使路径变得更加简洁
  • 获得参数更加方便,框架会自动进行类型转换
  • 通过路径变量的类型可以约束访问参数,如果类型不一样,则访问不到对应的请求方法,如这里访问是的路径是/commit/1/a,则路径与方法不匹配,而不会是参数转换失败

使用method属性指定请求类型

用于约束请求的类型,可以收窄请求范围。
指定请求谓词的类型如GET, POST, HEAD, OPTIONS, PUT, PATCH, DELETE, TRACE等

测试

我们在@RequestMapping 注解中增加一个参数method,可以指定请求的类型!

1.比如我们指定为Post

    @RequestMapping(value = "/add/{a}/{b}",method = RequestMethod.POST)
    public String test1(@PathVariable int a,@PathVariable String b, Model model){

        String res = a + b;

        model.addAttribute("msg","结果为"+res);

        return "test";
    }

2.可以看到,因为浏览器默认的请求方法为GET,所以我们用POST方法请求时,会报错405
在这里插入图片描述
3.我们把请求方法改为GET,可以看到就可以正常请求了!
在这里插入图片描述

小结

Spring MVC 的 @RequestMapping 注解能够处理 HTTP 请求的方法:
比如 GET, PUT, POST, DELETE 以及 PATCH。

所有的地址栏请求默认都会是 HTTP GET 类型的。

方法级别的注解变体有如下几个:组合注解

@GetMapping
@PostMapping
@PutMapping
@DeleteMapping
@PatchMapping

@GetMapping 是一个组合注解,平时使用的会比较多,它所扮演的是 @RequestMapping(method =RequestMethod.GET) 的一个快捷方式。

    @GetMapping("/add/{a}/{b}")
    public String test1(@PathVariable int a,@PathVariable String b, Model model){

        String res = a + b;

        model.addAttribute("msg","结果为"+res);

        return "test";
    }

    @PostMapping("/add/{a}/{b}")
    public String test2(@PathVariable int a,@PathVariable int b, Model model){

        int res = a + b;

        model.addAttribute("msg","结果为"+res);

        return "test";
    }```

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值