【Spring】— Spring MVC的注解

这篇具有很好参考价值的文章主要介绍了【Spring】— Spring MVC的注解。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Spring MVC的注解

1.DispatcherServlet

DispatcherServlet的全名:

org.Springframework.web.servlet.DispatcherServlet

它在程序中充当着前端控制器的角色。

【示例】在使用DispatcherServlet时,只需将其配置在项目的web.xml文件中,其配置代码如下。

	<servlet>
        <!--配置前端过滤器-->
        <servlet-name>springmvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--初始化时加载配置文件-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc-config.xml</param-value>
        </init-param>
        <!--表示容器在启动时立即加载Servlet -->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>springmvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

在上述代码中,<load-on-startup>元素和<init-param>元素都是可选的。如果<load-on-startup>元素的值为1,在应用程序启动时就会立即加载该Servlet;如果<load-on-startup>元素不存在,应用程序会就在第一个Servlet请求时加载该Servlet。如果<init-param>元素存在并且通过其子元素配置了Spring MVC配置文件的路径,应用程序在启动时就会加载配置路径下的配置文件;如果没有通过<init-param>元素配置,应用程序就会默认到WEB-INF目录下寻找如下方式命名的配置文件。

servletName-servlet.xml

servletName指的是部署在web.xml中的DispatcherServlet的名称,在上面web.xml中的配置代码中即为springmvc,而-servlet.xml是配置文件名的固定写法,所以应用程序会在WEB-INF下寻找springmvc-servlet.xml。

2.Controller注解类型

org.springframework.stereotype.Controller注解类型用于指示Spring类的实例是一个控制器,其注解形式为@Controller。该注解在使用时不需要再实现Controller接口,只需要将@Controller注解加入控制器类上,然后通过Spring的扫描机制找到标注了该注解的控制器即可。

【示例】@Controller注解在控制器类中的使用示例如下。

package com.ssm.controller;
import org.springframework.stereotype.Controller;
......
//Controller注解
@Controller
public class ControllerTest{
......
}

为了保证Spring能够找到控制器类,还需要在Spring MVC的配置文件中添加相应的扫描配置信息,具体如下。

(1)在配置文件的声明中引入spring-context

(2)使用<context: component-scan>元素指定需要扫描的类包。

完整的配置文件如下。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
        http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
        http://www.springframework.org/schema/context
        http://www.springframework.org/schema/context/spring-context-4.3.xsd">
    <!--  指定需要扫描的包  -->
    <context:component-scan base-package="com.ssm.controller"/>
</beans>

<context: component-scan>元素的属性base-package指定了需要扫描的类包为com.ssm.controller。在运行时,该类包及其子包下所有标注了注解的类都会被Spring所处理。与实现了Controller接口的方式相比,使用注解的方式显然更加简单。同时,Controller接口的实现类只能处理一个单一的请求动作,而基于注解的控制器可以同时处理多个请求动作,在使用上更加灵活。因此,在实际开发中通常都会使用基于注解的形式。

注意

使用注解方式时,程序的运行需要依赖Spring的AOP包,因此需要向lib目录中添加spring.aop-4.3.6 RELEASE.jar,否则程序运行时会报错。

3.RequestMapping注解类型

(1)@RequestMapping注解的使用

Spring通过@Controller注解找到相应的控制器类后,还需要知道控制器内部对每一个请求是如何处理的,这就需要使用org.springframework.web.bind.annotation.RequestMapping注解类型。RequestMapping用于映射一个请求或一个方法,其注解形式为@RequestMapping,可以使用该注解标注在一个方法或一个类上。

(1)标注在方法上

当标注在一个方法上时,该方法将成为一个请求处理方法,它会在程序接收到对应的URL请求时被调用。

【示例】使用@RequestMapping注解标注在方法上的示例如下。

package com.ssm.controller;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;

......
//Controller注解
@org.springframework.stereotype.Controller
public class AnnotationControllerTest {
    //@RequestMapping注解标注再方法上
    @RequestMapping(value="/annotationController")
    public ModelAndView handleRequest(HttpServletRequest arg0, HttpServletResponse arg1)throws Exception{
        ......
        return m;
    }

}

