当前位置: 首页>编程语言>正文

不使用spring 实现操作日志 springmvc不用xml配置

        Eclipse中SpringMVC的简单开发--Annotation一文中讲述了使用注释的方式进行SpringMVC的简单开发,而本文我们讲述的是另一种开发方式,即XML配置开发。XML配置开发则是Spring2.5之前唯一的开发方式,因此是比较传统的开发方式,我们通过本文的例子,来了解XML配置开发的优缺点。首先,与其它方式开发相同,先创建一个动态web项目,项目名为FirstSpringMVC。然后接着以下详细的步骤。

1.jar包的导入


        首先,需要将开发需要的jar包导入,一般把spring的lib下的包外加jstl.jar和commons-logging包等即可,复制到web项目的WEB-INF目录下lib文件下。具体如下图:


                                                   

不使用spring 实现操作日志 springmvc不用xml配置,不使用spring 实现操作日志 springmvc不用xml配置_SpringMVC,第1张


2.web.xml配置


        因为无论是XML配置开发还是annotation开发,请求与响应的过程都是由DispatcherServlet这个前端控制器进行调控整个过程的,因此web.xml文件内容与annotation开发时基本一致。


<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">  
 <!-- The front controller of this Spring Web application, responsible for handling all application requests -->  
    <servlet>  
        <servlet-name>springDispatcherServlet</servlet-name>  
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>  
        <init-param>  
            <param-name>contextConfigLocation</param-name>  
            <param-value>classpath:springMVC-servlet.xml</param-value>  
<!-- param-value中的是Spring的配置文件,这个是放在src目录下的配置文件,如果放在其他位置可以使用路径+文件名  
例如在WEB-INF  文件夹下面springmvc.xml 那么就可以写为<param-value>/WEB-INF/springmvc.xml</param-value>  -->       
		</init-param>  
        <load-on-startup>1</load-on-startup>  
    </servlet>  
  
    <!-- Map all requests to the DispatcherServlet for handling -->  
    <servlet-mapping>  
        <servlet-name>springDispatcherServlet</servlet-name>  
        <url-pattern>/</url-pattern>  
<!--过滤全部文件-->  
 	</servlet-mapping>
 	<welcome-file-list>
    <welcome-file>index.html</welcome-file>
    <welcome-file>index.htm</welcome-file>
    <welcome-file>index.jsp</welcome-file>
    <welcome-file>default.html</welcome-file>
    <welcome-file>default.htm</welcome-file>
    <welcome-file>default.jsp</welcome-file>
  </welcome-file-list>
 </web-app>
3.处理器开发


        这是XML配置开发和Annotation开发的最大区别:Annotation开发的控制器类是一个普通的类,而XML配置开发的类则需要实现Controller接口。至于存在差异的原因就是Annotation开发的时候需要用@Controller修饰类,则相当于XML配置实现Controller接口。这里有两个控制器类,一个是HelloController类,另一个是RejectController类。控制器类实现Controller接口,则需要实现handleRequest方法,其实现类可以访问对应请求的HttpServletRequest和HttpServletResponse,必须返回一个包含视图路径或者包含视图路径和模的ModelAndView对象。以下两个控制器类中return newModelAndView("hello")说明该类对应的视图页面是hello.jsp。


HelloController类:


package springmvc;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.*;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;

public class HelloController implements Controller {
	private static final Log logger=LogFactory.getLog(HelloController.class);

	@Override
	public ModelAndView handleRequest(HttpServletRequest arg0, HttpServletResponse arg1) throws Exception {
		// TODO Auto-generated method stub
		logger.info("HelloController called");
		return new ModelAndView("hello");
	}

}

RejectController类:

package springmvc;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.web.servlet.ModelAndView;
import org.springframework.web.servlet.mvc.Controller;

public class RejectController implements Controller {

