SpringMVC入门(一)

  • 2020 年 3 月 11 日
  • 筆記

1. 工作流程

  • 用户请求服务器,然后核心控制器捕获请求
  • 核心控制器交由映射器把请求url和控制器进行映射
  • 核心控制器交由适配器调用映射的控制器,中间还进行数据转换
  • 对应的控制器的逻辑操作完成后返回ModelAndView或String
  • 视图解析器解析ModelAndView
  • 返回一个View
  • 用户看到请求的数据
  • 笔者目前的操作都是返回String,然后前端Ajax异步获取数据,所以下面演示也用String类型的返回值
  • 并且都是基于注解

2. 步骤

2.1 工程目录及jar包

2.2 配置Web.xml

<!-- 配置spring的核心控制器 -->  <servlet>      <servlet-name>dispatcherServlet</servlet-name>      <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>      <!-- 配置servlet初始化参数,告知applicationContext位置 -->      <init-param>          <param-name>contextConfigLocation</param-name>          <param-value>classpath:applicationContext.xml</param-value>      </init-param>      <!-- 启动顺序 -->      <load-on-startup>1</load-on-startup>  </servlet>  <!-- 映射地址 -->  <servlet-mapping>      <servlet-name>dispatcherServlet</servlet-name>      <url-pattern>*.do</url-pattern>  </servlet-mapping>      <!-- 编码过滤器,解决传送过来的参数乱码问题 -->  <filter>      <filter-name>CharacterEncodingFilter</filter-name>      <filter-class>          org.springframework.web.filter.CharacterEncodingFilter      </filter-class>      <init-param>          <param-name>encoding</param-name>          <param-value>UTF-8</param-value>      </init-param>  </filter>  <filter-mapping>      <filter-name>CharacterEncodingFilter</filter-name>      <url-pattern>/*</url-pattern>  </filter-mapping>      <!-- 欢迎页 -->  <welcome-file-list>      <welcome-file>/WEB-INF/pages/index.html</welcome-file>  </welcome-file-list>

2.3 配置applicationContext.xml

<!-- 告知sptring创建容器时要扫描的包 -->  <context:component-scan base-package="com.howl.controller"/>      <!-- 配置springmvc的视图解析器,这里不使用 -->  <!-- <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">      <property name="prefix" value="/WEB-INF/pages/"></property>      <property name="suffix" value=".html"></property>  </bean> -->      <!-- 注册HandlerMapping,HandlerAdapter -->  <mvc:annotation-driven >      <!-- response设置utf-8,解决返给前端中文乱码问题 -->      <mvc:message-converters register-defaults="true">          <bean class="org.springframework.http.converter.StringHttpMessageConverter">              <property name="supportedMediaTypes" value="text/html;charset=UTF-8"/>          </bean>      </mvc:message-converters>  </mvc:annotation-driven>

2.4 创建Controller

package com.howl.controller;    @Controller("UserController") //注解控制器  @RequestMapping("/User") //分模块地址映射  @ResponseBody  //返回字符串,不是ModelandView  public class UserController {        @RequestMapping(value="/add",method=RequestMethod.GET) //指定访问方法      public String add(){          System.out.println("执行了add方法");          return "{'code' : '0000','msg' : '执行了add方法'}"; //返回值json      }    //模块测试,先忽略后面讲解------------------[开始]      @RequestMapping("/update")      public String update(){          System.out.println("执行了update方法");          return "执行了update方法";      }  //模块测试--------------------------------[完]        @RequestMapping("/insert")      public String insert(int id){          System.out.println("执行了insert方法,id="+ id);          return "执行了insert方法,id="+ id;      }    }

2.5 前端页面

<body>      <a href="User/add.do">add</a>      <a href="update.do">update</a>  <!-- 这里测试分模块,后面会讲解,先略过 -->      <a href="User/insert.do?id=1">insert</a>  </body>
  • 前端点击add与insert链接的时候,分别返回
  • 这里注意,前端发送参数的属性name要和对应方法的参数名字类型一致

2.6 模块测试

  • 笔者在UserController加了@RequestMapping("/User"),设置了模块
  • 而且UserController里确实写了@RequestMapping("/update")
  • 但是访问前端页面的update链接的时候 -_- !! 找不到对象 !!

究其原因:是分模块的锅,仔细看二者的url区别

  • add——http://localhost:8080/Springmvc/User/add.do
  • update——http://localhost:8080/Springmvc/update.do
  • 可以看到二者地址栏区别在于/User/,没错就是在类上配置的@RequestMapping("/User")
  • 这个注解可以用在模块化管理,十分便利,比如访问用户/User/,访问问题/Question/,一眼就看出来