使用@RequestMapping注解后,上述代码中的handleRequest()方法就可以通过地址http://localhost:8080/chapter11/annotationController进行访问。

(2)标注在类上

当标注在一个类上时,该类中的所有方法都将映射为相对于类级别的请求,表示该控制器所处理的所有请求都被映射到value属性值所指定的路径下。

//Controller注解
@Controller

//@RequestMapping注解标注再方法上
@RequestMapping(value = "/controll")
public class AnnotationControllerTest {
    @RequestMapping(value="/annotationController")
    public ModelAndView handleRequest(HttpServletRequest arg0, HttpServletResponse arg1)throws Exception{
        ......
        return m;
    }

}

由于在类上添加了@RequestMapping注解,并且其value属性值为“/controll”,因此上述代码方法的请求路径将变为http://localhost:8080/chapter11/controll/annotationController。如果该类中还包含其他方法,那么在其他方法的请求路径中也需要加入“/ control”。

(2)@RequestMapping注解的属性

@RequestMapping注解除了可以指定value属性外,还可以指定一些其他属性,如表所示。

【Spring】— Spring MVC的注解
所有属性都是可选的,但其默认属性是value。当value是其唯一属性时,可以省略属性名,例如下面两种标注的含义相同。

@RequestMapping(value="/annotationController")
@RequestMapping("/annotationController")
(3) 组合注解

前面已经对@RequestMapping注解及其属性进行了详细讲解,而在Spring 4.3版本中引入了组合注解来帮助简化常用的HTTP方法的映射,并更好地表达被注解方法的语义。其组合注解如下所示。

  • @GetMapping:匹配GET方式的请求。
  • @PostMapping:匹配POST方式的请求。
  • @PutMapping:匹配PUT方式的请求。
  • @DeleteMapping:匹配DELETE方式的请求。
  • @PatchMapping:匹配PATCH方式的请求。

以@GetMapping为例,该组合注解是@RequestMapping(method=RequestMethod.GET)的缩写,它会将Http Get映射到特定的处理方法上。在实际开发中,传统的@RequestMapping注解使用方式如下。

@RequestMapping(value="/user/{id}",method = RequestMethod.GET)
    public String selectUserById(string id){
        ......
    }

而使用新注解@GetMapping后,可以省略method属性,从而简化代码,使用方式如下。

  @GetMapping(value="/user/{fid}")
    public String selectUserById(string id){
        ......
    }
(4)请求处理方法的参数类型和返回类型

在控制器类中,每一个请求处理方法都可以有多个不同类型的参数,以及一个多种类型的返回结果。之前handleRequest()方法的参数就是对应请求的HttpServletRequest和HttpServletResponse两种参数类型。除此之外,还可以使用其他的参数类型,例如在请求处理方法中需要访问HttpSession对象,就可以添加HttpSession作为参数,Spring会将对象正确地传递给方法,其使用示例如下。

 @RequestMapping(value="/annotationController")
    public ModelAndView (httpSession session)
    {
        ......
        return m;
    }

在请求处理方法中,可以出现的参数类型如下。

javax.servlet.ServletRequest/javax.servlet.http.HttpServletRequest
javax.servlet.ServletResponse/javax.servlet.http.HttpServletResponse 
javax.servlet.http.HttpSession 
org.springframework.web.context.request.WebRequest或 
org.springframework.web.context.request.NativeWebRequest 
java.util.Locale
java.util.TimeZone (Java 6+)/java.time.Zoneld(on Java 8) 
java.io.InputStream/java.io.Reader 
Java.io.OutputStream/java.io.Writer 
org.springframework.http.HttpMethod 
java.security.Principal
@PathVariable@MatrixVariable@RequestParam@RequestHeader@RequestBody、 
@RequestPart@SessionAttribute@RequestAttribute注解 
HttpEntity<?> 
java.util.Map/org.springframework.ui.Model/lorg.springframework.ui.ModelMap 
org.springframework.web.servlet.mvc.support.RedirectAttributes 
org.springframework.validation.Errors/org.springframework.validation.BindingResult 
org.springframework.web.bind.support.SessionStatus 
org.springframework.web.util.UriComponentsBuilder

