SpringMVC:Hello,SpringMVC【注解版】

SpringMVC:Hello,SpringMVC【注解版】

  • HelloSpringMVC配置:

    • 1,新建一个普通Module,添加web支持;

    • 2,确定导入了SpringMVC的依赖;

    • 3,检查项目打包下Artfacts,是否有lib目录;

    • 4,配置web.xml,注册DispatcherServlet:

      <?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>

             <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>

      </web-app>
    • 5,添加SpringMVC配置文件:

      • 为了支持基于注解的IOC,设置了自动扫描包的功能;

      <?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.ljxdemo.controller"/>
        <!-- 让Spring MVC不处理静态资源 -->
        <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>

      </beans>
    • 5,新建Controller:

      • @Controller是为了让Spring IOC容器初始化时自动扫描到;

      • @RequestMapping是为了映射请求路径,这里因为类与方法上都有映射所以访问时应该是/HelloController/hello;

      • 方法中声明Model类型的参数是为了把Action中的数据带到视图中;

      • 方法返回的结果是视图的名称hello,加上配置文件中的前后缀变成WEB-INF/jsp/hello.jsp。

      @Controller
      @RequestMapping("/HelloController")
      public class HelloController {

         @RequestMapping("/hello")
         public String sayHello(Model model){
             //封装数据
             model.addAttribute("msg","ddddd");
             //返回的字符串,就是视图的名字
             return "test";

        }
      }
    • 6,创建test.jsp:

      • 在WEB-INF/ jsp目录中创建hello.jsp , 视图可以直接取出并展示从Controller带回的信息;

      • 可以通过EL取出Model中存放的值,或者对象;

      <%@ page contentType="text/html;charset=UTF-8" language="java" %>
      <html>
         <head>
             <title>Title</title>
         </head>
         <body>
            ${msg}
         </body>
      </html>
    • 配置Tomcat,启动测试;

 

 

  • 使用springMVC必须配置的三大件:

    • 处理器映射器、处理器适配器、视图解析器

    • 通常,我们只需要手动配置视图解析器,而处理器映射器处理器适配器只需要开启注解驱动即可,而省去了大段的xml配置;

 

 

 

 

posted @   gzs1024  阅读(24)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示