SpringMvc(后期持续完善)
1.SpringMvc的入门案列
1.创建WEB工程,引入开发jar包
1.具体的坐标如下:
<!-- 版本锁定 -->
<properties>
<spring.version>5.0.2.RELEASE</spring.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.0</version>
<scope>provided</scope>
</dependency>
</dependencies>
2.配置核心的控制器(配置DispatcherServlet)
1.在web.xml配置文件中核心控制器DispatcherServlet
<!-- SpringMVC的核心控制器 -->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servletclass>
<!-- 配置Servlet的初始化参数,读取springmvc的配置文件,创建spring容器 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!-- 配置servlet启动时加载对象 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
3.编写springmvc.xml的配置文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd">
<!-- 配置spring创建容器时要扫描的包 -->
<context:component-scan base-package="com.itheima"></context:component-scan>
<!-- 配置视图解析器 -->
<bean id="viewResolver"
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/pages/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 配置spring开启注解mvc的支持
<mvc:annotation-driven></mvc:annotation-driven>-->
</beans>
4.编写index.jsp和HelloController控制器类
1.index.jsp
<body>
<h3>入门案例</h3>
<a href="${ pageContext.request.contextPath }/hello">入门案例</a>
</body>
2.HelloController
package cn.itcast.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
/**
* 控制器
* @author rt
*/
@Controller
public class HelloController {
/**
* 接收请求
* @return
*/
@RequestMapping(path="/hello")
public String sayHello() {
System.out.println("Hello SpringMVC!!");
return "success";
}
}
5.在WEB-INF目录下创建pages文件夹,编写success.jsp的成功页面
<body>
<h3>入门成功!!</h3>
</body>
6.启动Tomcat服务器,进行测试
2.SpringMvc中的常用注解
1.@RequestMapping注解
1. RequestMapping注解的作用是建立请求URL和处理方法之间的对应关系
2. RequestMapping注解可以作用在方法和类上
1. 作用在类上:第一级的访问目录
2. 作用在方法上:第二级的访问目录
3. 细节:路径可以不编写 / 表示应用的根目录开始
4. 细节:${ pageContext.request.contextPath }也可以省略不写,但是路径上不能写 /
3. RequestMapping的属性
1. path 指定请求路径的url
2. value value属性和path属性是一样的
3. mthod 指定该方法的请求方式
4. params 指定限制请求参数的条件
5. headers 发送的请求中必须包含的请求头
**2.@RequestParam注解 **
1. 作用:把请求中的指定名称的参数传递给控制器中的形参赋值
2. 属性
1. value:请求参数中的名称
2. required:请求参数中是否必须提供此参数,默认值是true,必须提供
代码如下:
<a href="/testRequestParam?username=王五">测试@RequestParam</a>
/**
* @Author: gcl
* @Date: 2019/4/29 8:44
*/
@Controller
public class AnnotationTest {
/**
* 测试@RequestParam
*/
@RequestMapping("/testRequestParam")
public String testRequestParam(@RequestParam("username") String name){
System.out.println("name"+name);
return "success";
}
}
注意: 如果写成<a href="/testRequestParam?name=王五">测试@RequestParam</a>
会出现如下错误:
<a href="/testRequestParam2?age=3">testRequestParam2</a>
/**
* 测试@RequestParam注解
*/
@RequestMapping("/testRequestParam2")
public String testRequestParam2(@RequestParam(value="username") int age){
System.out.println(age);
return "success";
}
解决上面问题:
提交的参数是字符串类型
方案一:
/**
* 测试@RequestParam注解
*/
@RequestMapping("/testRequestParam2")
public String testRequestParam2(@RequestParam(value="username",defaultValue = "0") int age){
System.out.println(age);
return "success";
}
方案二:(推荐使用)
/**
* 测试@RequestParam注解
*/
@RequestMapping("/testRequestParam2")
public String testRequestParam2(@RequestParam(value="username") Integer age){
System.out.println(age);
return "success";
}
**3.@RequestBody注解 **
作用:
用于获取请求体内容。 直接使用得到是 key=value&key=value...结构的数据。
get 请求方式不适用。
属性:
required:是否必须有请求体。默认值是:true。当取值为 true 时,get 请求方式会报错。如果取值
为 false, get 请求得到是 null。
代码如下:
<form ACTION="/testRequestBody" method="post">
<input type="text" name="username" >
<input type="submit" value="submit">
</form>
/**
* 测试@RequestBody
*/
@RequestMapping("/testRequestBody")
public String testRequestBody(@RequestBody String body){
System.out.println("body"+body);
return "success";
}
问题:
1.中文会乱码,如何解决?
2.@RequestBody 的另一种作用?
4.@PathVariable注解
1. 作用:拥有绑定url中的占位符的。例如:url中有/delete/{id},{id}就是占位符
2. 属性
1. value:指定url中的占位符名称
3. Restful风格的URL
1. 请求路径一样,可以根据不同的请求方式去执行后台的不同方法
2. restful风格的URL优点
1. 结构清晰
2. 符合标准
3. 易于理解
4. 扩展方便
5.@RequestHeader注解
作用:
用于获取请求消息头。
属性:
value:提供消息头名称
required:是否必须有此消息头
注:
在实际开发中一般不怎么用。
代码如下:
jsp 中代码:
<!-- RequestHeader 注解 -->
<a href="springmvc/useRequestHeader">获取请求消息头</a>
控制器中代码:
/**
* RequestHeader 注解
* @param user
* @return
*/
@RequestMapping("/useRequestHeader")
public String useRequestHeader(@RequestHeader(value="Accept-Language",
required=false)String requestHeader){
System.out.println(requestHeader);
return "success";
}
**6.CookieValue 注解 **
作用:
用于把指定 cookie 名称的值传入控制器方法参数。
属性:
value:指定 cookie 的名称。
required:是否必须有此 cookie。
代码如下:
jsp 中的代码:
<!-- CookieValue 注解 -->
<a href="springmvc/useCookieValue">绑定 cookie 的值</a>
控制器中的代码:
/**
* Cookie 注解注解
* @param user
* @return
*/
@RequestMapping("/useCookieValue")
public String useCookieValue(@CookieValue(value="JSESSIONID",required=false)String cookieValue){
System.out.println(cookieValue);
return "success";
}
**7.@ModelAttribute 注解 **
1. 作用
1. 出现在方法上:表示当前方法会在控制器方法执行前线执行。
2. 出现在参数上:获取指定的数据给参数赋值。
2. 应用场景
1. 当提交表单数据不是完整的实体数据时,保证没有提交的字段使用数据库原来的数据。
代码如下:
**8.@SessionAttributes 注解 **
1. 作用:用于多次执行控制器方法间的参数共享
2. 属性
1. value:指定存入属性的名称
代码如下:
3.RestFul风格
前端代码:
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" isErrorPage="true" %>
<html>
<body>
<h3>入门案例</h3>
<a href="${ pageContext.request.contextPath }/hello">入门案例</a>
<a href="${ pageContext.request.contextPath }/pathVariable/259">PathVariable测试</a>
<hr color="blue">
<a href="/restful/book/1">GET请求</a>
<hr color="blue">
<form action="/restful/book" method="post">
<input type="submit" value="POST">
</form>
<hr color="blue">
<%--当时将action="/restful/book"时报405,应该写成action="/restful/book/1"因为后端的方法上为 @RequestMapping(value = "/book/{id}",method =RequestMethod.DELETE)
--%>
<form action="/restful/book/1" method="post">
<input type="hidden" name="_method" value="DELETE">
<input type="submit" value="DELETE">
</form>
<hr color="blue">
<form action="/restful/book/1" method="post">
<input type="hidden" name="_method" value="PUT">
<input type="submit" value="PUT">
</form>
</body>
</html>
后端代码:
package com.heimanba.controller;
/**
* @Author: gcl
* @Date: 2019/4/29 0:09
*/
import org.springframework.web.bind.annotation.*;
/**
* GET 用来获取资源
* POST 用来新建资源
* DELETE 用来删除资源
* PUT 用来更新资源
*
*/
@RestController
@RequestMapping("/restful")
public class RestFulTest {
/**
* GET请求
*/
@RequestMapping(value = "/book/{id}")
public String testGet(@PathVariable("id") int id){
System.out.println("测试GET请求"+id);
return "success";
}
/**
* POST请求
*/
@RequestMapping(value = "/book",method = RequestMethod.POST)
public String testPost(){
System.out.println("测试POST请求");
return "success";
}
/**
* DELETE请求
*/
@RequestMapping(value = "/book/{id}",method = RequestMethod.DELETE)
public String testDelete(@PathVariable("id") int id){
System.out.println("测试DELETE请求"+id);
return "success";
}
/**
* PUT请求
*/
@RequestMapping(value = "/book/{id}",method = RequestMethod.PUT)
public String testPut(@PathVariable("id") int id){
System.out.println("测试PUT请求"+id);
return "success";
}
}
出现问题:
出现405,是由于tomcat版本过高,在success.jsp页面头上添加isErrorPage="true"即可解决问题
总结:如何发送DELETE或PUT请求?
- 需要配置HiddenHttpMethodFilter
- 需要发送POST请求
- 需要在发送POST请求时携带一个name="_method"的隐藏域,value="DELTE或PUT"