注意

org.springframework.ui.Model类型不是一个Servlet API类型,而是一个包含Map对象的Spring MVC类型。如果方法中添加了Model参数,那么每次调用该请求处理方法时,Spring MVC都会创建Model对象,并将其作为参数传递给方法。

入门案例中,请求处理方法返回的是一个ModelAndView类型的数据。除了这种类型外,请求处理方法还可以返回其他类型的数据。Spring MVC所支持的常见方法返回类型如下。

 ModelAndView 
 Model 
 Map 
 View 
 String 
 void 
 HttpEntity<?>ResponseEntity<?> 
 Callable<?> 
  DeferredResult<?>

在上述列举的返回类型中,常见的返回类型有ModelAndView、String和void。其中,ModelAndView类型中可以添加Model数据,并指定视图;String类型的返回值可以跳转视图,但不能携带数据;而void类型主要在异步请求时使用,它只返回数据,而不会跳转视图。

由于ModelAndView类型未能实现数据与视图之间的解耦,因此在开发时,方法的返回类型通常都会使用String。既然String类型的返回值不能携带数据,那么在方法中是如何将数据带入视图页面呢?这就用到了上面所讲解的Model参数类型,通过该参数类型即可添加需要在视图中显示的属性。

返回String类型方法的示例代码如下。

 @RequestMapping(value="/annotationController")
    public String handleRequest(HttpServletRequest arg0, HttpServletResponse arg1,
                                Model model)throws Exception{
        model.addAttribute("msg","第一个Spring MVC程序");
        return "/WEB-INF/jsp/welcome.jsp";
   }

在上述方法代码中增加了一个Model类型的参数,通过该参数实例的addAttribute()方法即可添加所需数据。String类型除了可以返回上述代码中的视图页面外,还可以进行复位向与请求转发,具体方式如下。

(1)redirect复位向

例如,在修改用户信息操作后,将请求复位向到用户查询方法的实现代码如下。

@RequestMapping(value="/update")
    public String update(HttpServletRequest request, HttpServletResponse response,
                                Model model){
        //复位向请求路径
        return "redirect: queryUser";
   }

(2)forward请求转发

例如,用户执行修改操作时,转发到用户修改页面的实现代码如下。

    @RequestMapping(value="/toEdit")
    public String toEdit(HttpServletRequest request, HttpServletResponse response,
                         Model model){
        //复位向请求路径
        return "forward: editUser";
    }

4.ViewResolver(视图解析器)

Spring MVC中的视图解析器负责解析视图,可以在配置文件中定义一个ViewResolver来配置视图解析器,其配置示例如下。

    <!--定义视图解析器-->
    <bean id="viewResolver"
          class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <!--设置前缀-->
        <property name="prefix" value="/WEB-INF/jsp/" />
        <!--设置后缀-->
        <property name="suffix" value=".isp" />
    
    </bean>

在上述代码中定义了一个id为viewResolver的视图解析器,并设置了视图的前缀和后缀属性。这样设置后,方法中所定义的view路径将可以简化。例如,入门案例中的逻辑视图名只需设置为“welcome”,而不再需要设置为“/WEB-INF/jsp/welcome.jsp”,在访问时视图解析器会自动地增加前缀和后缀。文章来源地址https://www.toymoban.com/news/detail-499394.html

