SpringMVC概述、配置方法及部分注解使用方法

一.SpringMVC概述及配置方法

1.1是什么?

① 一种轻量级的、基于MVC的Web层应用框架。偏前端而不是基于业务逻辑层。
② 是Spring框架的一个后续产品。

1.2能干什么?

  1. 天生与Spring框架集成,如:(IOC,AOP)
  2. 支持Restful风格
  3. 进行更简洁的Web层开发
  4. 支持灵活的URL到页面控制器的映射
  5. 非常容易与其他视图技术集成,如:Velocity、FreeMarker等等。
  6. 因为模型数据不存放在特定的API里,而是放在一个Model里(Map数据结构实现,因此很容易被其他框架使用)
  7. 非常灵活的数据验证、格式化和数据绑定机制、能使用任何对象进行数据绑定,不必实现特定框架的API
  8. 更加简单、强大的异常处理
  9. 对静态资源的支持
  10. 支持灵活的本地化、主题等解析

2.SpringMVC配置

2.1需要配置什么?

  1. 将Web层进行了职责解耦,也就和struts2一样,基于请求-响应模型
  2. 常用主要组件
    2.1 DispatcherServlet:前端控制器
    2.2 Controller:处理器/页面控制器,做的是MVC中的C的事情,但控制逻辑转移到前端控制器了,用于对请求进行处理
    2.3 HandlerMapping :请求映射到处理器,找谁来处理,如果映射成功返回一个HandlerExecutiongChain对象(包含一个Handler处理器(页面控制器)对象、多个HandlerInterceptor拦截器对象)
    2.4 ViewResolver : 视图解析器,找谁来处理返回的页面。把逻辑视图解析为具体的View,进行这种策略模式,很容易更换其他视图技术;
    如InternalResourceViewResolver将逻辑视图名映射为JSP视图
    2.5 LocalResolver:本地化、国际化
    2.6 MultipartResolver:文件上传解析器
    2.7 HandlerExceptionResolver:异常处理器

2.2配置步骤:

1.新建项目,项目目录结构:

在这里插入图片描述

2.将jar包放入lib目录下,并导入项目中:

在这里插入图片描述
(具体创建web项目和导包方法查看:)

3.配置web.xml
    <!-- 配置SpringMVC核心控制器: -->
	<servlet>
		<servlet-name>springDispatcherServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<!-- 配置DispatcherServlet的初始化參數:设置文件的路径和文件名称 -->
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath:springmvc.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>springDispatcherServlet</servlet-name>
		<!-- 不能写/*,必须写/,这是REST URL风格的要求,REST风格会在后面介绍 -->
		<url-pattern>/</url-pattern>
	</servlet-mapping>
4.创建并、完成springmvc配置文件

创建如下文件:
在这里插入图片描述
添加Namespaces:
在这里插入图片描述
添加配置:

	<!-- 设置扫描组件的包: -->
	<context:component-scan
		base-package="com.byhq.ch" />

	<!-- 配置映射解析器:如何将控制器返回的结果字符串,转换为一个物理的视图文件 -->
	<bean id="internalResourceViewResolver"
		class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/views/" />
		<property name="suffix" value=".jsp" />
	</bean>

到此springmvc配置完成,添加index.jsp,success.jsp,Controller控制类进行测试。
完成后项目目录结构:
在这里插入图片描述

二、springMVC注解

1.@RequestMapping映射请求注解

1.1概述:
  1. SpringMVC使用@RequestMapping注解为控制器指定可以处理哪些 URL 请求
  2. 在控制器的类定义及方法定义处都可标注 @RequestMapping
    2.1 标记在类上:提供初步的请求映射信息。相对于 WEB 应用的根目录
    2.2 标记在方法上:提供进一步的细分映射信息。相对于标记在类上的 URL。
  3. 若类上未标注 @RequestMapping,则方法处标记的 URL 相对于 WEB 应用的根目录
    作用:DispatcherServlet 截获请求后,就通过控制器上 @RequestMapping 提供的映射信息确定请求所对应的处理方法。
1.2映射请求方式:
  1. 标准HTTP请求报头
    在这里插入图片描述
  2. @RequestMapping(value="/testMethord",method=RequestMethod.POST)
    其中method共有post、get、put、delete四种。
1.3Ant路径风格:

在这里插入图片描述

2.请求占位符@PathVariable注解:

@PathVariable 映射 URL 绑定的占位符
带占位符的 URL 是 Spring3.0 新增的功能,该功能在 SpringMVC 向 REST 目标挺进发展过程中具有里程碑的意义
通过 @PathVariable 可以将 URL 中占位符参数绑定到控制器处理方法的入参中:
URL 中的 {xxx} 占位符可以通过 @PathVariable(“xxx”) 绑定到操作方法的入参中。
在这里插入图片描述

3.@RequestParam注解

3.1概述
  1. 在处理方法入参处使用 @RequestParam 可以把请求参数传递给请求方法
  2. value:参数名
  3. required:是否必须。默认为 true, 表示请求参数中必须包含对应的参数,若不存在,将抛出异常
  4. defaultValue: 默认值,当没有传递参数时使用该值
3.2使用示例:

Controller:

	/**
	 * @RequestParam 注解用于映射请求参数
	 *         value 用于映射请求参数名称
	 *         required 用于设置请求参数是否必须的
	 *         defaultValue 设置默认值,当没有传递参数时使用该值
	 */
	@RequestMapping(value="/testRequestParam")
	public String testRequestParam(@RequestParam(value="username") String username,
	@RequestParam(value="age",required=false,defaultValue="0") int age){
		System.out.println("testRequestParam - username="+username +",age="+age);
		return "success";
	}

