一、helloworld的实现
1.加入jar包(加入无关的jar包可能会引起服务器的冲突)
commons-logging-1.2.jar
jstl.jar
spring-aop-4.1.6.RELEASE.jar
spring-beans-4.1.6.RELEASE.jar
spring-context-4.1.6.RELEASE.jar
spring-core-4.1.6.RELEASE.jar
spring-expression-4.1.6.RELEASE.jar
spring-web-4.1.6.RELEASE.jar
spring-webmvc-4.1.6.RELEASE.jar
standard.jar
2.配置web.xml文件(配置dispatcherServlet)
<!-- 配置 DispatcherServlet -->
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 配置 DispatcherServlet 的一个初始化参数: 配置 SpringMVC 配置文件的位置和名称 -->
<!--
实际上也可以不通过 contextConfigLocation 来配置 SpringMVC 的配置文件, 而使用默认的.
默认的配置文件为: /WEB-INF/<servlet-name>-servlet.xml
-->
<!--
<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>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>(注意:此处不能写成/*,否则会找不到页面)
</servlet-mapping>
3.配置springmvc.xml
<!-- 配置自定扫描的包 -->
<context:component-scan base-package="com.wzy.springmvc"></context:component-scan>
<!-- 配置视图解析器: 如何把 handler 方法返回值解析为实际的物理视图 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/views/"></property><!-- 前缀-->
<property name="suffix" value=".jsp"></property><!-- 后缀-->
</bean>
4.编写handler类
package com.oracle.handlers;
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("/hello")
public String sayHello(){
System.out.println("Hello World");
return "success";
}
}
5.编写相应的测试页面
二、requestMapping注解
/**
* 1. @RequestMapping 除了修饰方法, 还可来修饰类 2. 1). 类定义处: 提供初步的请求映射信息。相对于 WEB 应用的根目录
* 2). 方法处: 提供进一步的细分映射信息。 相对于类定义处的 URL。若类定义处未标注 @RequestMapping,则方法处标记的 URL
* 相对于 WEB 应用的根目录
*/
@RequestMapping("/testRequestMapping")
public String testRequestMapping() {
System.out.println("testRequestMapping");
return SUCCESS;
}
1.requestMapping 的属性
method属性:设置请求的方式
@RequestMapping(value="/testRequestMethod",method=RequestMethod.POST)
public String testRequestMethod(){
System.out.println("testRequestMethod");
return "success";
}
设置为post请求,如果请求方式为get:<a href=springmvc/testRequestMethod>testRequestMethod</a>;
会抛出405异常
改为post提交:
<form action="springmvc/testRequestMethod" method="post">
<input type="submit" />
</form>
则正常提交~~
params和headers属性(了解)
@RequestMapping(value="/testRequestParams",params={"username","age!=10"})
public String testRequestParams(){
System.out.println("testRequestParams");
return "success";
}
@RequestMapping(value="/testRequestParams",params={"username","age!=10"},headers={"Accept-Language=en-US,zh;q=0.8"})
public String testRequestParams(){
System.out.println("testRequestParams");
return "success";
}
params和headers可以采用数组的方式设置
params • 和 headers支持简单的表达式:
param1: 表示请求必须包含名为 param1 的请求参数 –
!param1: 表示请求不能包含名为 param1 的请求参数 –
param1 != value1: 表示请求包含名为 param1 的请求参数,但其值
不能为 value1
{“param1=value1”, “param2”}: 请求必须包含名为 param1 和param2 –
的两个请求参数,且 param1 参数的值必须为 value1
2.requestMapping在映射的时候的url还支持ant类型的通配符(了解)
Ant 风格资源地址支持 3 种匹配符:
?:匹配文件名中的一个字符 –
*:匹配文件名中的任意字符 –
**:** 匹配多层路径 –
@RequestMapping(value="/testUrlAnt/*/ant")
public String testUrlAnt(){
System.out.println("testUrlAnt");
return "success";
}
<a href=springmvc/testUrlAnt/mnbv/ant>testUrlAnt</a>
三、 PathVariable注解( 可以来映射 URL 中的占位符到目标方法的参数中)
@RequestMapping(value="/testPathVariable/{id}")
public String testPathVariable(@PathVariable("id") int id){
System.out.println("testPathVariable:"+id);
return "success";
}
<a href=springmvc/testPathVariable/1>testPathVariable</a>
四、REST
1.rest方式的url
Rest 风格的 URL. 以 CRUD 为例:
新增: /order POST(没有id)
修改: /order/1 PUT 普通风格: update?id=1
删除:/order/1 DELETE 普通风格:delete?id=1
查找:/order/1 GET 普通风格:get?id=1
2.如何发送PUT请求和DELETE请求
1. 需要在web.xml中配置 HiddenHttpMethodFilter
<!--
配置 org.springframework.web.filter.HiddenHttpMethodFilter: 可以把 POST 请求转为 DELETE 或 POST 请求
-->
<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>
2. 需要发送 POST 请求
3. 需要在发送 POST 请求时携带一个 name="_method" 的隐藏域, 值为 DELETE 或 PUT
<form action="springmvc/testRest/1" method="post">
<input type="hidden" name="_method" value="PUT" />
<input type="submit" value="PUT" />
</form>
<form action="springmvc/testRest/1" method="post">
<input type="hidden" name="_method" value="DELETE" />
<input type="submit" value="DELETE" />
</form>
<form action="springmvc/testRest" method="post">
<input type="submit" value="post" />
</form>
<a href=springmvc/testRest/1>testRest</a>
4.在handler中获取
@RequestMapping(value="/testRest/{id}",method=RequestMethod.PUT)
public String testRestDeletePut(@PathVariable("id") int id){
System.out.println("put:"+id);
return "success";
}
@RequestMapping(value="/testRest/{id}",method=RequestMethod.DELETE)
public String testRestDelete(@PathVariable("id") int id){
System.out.println("delete:"+id);
return "success";
}
@RequestMapping(value="/testRest",method=RequestMethod.POST)
public String testRest(){
System.out.println("post");
return "success";
}
@RequestMapping(value="/testRest/{id}",method=RequestMethod.GET)
public String testRest(@PathVariable("id") int id){
System.out.println("get:"+id);
return "success";
}
五、RequestParam注解(来映射请求参数)
value 属性:即请求参数的参数名
required属性: 该参数是否必须. 默认为 true
defaultValue属性: 请求参数的默认值
@RequestMapping(value = "/testRequestParam")
public String testRequestParam(
@RequestParam(value = "username") String un,
@RequestParam(value = "age", required = false, defaultValue = "0") int age) {
System.out.println("testRequestParam, username: " + un + ", age: "
+ age);
return SUCCESS;
}
<a href="springmvc/testRequestParam?username=atguigu&age=11">Test RequestParam</a>
六、RequestHander注解(来映射请求头)
用法同 @RequestParam
@RequestMapping(value="/testRequestHeader")
public String testRequestHeader(@RequestHeader("Accept-Language") String al){
System.out.println("testRequestHander Accept-Language:"+al);
return "success";
}
<a href=springmvc/testRequestHander>testRequestHander</a>
七、CookieValue注解(映射一个 Cookie 值)
用法同@RequestParam
@RequestMapping(value="/testCookieValue")
public String testCookieValue(@CookieValue("JSESSIONID") String id){
System.out.println("testCookieValue CookieValue:"+id);
return "success";
}
<a href=springmvc/testCookieValue>testCookieValue</a>