RestFul和控制器

RestFul和控制器

控制器:

  • 控制器负责提供访问应用程序的行为,通常通过接口定义或者注解定义两种方式
  • 控制器负责解析用户的请求并将其转换为一个模型
  • 在SpringMVC中一个控制器类可以包含多个方法
  • 在SpringMVC中,对Controller的配置方法有很多种

实现Controller接口

Controller接口源码:

@FunctionalInterface
public interface Controller {
    @Nullable
    ModelAndView handleRequest(HttpServletRequest var1, HttpServletResponse var2) throws Exception;
}

编写一个Controller的实现类:

//注意不要导错包
public class ControllerTest1 implements Controller {
    public ModelAndView handleRequest(javax.servlet.http.HttpServletRequest httpServletRequest, javax.servlet.http.HttpServletResponse httpServletResponse) throws Exception {
        //返回一个模型视图对象
        ModelAndView mv=new ModelAndView();
        mv.addObject("msg","Test1Controoler");
        mv.setViewName("test");
        return mv;
    }
}

在Spring配置文件中注册请求Bean;name对应请求路径,class对应请求处理类

<bean name="/t1" class="com.ssm.controller.ControllerTest1"></bean>

编写前端页面,注意是在目录WEB-INF/jsp/下

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
${msg}
</body>
</html>

测试:

在这里插入图片描述

注意:

  • 实现接口的方式比较老
  • 缺点:一个控制器中只有一个方法,如果要多个方法则需要定义多个Controller;比较麻烦

使用注解@Controller

  • @Controller注解类型用于声明Spring类的实例的一个控制器

  • Spring能通过扫描机制来找到应用程序中所有的基于注解的控制器类,为了保证Spring能找到控制器,需要配置文件中声明组件扫描

     <context:component-scan base-package="com.ssm"/>
    
  • 测试:增加一个ControllerTest2的实现类,使用注解实现

    @Controller注解的类会自动添加到Spring上下文中
    @Controller
    public class ControllerTest2 {
        @RequestMapping("/t2")
        public String index(Model model){
             //Spring MVC会自动实例化一个Model对象用于向视图中传值
            model.addAttribute("msg","ControllerTest2");
            //返回视图位置
            return "test";
        }
    }
    

    测试:

在这里插入图片描述

**注意:**两个请求都指向了一个视图,但结果却不一样,证明:视图被复用了,而控制器和视图之间是弱耦合关系


RestFul风格

​ 一个资源定位及资源操作的风格,只是一种风格,让软件的设计更加简洁,更有层次,更容易实现缓存的那个机制

测试:

  1. 新建一个类RestFulController
@Controller
public class RestFulController {
}
  1. 在Spring MVC中可以使用 @PathVariable 注解,让方法参数的值对应绑定到一个URI模板变量上。
@Controller
public class RestFulController {

    //映射访问路径
    @RequestMapping("/commit/{p1}/{p2}")
    public String index(@PathVariable int p1,@PathVariable int p2, Model model){
        int result=p1+p2;
        //Spring MVC会自动实例化一个Model对象用于向视图中传值
        model.addAttribute("msg","结果:"+result);
        //返回视图位置
        return "test";
    }
}

测试:

在这里插入图片描述

风格好处:

  1. 使路径更加简洁
  2. 获得参数更加方便,框架会自动转换
  3. 通过路径变量可以约束访问参数,如果类型不一致,则访问不到对应的请求方法

使用method属性指定请求类型

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

测试:

​ 新增一个方法:

映射访问路径,必须是POST请求
@RequestMapping(value = "/hellocoffic}",method = RequestMethod.POST)
public String index2( Model model){
    //Spring MVC会自动实例化一个Model对象用于向视图中传值
    model.addAttribute("msg","HELLOCOFFIC");
    //返回视图位置
    return "test";
}

使用GET请求方式访问就会报405:

在这里插入图片描述

总结:

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

  • 所有地址默认请求是GET

  • 除了@RequestMapping 还有几个注解变体:

    @GetMapping
    @PostMapping
    @PutMapping
    @DeleteMapping
    @PatchMapping
    

比如 GET, PUT, POST, DELETE 以及 PATCH。

  • 所有地址默认请求是GET

  • 除了@RequestMapping 还有几个注解变体:

    @GetMapping
    @PostMapping
    @PutMapping
    @DeleteMapping
    @PatchMapping
    

参考:https://mp.weixin.qq.com/s?__biz=Mzg2NTAzMTExNg==&mid=2247483993&idx=1&sn=abdd687e0f360107be0208946a7afc1d&chksm=ce6104faf9168dec5000de5ac600efd8e62ddffbd12a9bbd2e3fb786a4db3d7ee7c07d31d6d8&scene=21#wechat_redirect

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值