【SpringMVC】使用注解进行开发

生活中,最使人疲惫的往往不是道路的遥远,而是心中的郁闷;最使人痛苦的往往不是生活的不幸,而是希望的破灭;最使人颓废的往往不是前途的坎坷,而是自信的丧失;最使人绝望的往往不是挫折的打击,而是心灵的死亡。所以我们要有自己的梦想,让梦想的星光指引着我们走出落漠,走出惆怅,带着我们走进自己的理想。

导读:本篇文章讲解 【SpringMVC】使用注解进行开发,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

闲话

今天真不想锻炼,但是还是得去,越想放弃的时候越是你应该坚持的时候

基本要点

在了解springmvc的执行原理与原生实现方式之后【SpringMVC】执行原理以及原生方式实现

我们要学习一种更加简单的开发方式,那就是使用注解,接下来我们就一起了解一下

1、配置web.xml

新建module,添加web支持,可以参考我之前的博客 【SpringMVC】MVC架构与Servlet

二话不说,上来首先要做的肯定是注册DispacherServlet啦

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">
    <servlet>
        <servlet-name>springmvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!-- 关联一个springmvc的配置文件 -->
        <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>
        <!--
          想要监听所有请求,这里可以填2种形式
          /:匹配所有的请求,不包括jsp结尾
          /*:匹配所有的请求,包括jsp结尾
        -->
        <url-pattern>/</url-pattern>
    </servlet-mapping>

</web-app>

2、配置springmvc的配置文件

与之前原生方式不一样的是,这里需要开始注解自动扫描
还需要配置与@RequestMapping注解相关的设置

<?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"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
       http://www.springframework.org/schema/beans/spring-beans.xsd
       http://www.springframework.org/schema/context
       https://www.springframework.org/schema/context/spring-context.xsd
       http://www.springframework.org/schema/mvc
       https://www.springframework.org/schema/mvc/spring-mvc.xsd">


    <!-- 开启自动扫描,让指定包下的注解生效,由IOC容器统一管理 -->
    <context:component-scan base-package="com.decade2.controller"/>
    <!-- 让Spring MVC不处理静态资源 -->
    <mvc:default-servlet-handler />
    <!--
    支持mvc注解驱动
    我们一般采用@RequestMapping注解来完成url路径和具体控制器的映射
    要想使该注解生效,必须注册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>
</beans>

3、编写jsp文件和控制器类

编写一个hello2.jsp

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

还有控制器类HelloController2 .java,我们需要了解几个关键注解和类

  • @Controller:可以理解为与前面实现Controller接口的效果一致,并且在Spring IOC容器初始化时被自动扫描到
  • @RequestMapping是为了映射请求路径,它可以加在方法上也可以加在类上,如果类和方法上都加了,需要把二者拼接起来
  • @RequestParam这个注解用于绑定前端传递的参数和后端接口方法上的参数,value值就是前端调用接口时需要传递的值,required表示该参数是否必须,默认是true,表示请求中一定要有相应的参数,否则将报404错误码。
  • 如果方法的入参是一个对象,那么前端调用时需要保证参数和对象类中的字段一致,否则后端接收到的该变量就会为null
  • Model这个类和之前原生方式中的ModelAndView类作用相同,但是它只能起封装模型的作用,具体跳转到哪个视图,和我们这个方法返回的String字符串有关系,该字符串就是视图的名字
package com.decade2.controller;

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

@Controller
@RequestMapping(value = "/controller")
public class HelloController2 {

    @RequestMapping(value = "/hello")
    public String hello(Model model) {
        model.addAttribute("message", "进入了HelloController2,并调用了hello方法!");
        return "hello2";
    }
    
	@RequestMapping(value = "/hello2")
    public String hello2(@RequestParam(value = "parameterType", required = false) final String parameterType, Model model) {
        model.addAttribute("message", parameterType);
        return "hello2";
    }
}

启动tomcat然后进行测试
在这里插入图片描述

如果需要重定向,那么就需要使用到redirect,它用不到视图解析器 , 本质就是重新请求一个新的页面 , 所以我们要注意路径问题

@RequestMapping(value = "/hello2")
public String hello2(Model model) {
	model.addAttribute("message", "进入了HelloController2,并调用了hello2方法!");
    return "redirect:/index.jsp";
}

这里我们请求http://localhost:8080/controller/hello2
在这里插入图片描述
我们发现,还是会跳到首页,但是地址栏url发生了变化
在这里插入图片描述

4、总结

不管使用注解还是实现Controller接口,我们都能实现我们想要的效果,当然,使用注解更加简单

  • 我们不需要再去springmvc的配置文件中专门的配置url和控制器类的关系
  • 注解使得控制器和视图之间是弱耦合关系
    假设http://localhost:8080/controller/add和http://localhost:8080/controller/delete都指向一个视图
    除了页面上展示的message不一样,其他的都一样,那么我们就可以在同一个类下,写2个方法,除了model中的message信息不一样,指向的页面都一样

如果启动报错404,可以参考上一篇博客 【SpringMVC】执行原理以及原生方式实现 最后一部分

如有错误,欢迎指正!

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

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

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

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