[学习笔记]基于注解的spring3.0.x MVC学习笔记(三)
来源:互联网 发布:java多线程单例 编辑:程序博客网 时间:2024/05/16 10:07
这篇不会大量的张贴代码,毕竟是自己对springMVC的学习,而不是对某一种东西作为详细解析的,好了话不多说了,近期学习springMVC换了不少东西,连日志工具也换了,采用了slf4j+logback进行日志管理,至于好处,请自行Google
如何把主流的log4j+commons-loggin更换为slf4j+logback呢,由于spring里面采用了commons-logging日志监控,所以我们需要准备以下几个包:
logback-classic.jar:改善了log4j并且实现了slf4j-log4j的代码
logback-core.jar:logback的核心代码
slf4j-api.jar:slf4j实现代码
jcl-over-slf4j.jar:代替commons-loggin类
log4j-over-slf4j.jar(可选):替换log4j。原有的log4j.properites将失效,需要转换为logback.xml
jul-to-slf4j.jar:(可选)替换jdk logging。需要在程序开始时调用SLF4JBridgeHandler.install()来注册listener。
LogBack.xml配置文件跟Log4j.xml的配置文件非常相似:
<?xml version="1.0" encoding="UTF-8"?><configuration><appender class="ch.qos.logback.core.ConsoleAppender" name="STDOUT"><encoder><pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{100} - %msg%n</pattern></encoder></appender><logger name="org.lxh.mvc.controller" level="INFO" /><!-- 3rdparty Loggers --><logger name="org.springframework.core"><level value="info" /></logger><logger name="org.springframework.beans"><level value="info" /></logger><logger name="org.springframework.context"><level value="info" /></logger><logger name="org.springframework.web"><level value="info" /></logger><root><level value="debug" /><appender-ref ref="STDOUT" /></root></configuration>
logger{100} :是限制当前日志显示内容的长度,最大为100个字符
如何使用logback+slf4j?
参考代码:
private Logger logger = LoggerFactory.getLogger(RequestMappingStudy1.class);
同以前使用log4j+commons-logging是一样的方式,只是换了使用slf4j的工厂类而已
用到spring配置如下:
<!-- 对spring org.lxh包下所有注解扫描 --><context:component-scan base-package="org.lxh"></context:component-scan><!-- 支持spring mvc新的注解类型 详细spring3.0手册 15.12.1 mvc:annotation-driven--><mvc:annotation-driven /><!-- 对模型视图名称的解析,即在模型视图名称添加前后缀,在requestmapping输入的地址后自动调用该类进行视图解析--><bean id="viewResolver"class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="viewClass"value="org.springframework.web.servlet.view.JstlView"></property><property name="prefix" value="/" /><property name="suffix" value=".jsp"></property></bean>
这次开始主要对spring的每个注解用法进行详细的介绍,
@RequestMapping的参数如下
/**
* @see RequestMapping 参数
*
* @param value
* 需要跳转的地址
* @param mehtod
* 基于RestFul的跳转参数,有RequestMethod.get post,put 等
* @param params
* 符合某个参数的时候才调用该方法
* @param headers
* 符合头信息的时候才调用
* */
SpringMVC中大部分请求都是由RequestMapping提交的,而且提交的类型有很多种,以3.0来讲一般的请求方式有以下几种
第一种:以无参的形式返回:
/**
* 无参数返回的是根据 prefix前缀+@RequestMapping value +suffix后缀组成
*
* */
@RequestMapping("/novoid")
public void novoid() {
logger.info(this.getClass().getSimpleName() + "novoid方法被调用");
}
返回的地址是http://访问地址/项目名称/spring配置文件bean 为viewResolver 的prefix的值+requestMapping返回的值+suffix的值
第二种:返回一个String类型:
/**
* 根据String字符串返回对应的地址 prefix前缀+返回值+suffix后缀组成
* */
@RequestMapping("/string")
public String string() {
logger.info("String 方法调用");
return "WEB-INF/jsp/success";
}
第三种:返回一个ModelAndView对象
/**
* spring2.5的方法,返回一个ModelAndView 对象,通过setViewName方法跳转到指定的页面 调用addObject
* 相当于调用request.setAttribute方法
* */
@RequestMapping("/modelview")
public ModelAndView view(Model model) {
logger.info("view 方法调用");
ModelAndView andView = new ModelAndView();
andView.setViewName("WEB-INF/jsp/success");
return andView;
}
第四种返回一个Map集合
/**
* @see 使用map作为返回值的时候 是以prefix前缀+requestMapping的value+suffix后缀组成 返回一个map
* ,map的put方法调用相当于request.setAttribute方法
* */
@RequestMapping("/mapa")
public Map<String, Object> mapa(ModelMap map1) {
Map<String, Object> map = new HashMap<String, Object>();
UserBean bean = new UserBean();
bean.setId(1);
bean.setUsername("Edward Lau");
bean.setPassword("edward");
map.put("hello", "world key");
map.put("user", bean);
return map;
}
使用第四种方法,可以在页面中通过调用JSTL进行取值,如下面jsp代码
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Mapa</title>
</head>
<body>
Map a
姓名:${user.username }
密码:${user.password }
hello:${hello }
</body>
</html>
第五种返回一个ModelMap类型:
/** * @see 返回一个ModelMap类型,返回地址根据以prefix前缀+requestMapping的value+suffix后缀组成 * ModelMap 本身也拥有hashmap的方法,也可以使用addAllAttributes对一个map添加到attribute里面 * */@RequestMapping("/map")public ModelMap map() {ModelMap map = new ModelMap();map.addAttribute("aa", "bb");map.addAllAttributes(temp());return map;}/** *@see 临时类 *@return 返回一个map类型 * */public Map<String, UserBean> temp() {Map<String, UserBean> map1 = new HashMap<String, UserBean>();UserBean bean = new UserBean();bean.setId(1);bean.setUsername("Edward Lau");bean.setPassword("edward");map1.put("user", bean);// map1.put("hello", "world key");UserBean bean1 = new UserBean();bean1.setId(2);bean1.setUsername("Edward Lau2");bean1.setPassword("edward");map1.put("user1", bean1);System.out.println(map1);return map1;}
使用ModelMap可以把一个多个集合存到一个属性中,可以直接在页面调用EL 语言进行读取,jsp代码如下:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Mapa</title>
</head>
<body>
Map a
姓名:${user.username }
密码:${user.password }
hello:${hello }
aa:${aa }
</body>
</html>
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(三)
- 基于注解的spring3.0.x MVC学习笔记(二)
- 基于注解的spring3.0.x MVC学习笔记(一)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(八)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(二)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(四)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(五)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(六)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(七)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(八)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(九)
- 基于spring source tools suite注解的spring3.0.x MVC学习笔记(一)
- 基于spring source tools suite注解的spring3.0.x MVC学习笔记(二)
- 基于annotation注解的Spring3 MVC Page Redirection Example之三页面重定向学习笔记
- 基于注解的spring 3.0.x MVC学习笔记(一)
- Spring3.X学习笔记3-基于注解和基于Java类的配置
- 基于annotation注解的Spring3 MVC之一 HelloWorld 例子学习笔记
- 基于annotation注解的Spring3 MVC Form Handling Example之二表单提交学习笔记
- [转] [学习笔记]基于注解的spring 3.0.x MVC学习笔记(一)
- JavaScript中typeof的用法
- 全民内核-配置3-处理器相关&&虚拟平台
- 互联网之灰度升级
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(二)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(三)
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(四)
- 369. Reading enrichs the mind. 开卷有益
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(五)
- 2012年的感悟
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(六)
- Java学习笔记(异常处理)
- winform缩放时,控制控件的比例
- [学习笔记]基于注解的spring3.0.x MVC学习笔记(七)