[学习笔记]基于注解的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>
原创粉丝点击