本人是学习过springboot,在学习spring和springMVC,我发现对于配置文件来说是特别麻烦的事,但有利于对springboot有深一步的认识。
1.SpringMVC 概念简述
Spring 为展现层提供的基于 MVC 设计理念的优秀的 •
Web 框架,是目前最主流的 MVC 框架之一
Spring3.0 后全面超越 Struts2,成为最优秀的 MVC 框架 •
Spring MVC 通过一套 MVC 注解,让 POJO 成为处理请 •
求的控制器,而无须实现任何接口。
支持 REST 风格的 URL 请求 •
采用了松散耦合可插拔组件结构,比其他 MVC 框架更具 • 扩展性和灵活性
2.创建项目
使用的是javaweb项目,javaEE,tomcat等,对于项目的创建非常简单,需要下载javaweb相关的软件。
对于项目的创建请看
点击直接跳转
引入springmvc运行所需要的jar包,对于jar包需要的可以滴滴我。
实例:
3.配置 web.xml
1.配置 DispatcherServlet :DispatcherServlet 默认加载 /WEBINF/.xml 的 Spring 配置文件, 启动 WEB 层 的 Spring 容器。可以通过 contextConfigLocation 初始化参数自定
义配置文件的位置和名称
2.SpringMVC的核心就是DispatcherServlet,DispatcherServlet实质也是一个HttpServlet。DispatcherSevlet负责将请求分发,所有的请求都有经过它来统一分发。
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee
http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" id="WebApp_ID" version="4.0">
<!-- 配置 DispatcherServlet -->
<servlet>
<servlet-name>springDispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 配置 DispatcherServlet 的一个初始化参数: 配置 SpringMVC 配置文件的位置和名称 -->
<!--
实际上也可以不通过 contextConfigLocation 来配置 SpringMVC 的配置文件, 而使用默认的.
默认的配置文件为: /WEB-INF/<servlet-name>-servlet.xml
一般 WEB 应用服务器默认的 Servlet 的名称都是 default.
若所使用的 WEB 服务器的默认 Servlet 名称不是 default,则需要通过 default-servlet-name 属性显式指定
-->
<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>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
4.创建 Spring MVC 配置文件
配置自动扫描的包,配置视图解析器:视图名称解析器:将视图逻辑 •
名解析为: /WEB-INF/pages/.jsp
springmvc2.xml,文件位置在上图
<?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 http://www.springframework.org/schema/context/spring-context-4.0.xsd
http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
<!-- 配置自动扫描的包 -->
<context:component-scan base-package="hello"></context:component-scan>
<!-- 配置视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>
5.创建请求处理器类
package hello;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class helloworld {
/**
* 1. 使用 @RequestMapping 注解来映射请求的 URL
* 2. 返回值会通过视图解析器解析为实际的物理视图, 对于 InternalResourceViewResolver 视图解析器, 会做如下的解析:
* 通过 prefix + returnVal + 后缀 这样的方式得到实际的物理视图, 然会做转发操作
*
* /WEB-INF/views/success.jsp
*
* @return
*/
@RequestMapping("/helloworld")
public String hello() {
System.out.println("success");
return "success";
}
}
success.jsp 在包view下
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<h4>success page</h4>
</body>
</html>
index.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<a href="springmvc/testRequestMapping">test requestMapping</a>
<a href="helloworld">hello world</a>
</body>
</html>
运行结果如下:
使用 @RequestMapping 映射请求
Spring MVC 使用 @RequestMapping 注解为控制器指定可以处理哪些 URL 请求
在控制器的类定义及方法定义处都可标注 •
@RequestMapping
类定义处:提供初步的请求映射信息。相对于 WEB 应用的根目录 –
方法处:提供进一步的细分映射信息。相对于类定义处的 URL。若 – 类定义处未标注 @RequestMapping,则方法处标记的 URL 相对于WEB 应用的根目录
DispatcherServlet 截获请求后,就通过控制器上
• @RequestMapping 提供的映射信息确定请求所对应的处理方法
映射请求参数、请求方法或请求头
@RequestMapping 除了可以使用请求 URL 映射请求外, • 还可以使用请求方法、请求参数及请求头映射请求 @RequestMapping 的 value、method、params 及 heads • 分别表示请求 URL、请求方法、请求参数及请求头的映射条
件,他们之间是与的关系,联合使用多个条件可让请求映射
更加精确化。
params 和 headers支持简单的表达式: •
param1: 表示请求必须包含名为 param1 的请求参数 –
!param1: 表示请求不能包含名为 param1 的请求参数 –
param1 != value1: 表示请求包含名为 param1 的请求参数,但其值 –
不能为 value1
{“param1=value1”, “param2”}: 请求必须包含名为 param1 和param2 – 的两个请求参数,且 param1 参数的值必须为 value1
实例如下:
在springtest.java下添加方法
//使用method属性来指定传输的类型,是POST还是get类型
@RequestMapping(value = "testMethod",method = RequestMethod.POST)
public String testMethod() {
return SUCCESS;
}
在index.jsp下添加
<form action="springmvc/testMethod" method="POST">
<input type="submit" value="点击一下">
</form>
<!-- 相当于get请求,没有传参,所以要写一个form来传参 -->
<a href="springmvc/testMethod">testMethod</a>
运行效果出现了问题
这是就需要修改代码为utf-8编码格式
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
Ant风格资源路径
@PathVariable 映射 URL 绑定的占位符
在springtest.java下添加方法
@RequestMapping("/hel/{id}")
public String hello1(@PathVariable(value = "id")Integer id) {
System.out.println("pathvariable"+id);
return SUCCESS;
}
index.jsp
<a href="springmvc/hel/1">pathvariable</a>
运行代码,修改值,下面的控制台会出现变化
SpringMVC-REST
1.REST简介
1.REST:即 Representational State Transfer。(资源)表现层状态转化。是目前 最流行的一种互联网软件架构。它结构清晰、符合标准、易于理解、扩展方便,所以正得到越来越多网站的采用
2.资源(Resources):网络上的一个实体,或者说是网络上的一个具体信息。它 可以是一段文本、一张图片、一首歌曲、一种服务,总之就是一个具体的存在。可以用一个URI(统一资源定位符)指向它,每种资源对应一个特定的 URI 。要 获取这个资源,访问它的URI就可以,因此 URI 即为每一个资源的独一无二的识 别符。
3. 表现层(Representation):把资源具体呈现出来的形式,叫做它的表现层 •(Representation)。比如,文本可以用 txt 格式表现,也可以用 HTML 格 式、XML 格式、JSON 格式表现,甚至可以采用二进制格式。
4…状态转化(State Transfer):每发出一个请求,就代表了客户端和服务器的一 次交互过程。HTTP协议,是一个无状态协议,即所有的状态都保存在服务器端。因此,如果客户端想要操作服务器,必须通过某种手段,让服务器端发生“ 状态转化”(State Transfer)。而这种转化是建立在表现层之上的,所以就是 “ 表现层状态转化”。具体说,就是 HTTP 协议里面,四个表示操作方式的动 词:GET、POST、PUT、DELETE。它们分别对应四种基本操作:GET 用来获 取资源,POST 用来新建资源,PUT 用来更新资源,DELETE 用来删除资源。
•2.
/order/1 HTTP GET :得到 id = 1 的 order –
/order/1 HTTP DELETE:删除 id = 1的 order –
/order/1 HTTP PUT:更新id = 1的 order –
/order HTTP POST:新增 order –
HiddenHttpMethodFilter:浏览器 form 表单只支持 GET • 与 POST 请求,而DELETE、PUT 等 method 并不支 持,Spring3.0 添加了一个过滤器,可以将这些请求转换为标准的 http 方法,使得支持 GET、POST、PUT 与DELETE 请求。
3.例子:
<!-- 配置 HiddenHttpMethodFilter: 把 POST 请求转为 DELETE、PUT 请求 -->
<filter>
<filter-name>HiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>HiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
在实现的过程中出现了错误
出现了错误就需要解决,于是通过查找资料,问题得到解决
需要将jsp的文件进行修改,修改如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8" isErrorPage="true"%>
问题得到解决