`

Spring_MVC(2)控制层处理

阅读更多

言归正传,研究一下注解下的控制层。
我习惯于使用JSTL展示页面,因此需要在原lib基础上增加jstl.jar和standard.jar,详细lib依赖如下:

引用

aopalliance-1.0.jar
commons-logging-1.1.1.jar
log4j-1.2.15.jar
spring-beans-2.5.6.jar
spring-context-2.5.6.jar
spring-context-support-2.5.6.jar
spring-core-2.5.6.jar
spring-tx-2.5.6.jar
spring-web-2.5.6.jar
spring-webmvc-2.5.6.jar
standard.jar
jstl.jar


上一篇文中,我们定义了控制器AccountController:
AccountController.java

Java代码 复制代码
  1. /**  
  2.  * 2010-1-23  
  3.  */  
  4. package org.zlex.spring.controller;   
  5.   
  6. import javax.servlet.http.HttpServletRequest;   
  7. import javax.servlet.http.HttpServletResponse;   
  8.   
  9. import org.springframework.beans.factory.annotation.Autowired;   
  10. import org.springframework.stereotype.Controller;   
  11. import org.springframework.web.bind.ServletRequestUtils;   
  12. import org.springframework.web.bind.annotation.RequestMapping;   
  13. import org.springframework.web.bind.annotation.RequestMethod;   
  14. import org.zlex.spring.service.AccountService;   
  15.   
  16. /**  
  17.  *   
  18.  * @author <a href="mailto:zlex.dongliang@gmail.com">梁栋</a>  
  19.  * @version 1.0  
  20.  * @since 1.0  
  21.  */  
  22. @Controller  
  23. @RequestMapping("/account.do")   
  24. public class AccountController {   
  25.   
  26.     @Autowired  
  27.     private AccountService accountService;   
  28.   
  29.     @RequestMapping(method = RequestMethod.GET)   
  30.     public void hello(HttpServletRequest request, HttpServletResponse response)   
  31.             throws Exception {   
  32.   
  33.         String username = ServletRequestUtils.getRequiredStringParameter(   
  34.                 request, "username");   
  35.         String password = ServletRequestUtils.getRequiredStringParameter(   
  36.                 request, "password");   
  37.         System.out.println(accountService.verify(username, password));   
  38.     }   
  39. }  
/**
 * 2010-1-23
 */
package org.zlex.spring.controller;

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

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.ServletRequestUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.zlex.spring.service.AccountService;

/**
 * 
 * @author <a href="mailto:zlex.dongliang@gmail.com">梁栋</a>
 * @version 1.0
 * @since 1.0
 */
@Controller
@RequestMapping("/account.do")
public class AccountController {

	@Autowired
	private AccountService accountService;

	@RequestMapping(method = RequestMethod.GET)
	public void hello(HttpServletRequest request, HttpServletResponse response)
			throws Exception {

		String username = ServletRequestUtils.getRequiredStringParameter(
				request, "username");
		String password = ServletRequestUtils.getRequiredStringParameter(
				request, "password");
		System.out.println(accountService.verify(username, password));
	}
}


先说注解@RequestMapping
这里使用注解@RequestMapping(method = RequestMethod.GET)指定这个方法为get请求时调用。同样,我们可以使用注解@RequestMapping(method = RequestMethod.POST)指定该方法接受post请求。

Java代码 复制代码
  1. @Controller  
  2. @RequestMapping("/account.do")   
  3. public class AccountController {   
  4.   
  5.     @RequestMapping(method = RequestMethod.GET)   
  6.     public void get() {   
  7.     }   
  8.   
  9.     @RequestMapping(method = RequestMethod.POST)   
  10.     public void post() {   
  11.     }   
  12. }  
@Controller
@RequestMapping("/account.do")
public class AccountController {

	@RequestMapping(method = RequestMethod.GET)
	public void get() {
	}

	@RequestMapping(method = RequestMethod.POST)
	public void post() {
	}
}


这与我们久别的Servlet很相像,类似于doGet()和doPost()方法!
我们也可以将其改造为多动作控制器,如下代码所示:

Java代码 复制代码
  1. @Controller  
  2. @RequestMapping("/account.do")   
  3. public class AccountController {   
  4.   
  5.     @RequestMapping(params = "method=login")     
  6.     public void login() {   
  7.     }   
  8.   
  9.     @RequestMapping(params = "method=logout")     
  10.     public void logout() {   
  11.     }  
@Controller
@RequestMapping("/account.do")
public class AccountController {

	@RequestMapping(params = "method=login")  
	public void login() {
	}

	@RequestMapping(params = "method=logout")  
	public void logout() {
	}


这样,我们可以通过参数“method”指定不同的参数值从而通过请求("/account.do?method=login"和"/account.do?method=logout")调用不同的方法!
注意:使用多动作控制器必须在配置文件中加入注解支持!

Xml代码 复制代码
  1. <bean  
  2.         class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />  
<bean
		class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />


当然,我们也可以将注解@RequestMapping指定到某一个方法上,如:

Java代码 复制代码
  1. @Controller  
  2. public class AccountController {   
  3.        
  4.     @RequestMapping("/a.do")   
  5.     public void a() {}   
  6.   
  7.     @RequestMapping("/b.do")   
  8.     public void b() {}   
  9. }  
@Controller
public class AccountController {
	
	@RequestMapping("/a.do")
	public void a() {}

	@RequestMapping("/b.do")
	public void b() {}
}


这样,请求“a.do”和“b.do”将对应不同的方法a() 和b()。这使得一个控制器可以同时承载多个请求!
@RequestMapping("/account.do")@RequestMapping(value="/account.do")的简写!
再说输入参数!
这里的方法名可以随意定义,但是参数和返回值却又要求!
为什么?直接看源代码,我们就能找到答案!
AnnotationMethodHandlerAdapter.java部分源代码——有关参数部分:

Java代码 复制代码
  1. @Override  
  2. protected Object resolveStandardArgument(Class parameterType, NativeWebRequest webRequest)   
  3.         throws Exception {   
  4.   
  5.     HttpServletRequest request = (HttpServletRequest) webRequest.getNativeRequest();   
  6.     HttpServletResponse response = (HttpServletResponse) webRequest.getNativeResponse();   
  7.   
  8.     if (ServletRequest.class.isAssignableFrom(parameterType)) {   
  9.         return request;   
  10.     }   
  11.     else if (ServletResponse.class.isAssignableFrom(parameterType)) {   
  12.         this.responseArgumentUsed = true;   
  13.         return response;   
  14.     }   
  15.     else if (HttpSession.class.isAssignableFrom(parameterType)) {   
  16.         return request.getSession();   
  17.     }   
  18.     else if (Principal.class.isAssignableFrom(parameterType)) {   
  19.         return request.getUserPrincipal();   
  20.     }   
  21.     else if (Locale.class.equals(parameterType)) {   
  22.         return RequestContextUtils.getLocale(request);   
  23.     }   
  24.     else if (InputStream.class.isAssignableFrom(parameterType)) {   
  25.         return request.getInputStream();   
  26.     }   
  27.     else if (Reader.class.isAssignableFrom(parameterType)) {   
  28.         return request.getReader();   
  29.     }   
  30.     else if (OutputStream.class.isAssignableFrom(parameterType)) {   
  31.         this.responseArgumentUsed = true;   
  32.         return response.getOutputStream();   
  33.     }   
  34.     else if (Writer.class.isAssignableFrom(parameterType)) {   
  35.         this.responseArgumentUsed = true;   
  36.         return response.getWriter();   
  37.     }   
  38.     return super.resolveStandardArgument(parameterType, webRequest);   
  39. }  
		@Override
		protected Object resolveStandardArgument(Class parameterType, NativeWebRequest webRequest)
				throws Exception {

			HttpServletRequest request = (HttpServletRequest) webRequest.getNativeRequest();
			HttpServletResponse response = (HttpServletResponse) webRequest.getNativeResponse();

			if (ServletRequest.class.isAssignableFrom(parameterType)) {
				return request;
			}
			else if (ServletResponse.class.isAssignableFrom(parameterType)) {
				this.responseArgumentUsed = true;
				return response;
			}
			else if (HttpSession.class.isAssignableFrom(parameterType)) {
				return request.getSession();
			}
			else if (Principal.class.isAssignableFrom(parameterType)) {
				return request.getUserPrincipal();
			}
			else if (Locale.class.equals(parameterType)) {
				return RequestContextUtils.getLocale(request);
			}
			else if (InputStream.class.isAssignableFrom(parameterType)) {
				return request.getInputStream();
			}
			else if (Reader.class.isAssignableFrom(parameterType)) {
				return request.getReader();
			}
			else if (OutputStream.class.isAssignableFrom(parameterType)) {
				this.responseArgumentUsed = true;
				return response.getOutputStream();
			}
			else if (Writer.class.isAssignableFrom(parameterType)) {
				this.responseArgumentUsed = true;
				return response.getWriter();
			}
			return super.resolveStandardArgument(parameterType, webRequest);
		}


也就是说,如果我们想要在自定义的方法中获得一些个“标准”输入参数,参数类型必须包含在以下类型中:

引用

ServletRequest
ServletResponse
HttpSession
Principal
Locale
InputStream
OutputStream
Reader
Writer


当然,上述接口其实都是对于HttpServletRequest和HttpServletResponse的扩展。
此外,我们还可以定义自己的参数。
注意:自定义参数必须是实现类,绝非接口!Spring容器将帮你完成对象初始化工作!
比如说上文中,我们需要参数username和password。我们可以这么写:

Java代码 复制代码
  1. @RequestMapping(method = RequestMethod.GET)   
  2. public void hello(String username,String password) {   
  3.     System.out.println(accountService.verify(username, password));   
  4. }  
	@RequestMapping(method = RequestMethod.GET)
	public void hello(String username,String password) {
		System.out.println(accountService.verify(username, password));
	}


如果参数名不能与这里的变量名保持一致,那么我们可以使用注解@RequestParam进行强制绑定,代码如下所示:

Java代码 复制代码
  1. @RequestMapping(method = RequestMethod.GET)   
  2. public void hello(@RequestParam("username") String u,   
  3.         @RequestParam("password") String p) {   
  4.     System.out.println(accountService.verify(u, p));   
  5. }  
	@RequestMapping(method = RequestMethod.GET)
	public void hello(@RequestParam("username") String u,
			@RequestParam("password") String p) {
		System.out.println(accountService.verify(u, p));
	}


这比起我们之前写的代码有所简洁:

Java代码 复制代码
  1. @RequestMapping(method = RequestMethod.GET)   
  2. public void hello(HttpServletRequest request, HttpServletResponse response)   
  3.         throws Exception {   
  4.   
  5.     String username = ServletRequestUtils.getRequiredStringParameter(   
  6.             request, "username");   
  7.     String password = ServletRequestUtils.getRequiredStringParameter(   
  8.             request, "password");   
  9.     System.out.println(accountService.verify(username, password));   
  10. }  
	@RequestMapping(method = RequestMethod.GET)
	public void hello(HttpServletRequest request, HttpServletResponse response)
			throws Exception {

		String username = ServletRequestUtils.getRequiredStringParameter(
				request, "username");
		String password = ServletRequestUtils.getRequiredStringParameter(
				request, "password");
		System.out.println(accountService.verify(username, password));
	}


ServletRequestUtils类的工作已经由Spring底层实现了,我们只需要把参数名定义一致即可,其内部取参无需关心!
除了传入参数,我们还可以定义即将传出的参数,如加入ModelMap参数:

Java代码 复制代码
  1. @SuppressWarnings("unchecked")   
  2. @RequestMapping(method = RequestMethod.GET)   
  3. public Map hello(String username, String password, ModelMap model) {   
  4.   
  5.     System.out.println(accountService.verify(username, password));   
  6.        
  7.     model.put("msg", username);   
  8.   
  9.     return model;   
  10. }  
	@SuppressWarnings("unchecked")
	@RequestMapping(method = RequestMethod.GET)
	public Map hello(String username, String password, ModelMap model) {

		System.out.println(accountService.verify(username, password));
		
		model.put("msg", username);

		return model;
	}


这时,我们没有定义页面名称,Spring容器将根据请求名指定同名view,即如果是jap页面,则account.do->account.jsp!
不得不承认,这样写起来的确减少了代码量!
接着说输出参数!
通过ModelMap,我们可以绑定输出到的页面的参数,但最终我们将要返回到何种页面呢?再次查看AnnotationMethodHandlerAdapter源代码!
AnnotationMethodHandlerAdapter.java部分源代码——有关返回值部分:

Java代码 复制代码
  1. @SuppressWarnings("unchecked")   
  2. public ModelAndView getModelAndView(Method handlerMethod, Class handlerType, Object returnValue,   
  3.         ExtendedModelMap implicitModel, ServletWebRequest webRequest) {   
  4.   
  5.     if (returnValue instanceof ModelAndView) {   
  6.         ModelAndView mav = (ModelAndView) returnValue;   
  7.         mav.getModelMap().mergeAttributes(implicitModel);   
  8.         return mav;   
  9.     }   
  10.     else if (returnValue instanceof Model) {   
  11.         return new ModelAndView().addAllObjects(implicitModel).addAllObjects(((Model) returnValue).asMap());   
  12.     }   
  13.     else if (returnValue instanceof Map) {   
  14.         return new ModelAndView().addAllObjects(implicitModel).addAllObjects((Map) returnValue);   
  15.     }   
  16.     else if (returnValue instanceof View) {   
  17.         return new ModelAndView((View) returnValue).addAllObjects(implicitModel);   
  18.     }   
  19.     else if (returnValue instanceof String) {   
  20.         return new ModelAndView((String) returnValue).addAllObjects(implicitModel);   
  21.     }   
  22.     else if (returnValue == null) {   
  23.         // Either returned null or was 'void' return.   
  24.         if (this.responseArgumentUsed || webRequest.isNotModified()) {   
  25.             return null;   
  26.         }   
  27.         else {   
  28.             // Assuming view name translation...   
  29.             return new ModelAndView().addAllObjects(implicitModel);   
  30.         }   
  31.     }   
  32.     else if (!BeanUtils.isSimpleProperty(returnValue.getClass())) {   
  33.         // Assume a single model attribute...   
  34.         ModelAttribute attr = AnnotationUtils.findAnnotation(handlerMethod, ModelAttribute.class);   
  35.         String attrName = (attr != null ? attr.value() : "");   
  36.         ModelAndView mav = new ModelAndView().addAllObjects(implicitModel);   
  37.         if ("".equals(attrName)) {   
  38.             Class resolvedType = GenericTypeResolver.resolveReturnType(handlerMethod, handlerType);   
  39.             attrName = Conventions.getVariableNameForReturnType(handlerMethod, resolvedType, returnValue);   
  40.         }   
  41.         return mav.addObject(attrName, returnValue);   
  42.     }   
  43.     else {   
  44.         throw new IllegalArgumentException("Invalid handler method return value: " + returnValue);   
  45.     }   
  46. }   
		@SuppressWarnings("unchecked")
		public ModelAndView getModelAndView(Method handlerMethod, Class handlerType, Object returnValue,
				ExtendedModelMap implicitModel, ServletWebRequest webRequest) {

			if (returnValue instanceof ModelAndView) {
				ModelAndView mav = (ModelAndView) returnValue;
				mav.getModelMap().mergeAttributes(implicitModel);
				return mav;
			}
			else if (returnValue instanceof Model) {
				return new ModelAndView().addAllObjects(implicitModel).addAllObjects(((Model) returnValue).asMap());
			}
			else if (returnValue instanceof Map) {
				return new ModelAndView().addAllObjects(implicitModel).addAllObjects((Map) returnValue);
			}
			else if (returnValue instanceof View) {
				return new ModelAndView((View) returnValue).addAllObjects(implicitModel);
			}
			else if (returnValue instanceof String) {
				return new ModelAndView((String) returnValue).addAllObjects(implicitModel);
			}
			else if (returnValue == null) {
				// Either returned null or was 'void' return.
				if (this.responseArgumentUsed || webRequest.isNotModified()) {
					return null;
				}
				else {
					// Assuming view name translation...
					return new ModelAndView().addAllObjects(implicitModel);
				}
			}
			else if (!BeanUtils.isSimpleProperty(returnValue.getClass())) {
				// Assume a single model attribute...
				ModelAttribute attr = AnnotationUtils.findAnnotation(handlerMethod, ModelAttribute.class);
				String attrName = (attr != null ? attr.value() : "");
				ModelAndView mav = new ModelAndView().addAllObjects(implicitModel);
				if ("".equals(attrName)) {
					Class resolvedType = GenericTypeResolver.resolveReturnType(handlerMethod, handlerType);
					attrName = Conventions.getVariableNameForReturnType(handlerMethod, resolvedType, returnValue);
				}
				return mav.addObject(attrName, returnValue);
			}
			else {
				throw new IllegalArgumentException("Invalid handler method return value: " + returnValue);
			}
		}
	}


返回值的定义十分庞大,或者说可怕的if-else多少有点让我觉得厌恶!
我们可以定义以下类型的返回值:

引用

ModelAndView
Model
View
Map
String
null


ModelAndView、Model和View都是Spring之前版本所特有的元素,Map对应于传入参数ModelMap,String定义页面名称,null即对应void类型方法!
最常用的实现方式如下:

Java代码 复制代码
  1. @SuppressWarnings("unchecked")   
  2. @RequestMapping(method = RequestMethod.GET)   
  3. public String hello(String username, String password, ModelMap model) {   
  4.   
  5.     System.out.println(accountService.verify(username, password));   
  6.   
  7.     model.put("msg", username);   
  8.   
  9.     return "account";   
  10. }  
	@SuppressWarnings("unchecked")
	@RequestMapping(method = RequestMethod.GET)
	public String hello(String username, String password, ModelMap model) {

		System.out.println(accountService.verify(username, password));

		model.put("msg", username);

		return "account";
	}


当然,对于我来说在返回值中写入这么一个字符串多少有点不能接受,于是我还是乐于使用输入参数ModelMap+输出参数Map的方式。
给出一个完整的AccountController实现:
AccountController.java

Java代码 复制代码
  1. /**  
  2.  * 2010-1-23  
  3.  */  
  4. package org.zlex.spring.controller;   
  5.   
  6. import java.util.Map;   
  7.   
  8. import org.springframework.beans.factory.annotation.Autowired;   
  9. import org.springframework.stereotype.Controller;   
  10. import org.springframework.ui.ModelMap;   
  11. import org.springframework.web.bind.annotation.RequestMapping;   
  12. import org.springframework.web.bind.annotation.RequestMethod;   
  13. import org.zlex.spring.service.AccountService;   
  14.   
  15. /**  
  16.  *   
  17.  * @author <a href="mailto:zlex.dongliang@gmail.com">梁栋</a>  
  18.  * @version 1.0  
  19.  * @since 1.0  
  20.  */  
  21. @Controller  
  22. @RequestMapping("/account.do")   
  23. public class AccountController {   
  24.   
  25.     @Autowired  
  26.     private AccountService accountService;   
  27.   
  28.     @SuppressWarnings("unchecked")   
  29.     @RequestMapping(method = RequestMethod.GET)   
  30.     public Map hello(String username, String password, ModelMap model) {   
  31.   
  32.         System.out.println(accountService.verify(username, password));   
  33.   
  34.         model.put("msg", username);   
  35.         return model;   
  36.     }   
  37. }  
/**
 * 2010-1-23
 */
package org.zlex.spring.controller;

import java.util.Map;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.ui.ModelMap;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.zlex.spring.service.AccountService;

/**
 * 
 * @author <a href="mailto:zlex.dongliang@gmail.com">梁栋</a>
 * @version 1.0
 * @since 1.0
 */
@Controller
@RequestMapping("/account.do")
public class AccountController {

	@Autowired
	private AccountService accountService;

	@SuppressWarnings("unchecked")
	@RequestMapping(method = RequestMethod.GET)
	public Map hello(String username, String password, ModelMap model) {

		System.out.println(accountService.verify(username, password));

		model.put("msg", username);
		return model;
	}
}


最后说注解@Session
如果想将某个ModelMap中的参数指定到Session中,可以使用@Session注解,将其绑定为Session熟悉,代码如下所示:

Java代码 复制代码
  1. @Controller  
  2. @RequestMapping("/account.do")   
  3. @SessionAttributes("msg")   
  4. public class AccountController {   
  5.   
  6.     @Autowired  
  7.     private AccountService accountService;   
  8.   
  9.     @SuppressWarnings("unchecked")   
  10.     @RequestMapping(method = RequestMethod.GET)   
  11.     public Map hello(String username, String password, ModelMap model) {   
  12.   
  13.         System.out.println(accountService.verify(username, password));   
  14.   
  15.         model.put("msg", username);   
  16.         return model;   
  17.     }   
  18.   
  19. }  
@Controller
@RequestMapping("/account.do")
@SessionAttributes("msg")
public class AccountController {

	@Autowired
	private AccountService accountService;

	@SuppressWarnings("unchecked")
	@RequestMapping(method = RequestMethod.GET)
	public Map hello(String username, String password, ModelMap model) {

		System.out.println(accountService.verify(username, password));

		model.put("msg", username);
		return model;
	}

}


当然,我们还需要配置一下对应的视图解析器,给出完整配置:
servelt.xml

Xml代码 复制代码
  1. <?xml version="1.0" encoding="UTF-8"?>  
  2. <beans  
  3.     xmlns="http://www.springframework.org/schema/beans"  
  4.     xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.     xmlns:p="http://www.springframework.org/schema/p"  
  6.     xmlns:context="http://www.springframework.org/schema/context"  
  7.     xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd   
  8.         http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">  
  9.     <context:component-scan  
  10.         base-package="org.zlex.spring.controller" />  
  11.     <bean  
  12.         id="urlMapping"  
  13.         class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />  
  14.     <bean  
  15.         class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />  
  16.     <bean  
  17.         id="jstlViewResolver"  
  18.         class="org.springframework.web.servlet.view.InternalResourceViewResolver"  
  19.         p:viewClass="org.springframework.web.servlet.view.JstlView"  
  20.         p:prefix="/WEB-INF/page/"  
  21.         p:suffix=".jsp" />  
  22. </beans>  
<?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:p="http://www.springframework.org/schema/p"
	xmlns:context="http://www.springframework.org/schema/context"
	xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
		http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd">
	<context:component-scan
		base-package="org.zlex.spring.controller" />
	<bean
		id="urlMapping"
		class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping" />
	<bean
		class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter" />
	<bean
		id="jstlViewResolver"
		class="org.springframework.web.servlet.view.InternalResourceViewResolver"
		p:viewClass="org.springframework.web.servlet.view.JstlView"
		p:prefix="/WEB-INF/page/"
		p:suffix=".jsp" />
</beans>


这里使用了JstlView作为视图解析器。同时,指定前缀路径为"/WEB-INF/page/",后缀路径为".jsp"。也就是说,Spring容器将会在这个路径中寻找匹配的jsp文件!
注意加入xmlns:p="http://www.springframework.org/schema/p"命名空间!
再给出页面内容:
taglib.jsp

Jsp代码 复制代码
  1. <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>   
  2. <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>   
  3. <%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql"%>   
  4. <%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml"%>   
  5. <%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions"%>   
  6. <%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>   
  7. <%@ taglib prefix="form" uri="http://www.springframework.org/tags/form"%>  
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
<%@ taglib prefix="sql" uri="http://java.sun.com/jsp/jstl/sql"%>
<%@ taglib prefix="x" uri="http://java.sun.com/jsp/jstl/xml"%>
<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions"%>
<%@ taglib prefix="spring" uri="http://www.springframework.org/tags"%>
<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form"%>


account.jap

Jsp代码 复制代码
  1. <%@ page language="java" contentType="text/html; charset=UTF-8"  
  2.     pageEncoding="UTF-8"<spa
    分享到:
    评论
    3 楼 liutao1600 2013-05-07  
    学习了,太好了
    2 楼 tamsiuloong 2010-06-28  
    UTF
    tamsiuloong 写道
    楼主你好,我是基于下面配置的urlMpping
    <bean id="urlMapping"
    class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">

    <property name="mappings">
    <props>
    <prop key="site/site.do">siteAction</prop>
    </bean>
    如果我也想使用基于注解的控制器,我应该怎样做?

    同时使用二者,可以吗?
    1 楼 tamsiuloong 2010-06-28  
    楼主你好,我是基于下面配置的urlMpping
    <bean id="urlMapping"
    class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">

    <property name="mappings">
    <props>
    <prop key="site/site.do">siteAction</prop>
    </bean>
    如果我也想使用基于注解的控制器,我应该怎样做?

相关推荐

    spring_mvc源码

    用的是spring mvc作为控制层,控制层和model采用注解,持久层采用的是hibernate3+spring整合框架,做的一个简单的用户管理源码,数据库采用的是sqlserver,sql源码在里面,采用的是hql语句,如果要改数据库,只用改model和...

    Spring注解大全_spring应用层_spring注解大全_控制层注解_

    应用在MVC层(控制层)DispatcherServlet会自动扫描注解了此注解的类,然后将web请求映射到注解了RequestMapping的方法上。Service 组合注解(组合了@Component注解),应用在service层(业务逻辑层)

    SpringMVC框架架构介绍

    一、前言 二、spring mvc 核心类与接口 三、spring mvc 核心...十八、spring mvc 多视图控制器 十九、 &lt;mvc:annotation-driven /&gt; 到底做了什么工作 二十、 本文中springMVC.xml配置文件是核心,这里给一个下载地址

    深入解析Spring+MVC与Web+Flow.pdf

    后者是控制业务处理流程的有效解决方案,提供了一种编写有状态和基于会话的Web应用程序的简便手段。 《深入解析Spring MVCgn Web Flow》出自Spring核心开发者之手,不仅详细分析代码,全面剖析了两个框架的各种特性...

    Spring构建mvc工程详细教程.pdf

    文档内容包括springMVC的请求过程,springMVC工程的配置文件示例,如何写控制器,视图解析的分析等内容。

    Spring + Spring MVC +Mybatis.zip

    Struts2框架与Spring的整合问题日益凸显,而Spring MVC作为新一代的MVC框架,因其可以与Spring框架无缝整合的特性收到了越来越多的欢迎。Hibernate框架在面对需要存储过程或者复杂SQL时显得力不从心,不能提供高效的...

    Spring+MVC+Mybatis 书城项目

    Spring MVC: Spring MVC是Spring框架的一个模块,它实现了MVC(模型-视图-控制器)设计模式,用于构建Web应用。Spring MVC允许你将应用的逻辑、数据和用户界面分离,使得代码更加清晰和易于维护。 MyBatis: MyBatis...

    21道Java Spring MVC综合面试题详解含答案(值得珍藏)

    Spring MVC是Spring框架中的一部分,全称是Spring Web MVC,主要用于实现MVC设计模式的Web框架。它分离了控制器、模型对象、过滤器以及处理程序对象的角色,使得它们更容易进行定制。 Spring MVC的优点包括: 基于...

    Spring Boot + MVC 之service和持久化层的实现

    通过Idea创建Spring Boot java项目 基于Spring Boot + MVC 之控制器Controller实现 基于Spring Boot + MVC 之service和持久化层的实现 基于Spring Boot + JPA实现MVC三层框架

    springmvc demo

    即使用了MVC架构模式的思想,将web层进行职责解耦,基于请求驱动指的就是使用请求-响应模型,框架的目的就是帮助我们简化开发,Spring Web MVC也是要简化我们日常Web开发的。 Spring Web MVC也是服务到工作者模式的...

    Spring MVC MyBatis

    该案例采用目流行、规范的Java EE架构,整个应用分为DAO持久层、领域对象层、业务逻辑层、控制器层和视图层,各层之间分层清晰,层与层之间以松耦合的方法组织在一起。所有代码完全基于Eclipse IDE来完成,一步步...

    spring.net依赖注入Demo

    spring.net是为.net开发者提供的一个控制反转操作框架也称作依赖注入。 此demo仅提供参考spring.net mvc+三层

    基于Spring + Spring MVC + Mybatis

    快速搭建项目原型,基于Spring + Spring MVC + Mybatis,简单轻便、易于扩展的架构,适用于大多数项目 封装了常用的CURD,配合mybatis-generator 自动生成dao、model、mapper层,减少重复劳动,提高生产力,实现快速...

    Spring 3.0MVC JDBC 单表操作示例.rar

    利用 注解 的形式定义 控制层 服务层 和持久层 采用MYSQL5.0数据库 自己建2张表 student 和teacher 字段 看实体类中的属性。 DAO 层采用2种方法连接proxool连接池。一种是 Spring 封装的JDBC和 操作 (teacher...

    使用Spring MVC和JSP构建的全栈RSS阅读器Web应用程序(95分以上课程大作业).zip

    它采用MVC(Model-View-Controller,模型-视图-控制器)的架构模式,将应用程序分为模型层、视图层和控制器层,提供了处理请求、渲染视图和管理流程的功能。 3. MyBatis框架:MyBatis是一个持久层框架,用于与数据库...

    spring mvc中文教程

    本文将指导大家如何使用Spring MVC3去构建一个Web应用。在Spring MVC中,所有的用户请求都会被派发到控制器模块,控制器然后再根据业务逻辑去调用数据访问层获得数据,最后通过JSP视图返回。

    Spring MVC简单使用

    本文将指导大家如何使用Spring MVC3去构建一个Web应用。在Spring MVC中,所有的用户请求都会被派发到控制器模块,控制器然后再根据业务逻辑去调用数据访问层获得数据,最后通过JSP视图返回。

    test-mvc:使用 Spring MVC 测试框架进行测试

    使用 MockMvc、Mockito 和 DbUnit 进行单元和集成测试灵感Spring MVC 测试教程 - Spring MVC 中的异常处理 - 下一步如果您对测试生成 HTML 的控制器感兴趣,您可以查看 Spring MVC 测试教程( )并了解如何测试由...

    基于SpringCloud开发的在线教育系统

    控制层:Spring MVC、FastJSON、RestTemplate、Spring Security Oauth2+JWT等 微服务治理:Eureka、Zuul、Hystrix、Spring Cloud Config等 1、站点管理 2 媒资管理微服务 媒资查询:教学机构查询自己所拥有的媒体...

    基于Spring的MVC框架设计与实现

    为构建高效、灵活且易于使用的模型-视图-控制器(MVC)模式实现机制,提出一种基于Spring框架的MVC框架。该框架使用JSP 技术构建视图层,采用总体控制与局部控制相结合的方法增强控制层的功能,采用O/R Mapping类完成...

Global site tag (gtag.js) - Google Analytics