页面:

	<!--测试 请求参数 @RequestParam 注解使用 -->
	<a href="springmvc/testRequestParam?username=atguigu&age=10">testRequestParam</a>

4.@RequestHeader 注解

4.1概述
  1. 使用 @RequestHeader 绑定请求报头的属性值
  2. 请求头包含了若干个属性,服务器可据此获知客户端的信息,通过 @RequestHeader 即可将请求头中的属性值绑定到处理方法的入参中
4.2使用示例

Controller:

	//了解: 映射请求头信息 用法同 @RequestParam
	@RequestMapping(value="/testRequestHeader")
	public String testRequestHeader(@RequestHeader(value="Accept-Language") String al){
		System.out.println("testRequestHeader - Accept-Language:"+al);
		return "success";
	}

页面:

	<!-- 测试 请求头@RequestHeader 注解使用 -->
	<a href="springmvc/testRequestHeader">testRequestHeader</a>

5.@CookieValue 注解

5.1概述
  1. 使用 @CookieValue 绑定请求中的 Cookie 值
  2. @CookieValue 可让处理方法入参绑定某个 Cookie 值
5.2使用示例

Controller:

	//了解:@CookieValue: 映射一个 Cookie 值. 属性同 @RequestParam
	@RequestMapping("/testCookieValue")
	public String testCookieValue(@CookieValue("JSESSIONID") String sessionId) {
		System.out.println("testCookieValue: sessionId: " + sessionId);
		return "success";
	}

页面:

	<!--测试 请求Cookie @CookieValue 注解使用 -->
	<a href="springmvc/testCookieValue">testCookieValue</a>

6.使用表单标签传值

6.1概述
  1. 使用 POJO 对象绑定请求参数值
  2. Spring MVC 会按请求参数名和 POJO 属性名进行自动匹配,自动为该对象填充属性值。支持级联属性。如:dept.deptId、dept.address.tel 等
6.2使用示例

Controller:

	/**
	 * Spring MVC 会按请求参数名和 POJO 属性名进行自动匹配, 自动为该对象填充属性值。
	 * 支持级联属性
	 * 如:dept.deptId、dept.address.tel 等
	 */
	@RequestMapping("/testPOJO")
	public String testPojo(User user) {
		System.out.println("testPojo: " + user);
		return "success";
	}

页面:

	<!-- 测试 POJO 对象传参,支持级联属性 -->
	<form action=" testPOJO" method="POST">
		username: <input type="text" name="username"/><br>
		password: <input type="password" name="password"/><br>
		email: <input type="text" name="email"/><br>
		age: <input type="text" name="age"/><br>
		city: <input type="text" name="address.city"/><br>
		province: <input type="text" name="address.province"/>
		<input type="submit" value="Submit"/>
	</form>

增加实体类:

  1. Address
	package com.ch.springmvc.entities;
	public class Address {
		private String province;
		private String city;
		//get/set
	}
  1. User
	package com.ch.springmvc.entities;
	public class User {
		private Integer id ;
		private String username;
		private String password;
		private String email;
		private int age;
		private Address address;
		//get/set 
	}

④ 如果中文有乱码,需要配置字符编码过滤器(web.xml),且配置其他过滤器之前,
如(HiddenHttpMethodFilter),否则不起作用。

	<!-- 配置字符集 -->
	<filter>
		<filter-name>encodingFilter</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>
		<init-param>
			<param-name>forceEncoding</param-name>
			<param-value>true</param-value>
		</init-param>
	</filter>
	<filter-mapping>
		<filter-name>encodingFilter</filter-name>
		<url-pattern>/*</url-pattern>
	</filter-mapping>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值