springMVC01,【第一个springMVC例子(注解版):HelloWorld】

导读:本篇文章讲解 springMVC01,【第一个springMVC例子(注解版):HelloWorld】,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

链接: springMVC01,springMVC的执行流程【第一个springMVC例子(XML配置版本):HelloWorld】
在基于上一篇的文章基础上,使用注解配置来对比一下二者的差距。


创建项目

新建一个maven项目,在pom.xml中导入项目需要的依赖,然后添加web支持,配置tomcat以及web项目发布依赖包
(这一个过程我就忽略掉了,和上个项目是一模一样,可以根据自己的情况查看上面链接,我之前的文章)。


1.配置web.xml

web.xml中还是配置DispatcherServlet

 	<!--配置DispatcherServlet 前端控制器-->
    <servlet>
        <servlet-name>springmvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!--绑定spring配置文件-->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:springmvc-servlet.xml</param-value>
        </init-param>
         <load-on-startup>1</load-on-startup>
    </servlet>

    <servlet-mapping>
        <servlet-name>springmvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

2.编写spring配置文件

spring配置文件中,用来开启注解驱动,以及mvc注解驱动和视图解析器。在resources目录下新建一个springmvc-servlet.xml的配置文件。

<!--开启注解驱动,交由ioc容器来管理bean-->
    <context:component-scan base-package="com.gothic.sunset"/>

    <!--过滤静态资源请求-->
    <mvc:default-servlet-handler />

    <!--
   支持mvc注解驱动
       在spring中一般采用@RequestMapping注解来完成映射关系
       要想使@RequestMapping注解生效
       必须向上下文中注册DefaultAnnotationHandlerMapping
       和一个AnnotationMethodHandlerAdapter实例
       这两个实例分别在类级别和方法级别处理。
       而annotation-driven配置帮助我们自动完成上述两个实例的注入。
    -->
    <mvc:annotation-driven />

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

这里提一下,之前我们是通过modelAndView来完成页面数据传递跳转的,现在通过一个Model接口来完成数据传递。而@RequestMapping注解中的value属性值用来匹配我们地址栏的请求


3.controller层

上一篇,xml配置controler层的类是用实现controler接口来做的,这回都换成spring之前的注解配置bean来做。
新建一个包 com/gothic/sunset/controller 然后在里面新建一个类HelloController.java

package com.gothic.sunset.controller;


import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller  //使用注解将bean标识交由ioc容器管理
public class HelloController {

    @RequestMapping("/hello")
    public String sayHello(Model model){
        String str = "helloWorld!";
        //向模型中添加属性msg与值,可以在JSP页面中取出并渲染
        model.addAttribute("msg",str);
        // 最终访问/WEB-INF/hello.jsp
        return "hello";
    }
}

3.1@RequestMapping注解

@RequestMapping注解的作用就是将请求和处理请求的控制器方法关联
起来,建立映射关系。

  • @RequestMapping标识一个类:设置映射请求的请求路径的初始信息
  • @RequestMapping标识一个方法:设置映射请求请求路径的具体信息

@RequestMapping注解的value属性:

  1. @RequestMapping注解的value属性通过请求的请求地址匹配请求映射
  2. @RequestMapping注解的value属性是一个字符串类型的数组,表示该请求映射能够匹配多个请求地址所对应的请求
  3. @RequestMapping注解的value属性必须设置,至少通过请求地址匹配请求映射

@RequestMapping注解的method属性:

  1. @RequestMapping注解的method属性通过请求的请求方式(get或post)匹配请求映射
  2. @RequestMapping注解的method属性是一个RequestMethod类型的数组,表示该请求映射能够匹配多种请求方式的请求
  3. 若当前请求的请求地址满足请求映射的value属性,但是请求方式不满足method属性,则浏览器报错 405:Request method ‘POST’ not supported

对于处理指定请求方式的控制器方法,SpringMVC中提供了@RequestMapping的派生注解:
处理get请求的映射–>@GetMapping
处理post请求的映射–>@PostMapping
处理put请求的映射–>@PutMapping
处理delete请求的映射–>@DeleteMapping


4.运行测试

在这里插入图片描述


5.小结

浏览器发送请求,若请求地址符合前端控制器的url-pattern,该请求就会被前端控制器
DispatcherServlet处理。前端控制器会读取SpringMVC的核心配置文件,通过扫描组件找到控制器,将请求地址和控制器中@RequestMapping注解的value属性值进行匹配,若匹配成功,该注解所标识的控制器方法就是处理请求的方法。处理请求的方法需要返回一个字符串类型的视图名称,该视图名称会被视图解析器解析,加上前缀和后缀组成视图的路径,最终转发到视图对应的页面。


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/85357.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!