到了这里,关于【Spring】— Spring MVC的注解的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring MVC常用注解

    @PathVariable、@RequestBody和@RequestParam @PathVariable、@RequestBody和@RequestParam是Spring MVC框架中用于处理请求参数的注解。 @PathVariable:用于处URL路径中的 占位符参数 。例如,对于URL /users/{id} ,其中的 {id} 是一个占位符,可以使用@PathVariable注解将其绑定到方法的参数上,如下所示:

    2024年02月09日
    浏览(29)
  • 【Spring MVC】快速学习使用Spring MVC的注解及三层架构

    💓 博客主页:从零开始的-CodeNinja之路 ⏩ 收录文章:【Spring MVC】快速学习使用Spring MVC的注解及三层架构 🎉欢迎大家点赞👍评论📝收藏⭐文章 SpringWebMVC是基于ServletAPI构建的原始Web框架,从⼀开始就包含在Spring框架中。它的正式名称“SpringWebMVC”来⾃其源模块的名称(Spri

    2024年04月17日
    浏览(32)
  • Spring MVC相关注解运用 —— 下篇

    目录 一、@ResponseBody、@RestController 1.1. JSP页面 1.2 放行静态资源 1.3 编写实体类 1.4 控制器方法 1.5 添加依赖 1.6 测试结果 1.7 @RestController  二、静态资源映射 2.1 配置静态资源筛查器 2.2 配置静态资源资源映射器 2.3 配置默认Servlet处理静态资源 三、@RequestBody 3.1 AJAX请求发送JSO

    2024年02月12日
    浏览(37)
  • Spring MVC-@RequestMapping注解详解

    目录 1、@RequestMapping注解的作用 2、@RequestMapping注解的位置 3、value属性 (1)基础用法 (3)路径中的占位符(重点) 4、method属性 5、params属性(了解) 6、headers属性(了解) @RequestMapping注解的作用,就是 将请求和处理请求的控制器方法关联起来 ,建立映射关系。 SpringMVC接

    2023年04月24日
    浏览(34)
  • Spring MVC 三 :基于注解配置

    Servlet3.0 Servlet3.0是基于注解配置的理论基础。 Servlet3.0引入了基于注解配置Servlet的规范,提出了可拔插的ServletContext初始化方式,引入了一个叫ServletContainerInitializer的接口。 An instance of the ServletContainerInitializer is looked up via the jar services API by the container at container / application sta

    2024年02月11日
    浏览(26)
  • Spring MVC 的RequestMapping注解

    作用:用于建立请求URL和处理请求方法之间的对应关系。 出现位置: 类上: 请求 URL的第一级访问目录。此处不写的话,就相当于应用的根目录。写的话需要以/开头。它出现的目的是为了使我们的 URL 可以按照模块化管理,例如: 账户模块: /account /add /account /update /account

    2024年02月02日
    浏览(30)
  • Spring MVC相关注解运用 —— 上篇

    目录 一、@Controller、@RequestMapping 1.1 示例程序 1.2 测试结果 二、@RequestParam 2.1 示例程序 2.2 测试结果 三、@RequestHeader、@CookieValue 3.1 示例程序 3.2 测试结果 四、@SessionAttributes 4.1 示例程序 4.2 测试结果 五、@ModelAttribute 5.1 示例程序 5.2 测试结果 往期专栏文章相关导读  1. Maven系列

    2024年02月11日
    浏览(32)
  • Spring MVC相关注解运用 —— 中篇

    目录 一、RESTful风格支持 1.1 RESTful风格介绍 1.2 postman使用 二、@PathVariable 2.1 实例程序 2.2 测试结果  三、@PostMapping、@GetMapping、@PutMapping、@DeleteMapping 四、@HiddenHttpMethodFilter 4.1 在web.xml配置过滤器 4.2 控制器方法 4.3 JSP页面 4.4 测试结果 往期专栏文章相关导读  1. Maven系列专栏

    2024年02月12日
    浏览(45)
  • Spring MVC学习之——RequestMapping注解

    用于建立请求URL和处理请求方法之间的对应关系。 value:指定请求的实际地址,可以是一个字符串或者一个字符串列表。 value可以不写,直接在括号中写,默认就是value值 @RequestMapping(value=“/hello”) public String hello(){ return…} method:指定请求的方式,可以是GET、POST、PUT、DELE

    2024年01月18日
    浏览(41)
  • Spring MVC中的一些常用注解

    目录 @RequestMapping 实现路由映射 限制请求方式 @PathVariable 从url中获取变量的值 更改绑定参数的名字 @RequestParam 可以传递集合  更改绑定参数的名字 可修改是否为必传参数 @RequestBody 获取请求正文的内容  可修改是否为必传参数 @RequestPart 可以支持上传文件 更改绑定参数的名字

    2024年01月19日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包