Spring MVC3注解学习之简单入门范例

原创文章,转载请注明出处

本文地址:http://www.yshjava.cn/post/430.html

 

之前做Web应用都是在用Struts2,觉得功能强大,效率也能提升很多,所以一直都很喜欢Struts。虽然也曾经在接手前人遗留的项目时遭遇过Spring MVC,不过不知道是前人用的不好,还是自己水平差,亦或者是Spring MVC(那个时候还是2)本身的问题,让Spring MVC给自己留下了很不好的印象:配置文件繁琐、功能一般甚至简陋、不能够在开发效率上与Struts2媲美等等问题,致使自己一直以来都是带着偏见看待Spring MVC的,也因此一直都没有再去尝试过。

最近是一次偶然的机会,再次正面遭遇Spring MVC,不过这次它改头换面,由2升级到3了,看到别人基于Spring MVC注解方式写出来的简洁流畅的代码后,惊叹于Spring MVC3的注解驱动能力之强大,代码之简洁,觉得自己以前的偏见简直就是愚昧至极,不由地暗自对Spring MVC有了好感,打算实实在在尝试一把。

不过自己之前对Spring MVC确实不熟,加之这次升级的内容有点多,所以我找来了一份很好的入门文档《Spring3_MVC注解教程》作为自己的领路人。这份PPT做的很好,本文也是在此基础上有感而发的,在此感谢作者陈雄华先生的辛勤劳动和无私奉献!

本文所示代码均基于最新版SpringFrameword3.2.3,请知悉。

 

Spring MVC框架简介

  • 支持REST风格的URL
  • 添加更多注解,可完全注解驱动
  • 引入HTTP输入输出转换器(HttpMessageConverter)
  • 和数据转换、格式化、验证框架无缝集成
  • 对静态资源处理提供特殊支持
  • 更加灵活的控制器方法签名,可完全独立于Servlet API

 

Spring MVC框架结构

 

 

框架的实现者

 

 

如何在应用中使用Spring-MVC?

  1. 在应用中添加Spring框架支持;
  2. 在web.xml中配置Spring-MVC的请求转发器(前端控制器)
  3. 编写Spring-MVC的配置文件
  4. 将任意JavaBean通过注解配置成Controller(控制器)并注解其中的方法
  5. 完成

 

步骤简单明了,接下来我们一步一步详细说明:

在应用中加入Spring支持:

因为Spring-MVC是属于SpringFramework的一部分,因此要在应用中使用Spring-MVC,就必须以引入Spring基础框架为前提,另外还包括beans、context、aop、web组件,将上述组件的jar及其依赖添加到buildpath下,就算完成了为应用添加Spring框架支持的工作,然后在web.xml中配置Spring的监听器,代码如下:



	org.springframework.web.context.ContextLoaderListener


另外,因为是在web应用中使用Spring,因此建议配置一个名为org.springframework.web.util.IntrospectorCleanupListener的监听器来处理资源回收的工作:



	org.springframework.web.util.IntrospectorCleanupListener

 

再配置一个编码过滤器


	encodingFilter
	org.springframework.web.filter.CharacterEncodingFilter
	
		encoding
		UTF-8
	
	
		forceEncoding
		true
	


	encodingFilter
	/*
 


 

在web.xml中配置Spring-MVC的请求转发器(前端控制器)

在应用中使用Spring-MVC比较简单,除了需要引入相关依赖库外,还需要在web.xml配置Spring-MVC的请求转发器,代码如下:


	SpringMVCDispatcher
	org.springframework.web.servlet.DispatcherServlet
	
		
		contextConfigLocation
		
			classpath:mvc-config.xml
		
	
	1


	SpringMVCDispatcher
	
	/

 

编写Spring-MVC的配置文件

在上述代码中,我们告知Spring-MVC的请求转发器我们的mvc配置在classpath:mvc-config.xml中,因此我们需要在该文件中正确描述我们的mvc配置信息,配置代码如下:




	
    

	
	

	
	
		
 	
 	
 	
	
		
			
				
			
		
	
 	
 	
    
    
    
    
        
        	
        		
			    
			        
			        
			        
					
			    
			    
			    
					
					
					
					
			          
				
        	
        
    
    
    
    
    
    
    
        
        
    

 

将任意JavaBean通过注解配置成Controller(控制器)并注解其中的方法

本文主要示范如何使用注解为应用添加Spring-MVC支持,因此本文中的所有MVC映射配置都采用注解方式,范例Controller如下所示:

package cn.ysh.studio.spring.mvc.web;

import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.servlet.ModelAndView;

import cn.ysh.studio.spring.mvc.bean.User;

/**
 * @author Shenghany
 */
//通过注解将VisitController声明为一个Controller控制器
@Controller
//声明该Controller控制器的请求映射路径为/visit(非必须,可以不声明)
@RequestMapping("/visit")
public class UserController {

	//将当前方法的请求映射路径声明为create
    @RequestMapping("create")
    /**
     * 该方法将处理请求到/visit/create(控制器的映射路径(可以没有) + 处理方法的映射路径)路径的HTTP请求
     * @param model 将会被带到view层使用的数据模型
     * @return 逻辑视图名
     */
    public String create(Model model) {
        return "create";
    }

    @RequestMapping(value = "/visits", method = RequestMethod.POST)
    public ModelAndView visits() {
        ModelAndView mav = new ModelAndView("visitList");
        mav.addObject("visits", "");
        return mav;
    }
    
    @RequestMapping(value = {"/show", "view"}, method = {RequestMethod.GET, RequestMethod.POST})
    public String show(User user, Model model) {
        model.addAttribute("username", "springmvc");
        model.addAttribute("password", "类型非常灵活");
        return "show";
    }
    
    @RequestMapping("/hello/{username}")
    public String hello(@PathVariable("username")/*URL中的{xxx}占位符可以通过@PathVariable("xxx")绑定到操作方法的入参中*/String username, Model model) {
        model.addAttribute("username", username);
        model.addAttribute("password", "类型非常灵活");
        return "hello";
    }
    

}

 

为了是上面的Controller能够正常使用,我们还需要在WebRoot下创建Controller中使用的逻辑视图对应的视图文件,以上例中create为例,我们在WEB-INF/jsp/目录下新建jsp文件,内容如下:

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%>



  
    
    
    创建新用户
	
	
	    
  
  
  
    这是一个创建新用户的页面,对应的请求地址为<%=basePath%>visit/create
  

 

完成上述四个步骤后,将工程部署到任意web容器(本文采用tomcat6.0),然后启动,即可在浏览器中浏览映射出来的地址,如果需要在记录详细的Spring调试信息,则可以通过配置log4j来实现(这里多说一句,Spring的调试信息真的很详细很丰富,通过分析日志,将有助于我们快速理解和掌握Spring-MVC的工作原理)。

以访问示例中create地址为例,结果图如下所示:

 

至此,Spring-MVC算是简单入门了,但上述例子并未展现Spring-MVC注解的强大功能,稍后将会在一个单独的篇幅中详细介绍。

原创文章,转载请注明出处http://www.yshjava.cn/post/430.html

 

 

 

 

 

 

你可能感兴趣的:(Java,Web,spring,mvc)