最基本的springMVC注解配置详解
Spring MVC是当前最优秀的MVC框架,⾃从Spring 2.5版本发布后,由于⽀持注解配置,易⽤性有了⼤幅度的提⾼。上⼀篇博⽂已经介
绍了最简单的配置⽂件的详情,这⾥再介绍⼀下最简单的注解配置详情,毕竟springMVC是⿎励使⽤注解的。
1、导⼊jar包
注解主要在spring-webmvc-3.2.8.RELEASE.jar中
2、l配置⽂件
注:这⾥采⽤l默认命名⽅式,并且⽂件位于/WEB-INF⽬录下,所以在l中不需要配置<init-param></init-param>
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="/2001/XMLSchema-instance" xmlns="java.sun/xml/ns/javaee" xsi:schemaLocation="java.sun/xml/ns/j <display-name>spring_mvc_annotation</display-name>
<!-- springMVC的前端控制器 -->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
3、l配置⽂件
注意:表头这⾥添加mvc声明,声明的地址在 spring-webmvc-3.2.8.RELEASE.jar 中的 META-INF/spring.schemas 中。这样以后
<mvc:xxx>标签才会有效
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="/schema/beans"
xmlns:xsi="/2001/XMLSchema-instance"
xmlns:mvc="/schema/mvc" <!-- 注意添加mvc声明 -->
xmlns:aop="/schema/aop"
xmlns:tx="/schema/tx"
xmlns:context="/schema/context"
xsi:schemaLocation="
/schema/beans
/schema/beans/spring-beans-3.0.xsd
/schema/aop
/schema/aop/spring-aop-3.0.xsd
/schema/tx
/schema/tx/spring-tx-3.0.xsd
/schema/mvc <!-- 注意添加mvc声明 -->
/schema/mvc/spring-mvc-3.0.xsd <!-- 注意添加mvc声明,注意版本,不写版本会有默认版本 -->
/schema/context
/schema/context/spring-context-3.0.xsd">
<mvc:annotation-driven/>
<context:component-scan base-package="ller"></context:component-scan>
<!-- 配置视图解析器如何把handler ⽅法返回值解析为实际的物理视图根据控制器返回的字符串拼接成jsp路径:/WEB-INF/page/xx.jsp -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/page/"/><!-- 前缀 -->
<property name="suffix" value=".jsp"/><!-- 后缀 -->
</bean>springmvc常用标签
</beans>
4、控制层(controller层)
注意:这⾥的login.jsp已经放⼊/WEB-INF/page⽬录下,为了⽅便视图解析器处理:是进⼊index.jsp页⾯还是返回login.jsp登录页⾯。这
时初次进⼊login.jsp就需要利⽤toLogin()⽅法了。
package ller;
import javax.servlet.http.HttpSession;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
@Controller //在类上⾯定义,表明该类为控制器,返回字符串与redirect:xxx
@RequestMapping(value="/") //在类或⽅法上⾯使⽤此注解,设置URL访问地址。它有两个属性,value指定访问路径,method指定指定请求⽅式,请求⽅式在Reque public class LoginController {
@RequestMapping(value="/login",method=RequestMethod.GET) //访问.../login,⽅式为get时,该⽅法处理请求
public String toLogin(){
return "login";
}
@RequestMapping(value="/login",method=RequestMethod.POST)
public String doLogin(String username , String password , Model model , HttpSession session){ //
访问.../login,⽅式为post时,该⽅法处理请求
if("admin".equals(username)&&"123".equals(password)){
session.setAttribute("username", username);
model.addAttribute("message", "登录成功!");
return "index";
}else{
model.addAttribute("message", "登录失败!");
return "login";
}
}
}
5、jsp页⾯
login.jsp页⾯代码
<?xml version="1.0" encoding="UTF-8" ?>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html >
<html xmlns="/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <title>Insert title here</title>
</head>
<body>
<form action="/spring_mvc_annotation/login" method="post">
⽤户名:<input type="text" name="username" value=""/><br />
密码:<input type="password" name="password" value=""/><br />
<input type="submit" value="登录"/>
</form>
<div >${message }</div>
</body>
</html>
index.jsp页⾯代码
<?xml version="1.0" encoding="UTF-8" ?>
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html xmlns="/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" /> <title>Insert title here</title>
</head>
<body>
<h1>${sessionScope.username },${message }</h1>
</body>
</html>
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论