标签:
1、新建Maven项目,选择webapp,如下图,点击next,输入GroupId和ArtifactId(即项目名称)后点击Finish。
2、此时项目会报错,如下:
右击项目,点击最下面的Properties,更给其中左侧的Java Build Path中的JRE System Library为安装的JRE,同时更改Java Compile,还需要更改Project Facets中的java版本。如果需要也可以更改Dynamic Web Module的版本,不过这个需要到项目所在的路径下的.settings文件夹中的org.eclipse.wst.common.project.facet.core.xml中进行修改,修改后重启eclipse即可。
此时项目还有错,通过提示信息可知是由于找不到HttpServlet类,可通过导入Tomcat到工作目录或者通过Maven添加HttpServlet类所在的servlet-api.jar。
3、现在通过maven添加SpringMVC所需jar包,点击pom.xml中的Add按钮,在中间输入框中输入spring-webmvc:
Maven会自动导入spring-webmvc依赖的其他jar包,可通过点击pom.xml下方的Dependency Hierarchy标签查看依赖关系和有效的jar包:
4、修改web.xml(此时需注意,如果之前修改了Dynamic Web Module的版本,则需要修改web.xml头部为对应的版本),添加Servlet(此处使用的是3.0版本的web.xml):
<?xml version="1.0" encoding="UTF-8"?> <web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"> <servlet> <servlet-name>spring</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> </servlet> <servlet-mapping> <servlet-name>spring</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app>
<servlet-name>属性随意,只要上下一致即可,url-pattern中的"/"为拦截所有请求。
5、如上配置会自动去WEB-INF下寻找‘servlet-name‘-servlet.xml(此处对应为spring-servlet.xml),具体内容如下:
<?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:tx="http://www.springframework.org/schema/tx" xmlns:mvc="http://www.springframework.org/schema/mvc" 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 http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 配置扫描的包 --> <context:component-scan base-package="com.springdemo.*" /> <!-- 注册HandlerMapper、HandlerAdapter两个映射类 --> <mvc:annotation-driven /> <!-- 访问静态资源 --> <mvc:default-servlet-handler /> <!-- 视图解析器 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/view/"></property> <property name="suffix" value=".jsp"></property> </bean> </beans>
此配置会自动扫描com.springdemo下的所有包中的含有注解的类(如@Controller, @Service等);<mvc:annotation-driven />会注册两个映射类,负责将请求映射到类和方法中;因为配置的spring是拦截所有请求,所以需要配置<mvc:default-servlet-handler />,来让静态资源通过(如js, css文件等);视图解析器是将Controller类返回的视图名加上配置的前后缀进行展示。
在WEB-INF下创建view文件夹,并在其中创建jsp页面:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!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=UTF-8">
<title>首页</title>
</head>
<body>
<h1>This is SpringMVC Demo</h1>
</body>
</html>
创建com.springdemo.controller包(包路径需被配置的扫描路径能扫描到),在其中创建controller类,并加上注解:
package com.springdemo.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; @Controller public class DemoController { @RequestMapping("/index") public String index(){ return "demo"; } }
当请求index时会映射到此方法中,返回的字符串 demo会被配置拼接为 WEB-INF/view/demo.jsp,并展示出来。
6、在tomcat中部署运行,访问http://localhost:8080/SpringDemo/,则可见如下界面,说明配置成功。
代码见:https://github.com/zavier/SpringMVC-Demo
具体使用可见官方文档:http://docs.spring.io/spring/docs/current/spring-framework-reference/htmlsingle/
标签:
原文地址:http://www.cnblogs.com/zawier/p/5605040.html