springmvc 学习笔记

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" version="2.4"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">


<!-- Spring ApplicationContext配置文件的路径
此参数用于后面的Spring-Context loader -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:spring/*.xml</param-value>
</context-param>

<!--Spring ApplicationContext 载入 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
</web-app>


springmvc-servlet.xml

<?xml version="1.0" encoding="UTF-8"?>

<!--
修改说明:
1.修改<context:component-scan以确定要加载的controller,默认为com.**.controller
2.修改class=ControllerClassNameHandlerMapping节点的pathPrefix以确定要生成的前缀
-->
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd"
>
<!--
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>
<context:component-scan base-package="com.**.controller"/>
<bean class="cn.org.rapid_framework.spring.web.servlet.mvc.support.ControllerClassNameHandlerMapping" >
</bean>
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<property name="prefix" value="/pages"/>
<property name="suffix" value=".jsp"></property>
</bean>
-->
<!-- it's ok;-->
<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<prop key="test.do">testController</prop>
<prop key="testExtends.do">testExtendsController</prop>
<prop key="login.do">loginController</prop>
<prop key="login2.do">login2Controller</prop>
</props>
</property>
</bean>
<!-- 直接直向页面/WEB-INF/login.jsp -->
<bean id="loginController" class="org.springframework.web.servlet.mvc.ParameterizableViewController">
<property name="viewName" value="login"></property>
</bean>
<!-- login2Controller会指向 prop key='login2.do'里的login2页面+前后缀 -->
<bean id="login2Controller" class="org.springframework.web.servlet.mvc.UrlFilenameViewController">
</bean>
<bean id="testController" class="com.company.project.controller.TestController"></bean>
<bean id="testExtendsController" class="com.company.project.controller.TestExtendsController"></bean>
<bean class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"></property>
<property name="prefix" value="/WEB-INF/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>


能封装表单参数的 AbstractCommandController,CommondController、 FormController

web-inf/add_dept.jsp

<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<body>
<form action="" method="post">
name:<input type="text" name="name"><br>
createDate:<input type="text" name="createDate"><br>
<input type="submit" value="add">
</form>
</body>
</html>

springmvc-servlet.xml

<bean class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<prop key="add_dept.do">addDeptController</prop>
</props>
</property>
</bean>
<bean id="addDeptController" class="com.company.project.controller.DeptController">
<property name="commandClass" value="com.company.project.model.Department"></property>
</bean>

<bean class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"></property>
<property name="prefix" value="/WEB-INF/"></property>
<property name="suffix" value=".jsp"></property>
</bean>

会正常转换 整型及字符串,如果输入的不是一个整数,就会为0;
spring mvc 默认提供了一些属性编辑器:int,float,double,long,string,class,url

DeptController

package com.company.project.controller;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.validation.BindException;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractCommandController;
import com.company.project.model.Department;
public class DeptController extends AbstractCommandController{
//数据绑定 到model里。
@Override
protected ModelAndView handle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, BindException arg3) throws Exception {
Department dept = (Department)arg2;
return null;
}
}


自定义属性编辑器:

package com.company.project.controller;
import java.text.SimpleDateFormat;
import java.util.Date;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.beans.propertyeditors.CustomDateEditor;
import org.springframework.validation.BindException;
import org.springframework.web.bind.ServletRequestDataBinder;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.AbstractCommandController;

import com.company.project.MyConverter;
import com.company.project.model.Department;
public class DeptController extends AbstractCommandController{
//数据绑定 到model里。
@Override
protected ModelAndView handle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, BindException arg3) throws Exception {
Department dept = (Department)arg2;
return null;
}

@Override
protected void initBinder(HttpServletRequest arg0, ServletRequestDataBinder binder) throws Exception {
//这是一种做法
//binder.registerCustomEditor(Date.class, new MyConverter());
// 日期类型提供了半成品的一个属性编辑器 true:表示可以不输入这个日期,也就是说这个日期可以为空
binder.registerCustomEditor(Date.class, new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"),true));
}
}

MultiActionController
package com.company.project.controller;

import java.util.HashMap;
import java.util.Map;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.multiaction.MultiActionController;

import com.company.project.model.Department;

public class MultController extends MultiActionController{
//方法必须要有request,response,可选参数session,Model
public ModelAndView toAdd(HttpServletRequest request,HttpServletResponse response){
//ModelAndView mav = new ModelAndView("add_dept",model);
ModelAndView mav = new ModelAndView();
Map<String, Object> depts = new HashMap<String, Object>();
//设置视图名称
mav.setViewName("add_dept");
//设置模型
mav.addAllObjects(depts);
return mav;
}

public ModelAndView toList(HttpServletRequest request,HttpServletResponse response,HttpSession session,Department dept){
System.out.println(dept);
//return "success";
return new ModelAndView("success");
}
public Map xxx(HttpServletRequest request,HttpServletResponse response){

}
}


<bean
class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
<property name="mappings">
<props>
<prop key="add_dept.do">addDeptController</prop>
<prop key="list_dept.do">addDeptController</prop>
</props>
</property>
</bean>
<!-- 只有MultiActionController -->
<bean id="addDeptController"
class="com.company.project.controller.MultController">
<property name="commandClass" value="addDept.do"></property>
<!-- 方法名解析器 -->
<property name="methodNameResolver">
<!-- 按路径名解析,如prop key=list_dept.do,会执行list_dept方法,所以请求需跟方法名一致
<bean class="org.springframework.web.servlet.mvc.multiaction.InternalPathMethodNameResolver"></bean>
-->
<!-- 按参数解析 -->
<bean class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
<!-- 参数名需要有fun,然后根据fun的值,执行该方法,如:?fun=to_add,会执行to_add方法 -->
<property name="paramName" value="fun"></property>
</bean>
</property>
</bean>
<bean
class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="viewClass"
value="org.springframework.web.servlet.view.JstlView">
</property>
<property name="prefix" value="/WEB-INF/"></property>
<property name="suffix" value=".jsp"></property>
</bean>


简化URL映射关系
HanderMapping:

ControllerClassNameHanderMapping:按类名映射

<!-- 如果访问的URL为dept.do,会去找名称为DeptController类,id,name不重要
如果是MultController,如果是按路径名(InternalPathMethodNameResolver)解析器,可以用
mult/to_add.do:会执行MultController里的to_add方法
-->
<bean
class="org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping">
</bean>
<bean id="xxx" class="test.DeptController"></bean>
<!-- 只有MultiActionController -->
<bean id="addDeptController"
class="com.company.project.controller.MultController">
<property name="commandClass" value="addDept.do"></property>
<!-- 方法名解析器 -->
<property name="methodNameResolver">
<!-- 按路径名解析,如prop key=list_dept.do,会执行list_dept方法,所以请求需跟方法名一致 -->
<bean class="org.springframework.web.servlet.mvc.multiaction.InternalPathMethodNameResolver"></bean>
<!-- 按参数解析
<bean class="org.springframework.web.servlet.mvc.multiaction.ParameterMethodNameResolver">
参数名需要有fun,然后根据fun的值,执行该方法,如:?fun=to_add,会执行to_add方法
<property name="paramName" value="fun"></property>
</bean>
-->
</property>
</bean>
<bean
class="org.springframework.web.servlet.view.UrlBasedViewResolver">
<property name="viewClass"
value="org.springframework.web.servlet.view.JstlView">
</property>
<property name="prefix" value="/WEB-INF/"></property>
<property name="suffix" value=".jsp"></property>
</bean>


<!--BeanNameUrlHandlerMapping:会根据bean的url进行拦截 这种对MultController没办法使用-->
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping">
</bean>
<bean name="/test.do" class="com.company.project.controller.TestController"></bean>



annotation注解方式实现

controller类:
package test.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class TestController {
@RequestMapping("/start")
public String start(){
return "start";
}
}

web.xml:
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- Spring ApplicationContext配置文件的路径,可使用通配符,多个路径用1,号分隔
此参数用于后面的Spring-Context loader -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:spring/*.xml</param-value>
<!-- 手动指定配置文件位置及名称
<param-value>/WEB-INF/classes/springmvc-servlet.xml</param-value>
<param-value>/WEB-INF/classes/*.xml</param-value>
在spring包下的所有xml文件
<param-value>/WEB-INF/classes/spring/*.xml</param-value>
<param-value>classpath*:spring/*.xml</param-value>
-->
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
</web-app>

springmvc-servlet.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:p="http://www.springframework.org/schema/p"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<!-- 基于注解的方式 -->
<context:component-scan base-package="test.controller"/>
<!-- InternalResourceViewResolver:是在基于url的基础之上,加入了JSP,JSTL的视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<property name="prefix" value="/pages"/>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>

访问:http://localhost:8080/springmvc/start.do
会直接跳转到/pages/start.jsp

@RequestMapping:可以修饰类,及类里面的方法
如果在类级别定义了@RequestMapping,相当于定义了一个相对路径
如下:
@Controller
@RequestMapping("/test")
public class TestController {
@RequestMapping("/start")
public String start(){
return "start";
}
}

如果需要访问start方法,则应该是 localhost:8080/springmvc/test/start.do

如果没有类级别的@RequestMapping,则访问方法start方法,则应该是localhost:8080/springmvc/start.do, /:相当于根路径,处理求的方法必须要有@RequestMapping注解
处理以后请求,资源文件与上面相同,只是controller上不一样

http://localhost:8080/springmvc/start.do?name=zhangsan
package test.controller;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class TestController {
@RequestMapping("/start")
//可以只加一个request,也可以根据需要添加response,session,model等参数
public String start(HttpServletRequest request){
//传统的处理方法,
String name= request.getParameter("name");
return "start";
}
}

spring3.0引入了一种restful风格的模式:基于url参数的形式进行请求,如下:
http://localhost:8080/springmvc/start.do?name=zhangsan
http://localhost:8080/springmvc/start.do?name=lisi

处理形式:restful风格,请求的参数作为url一部分存在
http://localhost:8080/springmvc/start/zhangsan.do
http://localhost:8080/springmvc/start/lisi.do

支持restful风格需要有一个参数PathVariable,定义url模板,指定可变部分:

例子:处理
http://localhost:8080/springmvc/start/zhangsan.do
http://localhost:8080/springmvc/start/lisi.do
配置文件以之前一样,Controller类里:
----------------------------------------------------
package test.controller;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;

@Controller
public class TestController {
//{name}:表示可变部分,/start/{name}就是URL模板
@RequestMapping("/start/{name}")
//可以只加一个request,也可以根据需要添加response,session,model等参数
public String start(@PathVariable("name") String name){
//@PathVariable String name:路径变量;用于取URL模板里可变部分的值,2个name须一致
System.out.println(name);
return "start";
}
}

如果是多个可变参数:
@Controller
public class TestController {
@RequestMapping("/start/{name}/{age}")
public String start(@PathVariable("name") String name,@PathVariable("age") int nianling){
System.out.println(name);
System.out.println(nianling);
return "start";
}
}

如URL请求为:
http://localhost:8080/springmvc/start/zhangsan/20.do
===========================================================
@RequestMapping:可以根据不同的请求方法,映射到不同的处理方法,与之前的formcontroller相似,请求方法:post,get
package test.controller;

import javax.servlet.http.HttpServletRequest;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;

@Controller
public class TestController {
//处理get请求,如直接在地址栏输入 http://localhost:8080/springmvc/start.do
@RequestMapping(value="/start",method=RequestMethod.GET)
public String start(){
return "start_get";
}
//处理post请求, form以post方式提交,http://localhost:8080/springmvc/start.do
@RequestMapping(value="/start",method=RequestMethod.POST)
public String startPost(){
//跳转到start_post.jsp页面
return "start_post";
}
}

http://localhost:8080/springmvc/test/1986-07-06.do
package test.controller;

import java.text.SimpleDateFormat;
import java.util.Date;
import javax.servlet.http.HttpServletRequest;
import org.springframework.beans.factory.config.CustomEditorConfigurer;
import org.springframework.beans.propertyeditors.CustomDateEditor;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.InitBinder;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.support.WebRequestDataBinder;
@Controller
@RequestMapping("/test")
public class TestController {
//如果方法上没指定映射的value,则会映射到类级别/test
@RequestMapping(value="{test}",method=RequestMethod.GET)
public String startPost(@PathVariable("test") Date test){
System.out.println(test);
return "success";
}
@InitBinder
//参数可以有request,response,session,webrequestdatabinder(绑定数据)
public String initBinder(WebRequestDataBinder binder){
//所有日期类型都会进行转换,且不能不空
binder.registerCustomEditor(Date.class, new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"),false));
}
}

@Controller
@RequestMapping("/test")
public class TestController {
//如果方法上没指定映射的value,则会映射到类级别/test
@RequestMapping(value="{test}",method=RequestMethod.GET)
public String startPost(@PathVariable("test") Date test){
System.out.println(test);
return "success";
}
@InitBinder
//参数可以有request,response,session,webrequestdatabinder(绑定数据)
public String initBinder(WebRequestDataBinder binder){
//所有日期类型都会进行转换,且不能不空
binder.registerCustomEditor(Date.class, new CustomDateEditor(new SimpleDateFormat("yyyy-MM-dd"),false));
}
@RequestMapping("/testRequest")
public void testRequest(@RequestParam int id,@CookieValue anytype cookieName,@RequestHeader("content-type") anyType abc ){
//@RequestParam int id 类型可以是任何类型,参数名必须与请求的参数名一样
//@RequestHeader:从请求头里取,@RequestHeader("user-Agent"):浏览器类型
//@CookieValue:从cookie里取
//http://localhost:8080/springmvc/testRequest.do?id=xxx
System.out.println(id);
}
}

@RequestMapping("/testOut")
public String testOut(PrintWriter out,Map model){
//这里的out相当于 response.getWriter();
out.println("hello ");
//这里的model相当于ModelAndView对象,会直接初始化
model.put("key", "value");
return "viewName";
}

自动封装属性
http://localhost:8080/springmvc/testMethod.do?name=xxx&pass=xxx

User类里有name,pass属性:

Controller类里的方法:
@RequestMapping("/testMethod")
public void testMethod(User user){
//这里会自动给user的name,pass赋值
//User:为commend对象,领域模型
System.out.println(user);
}

@RequestMapping("/testMethod")
public void testMethod(User user,BindingResult result){
//BindingResult:用于验证对象绑定结果,把绑定过程出错的地方用在result里。如果不想处理错误绑定,则不需要指定
System.out.println(user);
}

基于配置文件的SpringMVC处理请求的方法定义总结:
public (ModelAndView | Map | String | void) actionName(HttpServletRequest request, HttpServletResponse response, [,HttpSession] [,AnyObject]);

参数类型:
1.HttpServletRequest(必须有)
2. HttpServletRespons(必须有)
3。HttpSession(可选)
4.AnyObject(可选)
备注:如果object与session都有,则session应为第三个参数

返回值类型:
1,ModelAndView
2.Map
3.String
4.void

基于注解的MVC,能够处理请求的方法定义总结:

参数类型:对数量及顺序是没有要求的
1,可以没有();
2,可以是HttpServletRequest
3,可以是HttpServletResponse
4,可以是HttpSession
5,可以是路径变量@PathVariable
6,可以是@RequestParam
7,可以是@CookieValue
8,可以是@RequestHeader
9,可以是PrintWriter
10,可以是Map model
11,可以是领域模型对象

备注:HttpSessiond需要有一个前提条件,那就是当前请求的session可用:即在这之前session已经被初始化:也就是说在这之前调用了request.getSession()或者session.setAttribute(),直接进入jsp页面,也会初始化session

返回值类型:
1,ModelAndView
2.Map
3.String:代表了viewName,model也会自动返回
4.void:一般使用out方法输出之后就用void
5.AnyType:返回任意类型的对象
6.List
@RequestMapping("/xxx")
public void testVoid(){
//如果没有使用out对象,则会隐含默认生成一个viewName--:是按请求路径解析出来的
//如:请求路径为:http://localhost:8080/springmvc/test/xxx.do,则生成的视图名为test/xxx
// /WEB-INF/page/test/xxx.jsp
System.out.println("...");
}

//返回任意对象

@RequestMapping("/xxx")
public User test(){//相当于model里添加了一个 model.put("key","value"),key:为默认类名(user),value为返回的对象
return null;
//视图名与void时一样:则会隐含默认生成一个viewName--:是按请求路径解析出来的
//如:请求路径为:http://localhost:8080/springmvc/test/xxx.do,则生成的视图名为test/xxx
// /WEB-INF/page/test/xxx.jsp


返回List

@RequestMapping("/xxx")
public List<User> query(){
return null;
//list也会加入到model里,默认key是实际成员的名+List如:model("userList",user).

可以使用EL表达式取里面的值:${userList},也可以request.getAttribute("userList")
##############annotation注解方式实现 结束###################

Spring MVC 常用 ViewResolver & View
@、 InternalResourceViewResolver、 UrlBasedViewResolver
@、Redirect 重定向视图 (redirect:)
@、XmlViewResovler
@、视图链
@、JstlView, ExcelView及自定义view (JsperReport, Pdf, Excel)


重定向视图:
防止重复提交,可以使用重定向

@RequestMapping(method=RequestMethod.POST)
public String addUser(User user){
return "redirect:/add_success";
}


#######拦截器,视图国际化,验证############################
拦截器:inteceptor
全局日志,权限管理

1.定义拦截器:
package test.web;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.handler.HandlerInterceptorAdapter;

public class MyInteceptor implements HandlerInterceptor{

public void afterCompletion(HttpServletRequest arg0,
HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {

}
//控制器已经执行完,生成视图之前可以做的操作,通常是向模型中加入一些公共成员
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object arg2, ModelAndView arg3) throws Exception {
}

public boolean preHandle(HttpServletRequest arg0, HttpServletResponse arg1,
Object handler) throws Exception {
//handler:指的是下一个对象的引用,如果是有两个拦截器,这就是指第二个拦截器对象,最后一个就是Controller
return false;
//return true:表示继续执行,false:表示直接中断,不会再执行之后的操作
}
}

springmvc-servlet.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:p="http://www.springframework.org/schema/p"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<!-- 基于注解的方式 -->
<context:component-scan base-package="test.controller"/>
<!-- InternalResourceViewResolver:是在基于url的基础之上,加入了JSP,JSTL的视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<property name="prefix" value="/pages"/>
<property name="suffix" value=".jsp"></property>
</bean>
<mvc:inteceptors>
<mvc:inteceptor>
<!-- path如果不指定,则对所有的请求都拦截
<mvc:mapping path=""/>-->
<!-- 表示符合/user/*这样的模式才拦截 -->
<mvc:mapping path="/user/*"/>
<bean class="test.web.MyInteceptor"></bean>
</mvc:inteceptor>
<!-- 可以定义多个inteceptor,按顺序执行 -->
</mvc:inteceptors>
</beans>

国际化ResourceMessage

在根路径下建立资源文件:
mess.properties
mess_en_US.properties
mess_zh_CN.properties
分别定义如下:
welcome="welcome"
welcome="(US)welcome"
welcome="欢迎你!"


jsp页面里,使用<spring:message/>

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@ taglib uri="http://www.springframework.org/tags" prefix="spring"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<body><!-- 国际化的key为welcome -->
<spring:message code="welcome"/><br>
</body>
</html>


加载国际化资源文件,需要在springmvc-servlet.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:p="http://www.springframework.org/schema/p"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-2.5.xsd">
<!-- 基于注解的方式 -->
<context:component-scan base-package="test.controller"/>
<!-- InternalResourceViewResolver:是在基于url的基础之上,加入了JSP,JSTL的视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
<property name="prefix" value="/pages"/>
<property name="suffix" value=".jsp"></property>
</bean>
<!-- 加载国际化配置,这里定义的id名必须为 messageSource-->
<bean id="messageSource" class="org.springframework.context.support.ResourceBundleMessageSource">
<!-- 根名称:去掉多语言后的名称,如这里的 mess,为在当前classpath里去找mess国际化配置文件 -->
<property name="basename" value="mess"></property>
<!-- 如果有多组国际化文件,可以指定basenames,它是一个list,配置如下 -->
<property name="basenames">
<list>
<value>mess1</value>
<value>mess2</value>
<value>....</value>
</list>
</property>
</bean>
</beans>



JSR-303 validate bean 验证
如:User类里
public class User {
@NotEmpty
private String name;
@Size(max=20,min=6)
private String pass;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getPass() {
return pass;
}
public void setPass(String pass) {
this.pass = pass;
}
}

然后在Controller里
@RequestMapping("/testMethod")
public void testMethod(@Valid User user,BindingResult result){
if(result.hasErrors()){
return "error";
}
System.out.println(user);
}

在参数里加@Valid注解,就会当这个user进行绑定的时候,就验证,验证的规则定义在User类里,如果验证过程出错,就会把错误信息放在BindingResult里
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值