	private static final Log logger=LogFactory.getLog(RejectController.class);
	@Override
	public ModelAndView handleRequest(HttpServletRequest arg0, HttpServletResponse arg1) throws Exception {
		// TODO Auto-generated method stub
		logger.info("HelloController called");
		String msg1="sorry!";
		return new ModelAndView("reject");
	}

}
4.SpringMVC配置文件


        该配置文件也体现了Annotation开发和XML配置开发的区别。其中主要不同是处理器映射器的配置,因为Annotation是打开了自动扫描与注释驱动所以并不需要处理器映射器,而XML配置则需要将用户的URL与处理器类相对应<bean name=... class=...>中,name对应的URL,而class对应的是处理类,而这里的name也就是先导页面jsp文件中出现的href的值。




<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
    xmlns:p="http://www.springframework.org/schema/p" xmlns:mvc="http://www.springframework.org/schema/mvc"
    xsi:schemaLocation="http://www.springframework.org/schema/beans 
            http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
            http://www.springframework.org/schema/context
            http://www.springframework.org/schema/context/spring-context-3.1.xsd
            http://www.springframework.org/schema/mvc 
            http://www.springframework.org/schema/mvc/spring-mvc-3.1.xsd">
    <!-- 配置适配器  -->
    <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"></bean>
    
    
    <!-- 配置处理器映射器 -->
    <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"></bean>
	<bean name="/hello.action" class="springmvc.HelloController"></bean>
	<bean name="/reject.action" class="springmvc.RejectController"></bean>
	
    
    
    
    <!-- 配置jsp视图解析器 ,需要有jstl这个jar包,否则不能映射-->
    <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
        <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/>
        <property name="prefix" value="/WEB-INF/jsp/"/>
        <property name="suffix" value=".jsp"/>
</bean>

</beans>



5.视图开发


        两个控制器类对应着hello.jsp和reject.jsp,具体如下:


hello.jsp:


<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!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=ISO-8859-1">
<title>Insert title here</title>
</head>
<div>
<center>
<body>
hello,carson!welcome to this page!
</body>
</center>
</div>
<form action="hello.action"></form>
</html>

reject.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>
<!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=ISO-8859-1">
<title>Insert title here</title>
</head>
<div>
<body>
<center>
I'm sorry,you can't open this page!
${msg1} 
</center>
</body>
</div>
</html>
6.项目文件结构


        项目文件结构也是需要注意的,文件需要有条理的放在相应文件夹,否则容易出错,尤其项目较大文件较多时,文件存储显得尤为重要,以下是该实例的文件结构:


                                                

不使用spring 实现操作日志 springmvc不用xml配置,不使用spring 实现操作日志 springmvc不用xml配置_不使用spring 实现操作日志_02,第2张


7.项目运行


点击项目右键run as-->run on server单击,选择相应的server,确认即可运行,首先我们看到先导页面。


不使用spring 实现操作日志 springmvc不用xml配置,不使用spring 实现操作日志 springmvc不用xml配置_不使用spring 实现操作日志_03,第3张



不使用spring 实现操作日志 springmvc不用xml配置,不使用spring 实现操作日志 springmvc不用xml配置_不使用spring 实现操作日志_04,第4张




不使用spring 实现操作日志 springmvc不用xml配置,不使用spring 实现操作日志 springmvc不用xml配置_不使用spring 实现操作日志_05,第5张


观察后两个页面的URL可以知道URL中的URI与之前SpringMVC配置文件中的bean的name是一致的,这就是配置的效果。




比较XML配置开发与Annotation开发,可以看出两者各有自己的特点:


1.XML需要更多的控制器类,而Annotation开发可以将所有处理方法放进一个控制器类中。


2.Annotation开发使得对控制器类需要做更多的工作,并且使得控制器类变得复杂,而XML配置开发,控制器类更符合单一职责原则。


3.XML配置则需要更多的XML方面的知识,而Annotation显得比较方便。



https://www.xamrdz.com/lan/5vm1960385.html

相关文章: