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

用惯了maven管理项目之后会发现自己懒惰了很多,所以决定放弃使用maven去学习spring3的mvc,采用传统的web project进行学习,好了闲话不说,首先我们需要知道spring mvc需要加什么包.

使用到spring mvc的需要加入以下依赖包:

org.springframework.aop-3.0.3.RELEASE.jar--------------Spring的切面编程

org.springframework.asm-3.0.3.RELEASE.jar--------------Spring独立的asm程序

org.springframework.beans-3.0.3.RELEASE.jar------------SpringIoC(依赖注入)的基础实现

org.springframework.context-3.0.3.RELEASE.jar-----------Spring提供在基础IoC功能上的扩展服务

org.springframework.core-3.0.3.RELEASE.jar--------------Spring的核心包

org.springframework.expression-3.0.3.RELEASE.jar------Spring表达式语言

org.springframework.web-3.0.3.RELEASE.jar--------------SpringWeb下的工具包

org.springframework.web.servlet-3.0.3.RELEASE.jar-----SpringMVC工具包,并且对JEE6.0 Servlet3.0的支持

除了spring的包之外还需要加入以下几个依赖包:

com.springsource.org.aopalliance-1.0.0.jar---------------aop的工具包

com.springsource.org.apache.commons.logging-1.1.1.jar----------commons的日志管理

本文使用了slf4j日志管理,所以需要加入以下包

slf4j-api-1.5.10.jar--------------------------------------------日志管理的增强

slf4j-log4j12-1.5.10.jar---------------------------------------日志包的连接层

所有包如图1springmvc需要的包:

image 图1:springmvc需要的包

实现的例子还是以helloworld的简单输出,以后再逐步加入数据库的操作,新建一个resource的source folder,用来存放spring的配置文件跟log4j.xml的日志文件

使用日志管理就必须要加入log4j.xml或者是log4j.properties进行配置,这里采用了Log4j.mxl进行配置

Log4j.xml:

<log4j:configuration xmlns:log4j="http://jakarta.apache.org/log4j/">

	<!-- Appenders -->
	<appender name="console" class="org.apache.log4j.ConsoleAppender">
		<param name="Target" value="System.out" />
		<layout class="org.apache.log4j.PatternLayout">
			<param name="ConversionPattern" value="%-5p: %c - %m%n" />
		</layout>
	</appender>
	
	<!-- Application Loggers -->
	<logger name="org.lxh.mvc.controller">
		<level value="debug" />
	</logger>
	
	<!-- 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 Logger -->
	<root>
		<priority value="info" />
		<appender-ref ref="console" />
	</root>
	
</log4j:configuration>

springmvc.xml

<!-- 对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="prefix" value="/" />
		<property name="suffix" value=".jsp"></property>
	</bean>

如果需要使用jstl的话则需要在<property>标签中加入

<property name="viewClass" value="org.springframework.web.servlet.view.JstlView" />

prefix:则为前缀,也就是目录的地址, 一般以"WEB-INF/xx"为主,若为 "/" 则为全局使用

suffix:则为后缀,也就是文件名的后缀.使用InternalResourceViewResolver类是只支持jsp,不支持html等其他后缀,如果强制加入其他后缀的话胡出现死循环,至于其他视图的话则以后在使用的时候再介绍

web.xml

	<servlet>
		<description>This is Spring MVC DispatcherServlet</description>
		<servlet-name>SpringMVC DispatchServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<init-param>
			<description>SpringContext</description>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath*:springmvc.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>SpringMVC DispatchServlet</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>

注意:配置spring的DispatcherServlet的时候,如果需要使用自定义名字的spring配置文件的话,需要在<serlvet>中加入<init-param>这个参数,否则的话spring会默认查找web-inf/classes下面以[servlet-name]-servlet.xml的文件,会出现以下错误:

ERROR: org.springframework.web.servlet.DispatcherServlet - Context initialization failed
org.springframework.beans.factory.BeanDefinitionStoreException: IOException parsing XML document from ServletContext resource [/WEB-INF/SpringMVC DispatchServlet-servlet.xml]; nested exception is java.io.FileNotFoundException: Could not open ServletContext resource [/WEB-INF/SpringMVC DispatchServlet-servlet.xml]

HelloWordController.java:

package org.lxh.mvc.controller;
 
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.servlet.ModelAndView;
 
@Controller
@RequestMapping("/test")
public class HelloWordController {
    private Logger logger = LoggerFactory.getLogger(HelloWordController.class);
 
    @RequestMapping("/hello")
    public void Hello() {
        logger.info("The hello() method is use");
    }
 
    @RequestMapping("/welcome")
    public String welcome() {
        logger.info("The welcome() method is use ");
//        return "/welcome";
         return "/WEB-INF/jsp/welcome";
    }
 
    @RequestMapping("/helloWorld")
    public ModelAndView helloWorld() {
        logger.info("The helloWorld() method is use");
        ModelAndView view = new ModelAndView();
        // view.setViewName("/helloworld");
        // view.setViewName("/WEB-INF/JSP/helloworld");
        view.setViewName("/hello");
        return view;
    }
}

可以发现上面为什么有那么多注释,

先一个一个来说明,spring mvc可以通过以下三种方式链接到视图解析器中,每种方法以requestMapping注解作为跳转.

第一种,使用无返回方法跳转,如果使用返回方法进行跳转的话,则会通过视图解析器进行以prefix(前缀)+方法名+suffix(后缀)组成的页面文件名称.这样的话可能需要用url writer框架进行重向地址更改,保证安全性.

第二种,使用一个返回的字符串方法作为跳转,使用字符串跳转的话好处就是在return的时候可以自己指定返回的名字,JSP组成是prefix(前缀)+返回的字符串+suffix(后缀),这样的话跳转的时候外围广很多而且,安全性相对高点

第三种,返回一个ModelAndView类型,ModelAndView是spring2.5经常使用的方式,使用setViewName方法则可以跳转到指定的页面.

在类中还还发现一个Contorller的注解,该注解是用于把当前Java类变成一个Spring里面的一个beans,如果在Class 上面加入requestMapping的话,而在方法上还拥有requestMapping,则在浏览器输入的地址为http://访问地址:端口/contextroot/要调用类的requestMapping跳转值/该类中存在的requestMapping/,而在Class上标记了requestMapping的话,则需要在指定的位置创建一个文件夹作为存放.

例如:

输入http://localhost:8080/SpringMVC_10000/test/hello的话则会查找根目录下面的test文件夹下面的hello.jsp.组成是 prefix(前缀)+/test/+方法名+suffix(后缀).目录结构如图2:

image 图2:跳转目录

posted @ 2010-07-23 14:42  EdwardLau  阅读(3042)  评论(0编辑  收藏  举报