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

时间:2021-05-10 16:06:02

这篇不会大量的张贴代码,毕竟是自己对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>