注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

淡泊明智

 
 
 

日志

 
 

基于注解的spring3.0.x MVC学习笔记(三)  

2012-04-26 15:07:42|  分类: Spring |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

这篇不会大量的张贴代码,毕竟是自己对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>
  评论这张
 
阅读(192)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018