jstl的使用举例(国际化)
- 导入jar包
jstl.jar
standard.jar
- 在springmvc.xml中配置国际化资源文件
<!-- 国际化资源文件 -->
<bean id="messageSource"
class="org.springframework.context.support.ResourceBundleMessageSource">
<!-- 配置i18n为基名 -->
<property name="basename" value="i18n"></property>
</bean>
- 在src下建立资源文件
i18n_en_US.properties
i18n_en_US.properties
i18n.username=username
i18n.password=password
i18n.username=\u7528\u6237\u540D
i18n.password=\u5BC6\u7801
- 代码
<a href="springmvc/testJstl">testJstl</a>
@RequestMapping("/testJstl")
public String testJstl(){
return SUCCESS;
}
//当前页记得加入fmt标签哟
//<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %>
<fmt:message key="i18n.username"></fmt:message>
<fmt:message key="i18n.password"></fmt:message>
- ie测试
mvc_view_controller标签
springmvc.xml中配置
<!-- 可以输入指定的path,无需经过Handler方法,直接跳转到目标页面 -->
<mvc:view-controller path="/success" view-name="success"/>
<!-- 在开发中通常都需要配置该标签;这样才不会影响其他页面到Handler方法的过程 -->
<mvc:annotation-driven></mvc:annotation-driven>
那么访问页面
就可以直接跳转到WEB-INF/views/success.jsp页面而不用经过Handler的方法了
springmvc自定义视图
在springmvc中配置BeanNameViewResolver视图解析器
<!-- 配置视图解析器:BeanNameViewResolver -->
<bean class="org.springframework.web.servlet.view.BeanNameViewResolver">
<property name="order" value="10"/>
<!-- InternalResourceViewResolver的order是integer.max_value
所以该视图解析器随便一个order值,优先级也比 InternalResourceViewResolver
解析器高(order值越小优先级越高)-->
</bean>
自定义一个视图
@Component
public class HelloView implements View {
@Override
public String getContentType() {
// TODO Auto-generated method stub
return "text/html";
}
@Override
public void render(Map<String, ?> arg0, HttpServletRequest request, HttpServletResponse response) throws Exception {
response.getWriter().write("Welcome to helloView:"+new Date());
}
}
Handler类
@RequestMapping("/testBeanNameViewResolver")
public String testBeanNameViewResolver(){
System.out.println("已经来到了beannameview");
return "helloView";//类首字母小写
}
当testBeanNameViewResolver方法返回“helloView”时,经过BeanNameViewResolver视图解析器的解析,会进入到我们自字义的view
转发/重定向
@RequestMapping("/testRedirect")
public String testRedirect(){
// return "forward:/WEB-INF/views/success.jsp";//转发
return "redirect:/index.jsp";//重定向
/* 使用了forward或者redirect后,InternalResourceViewResolver
* 视图解析器就不会再帮我们添加pefix suffix了*/
}
访问静态资源
在springmvc中,我们在请求一个页面的时候一般都会经过web.xml配置的dispatcher,然后将请求页面转发到对应的处理器中,处理完后再跳到其他页面;但有时候我们并不希望进行此项操作,比如我们现在只是单纯的想访问一下某js文件
那么就无需经过dispatcher;
步骤如下:在springmvc.xml中配置
<!-- 处理静态资源请求 -->
<mvc:default-servlet-handler />
<!-- 使用了上面的标签后还是需要使用该标签来开启非静态资源请求的拦截 -->
<mvc:annotation-driven></mvc:annotation-driven>
一个路径问题
@RequestMapping(value="/emp/{id}",method=RequestMethod.DELETE)
public String delete(@PathVariable("id") Integer id){
System.out.println("delete"+id);
employeeDao.delete(id);
return "redirect:/list";
}
- 如果return "redirect:/list" 加了斜框,那么路径会为: %项目路径% /list;如:
http://localhost/springmvc_crud/a/b/c
http://localhost/springmvc_crud/list
- 如果return "redirect:list" 没有斜框,那么路径会为: 用/list替换当前路径的最后子路径如:
http://localhost/springmvc_crud/a/b/c
http://localhost/springmvc_crud/a/b/list
数据绑定的流程
- SpringMVC主框架将ServletRequest对象及目标方法的入参实例传递给WebDataBinderFactory实例,以创建DataBinder实例对象
- DataBinder调用装配在Spring MVC上下文的ConversionService组件进行数据类型转换,数据格式化工作。将Servlet中的请求信息填充到入参对象中
- 调用Validator组件对已经绑定了请求消息的入参对象进行数据合法性校验,并最终生成数据绑定结果
- Spring MVC抽取BindingResult中的入参对象和校验错误对象,将他们赋给处理方法的响应入参
InitBinder注解
- 由@InitBinder标识的方法,可以对WebDataBinder对象进行初始化。WebDataBinder是Databinder的子类,用于完成由表单字段到JavaBean属性的绑定
- @InitBinder方法不能有返回值,它必须声明为void
- @InitBinder方法的参数通常是WebDataBinder
@InitBinder
public void initBinder(WebDataBinder binder){
//告诉binder不允许该字段的映射
binder.setDisallowedFields("empName");
}