`
lzhted
  • 浏览: 16658 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

【Java Web学习笔记】02-创建基于SpringMVC的web工程

阅读更多

参见 “学习笔记01 - 下载jar(http://teds.iteye.com/blog/2273819)”,准备好需要的jar,开始创建一个Web工程供学习使用。

 

创建web工程

这里使用的IDE是sts-3.6.4.RELEASE(Spring Tool Suite)。选择创建一个Dynamic Web Project。学习使用的服务器软件版本Tomcat 7,对应支持最高dynamic web module version是3.0。勾选创建web.xml。

 

引入基本jar

将下载的jar拷贝到web工程的目录“WebContent\WEB-INF\lib”中,工程会自动识别到其中的jar,但是子目录中的jar无法识别。

现在可以只拷贝Spring、SpringMVC、log4j2、Apache Commons的jar。

 

配置SpringMVC

在{project}/WebContent/WEB-INF/web.xml中配置springmvc。

更多的关于SpringMVC的介绍和配置信息可以上网搜索,也可以参考“跟开涛学SpringMVC”。

	<servlet>
		<servlet-name>springMVC</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath:spring-context.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>springMVC</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>

 简要描述下面的配置,定义DispatcherServlet,其职责主要是调度工作,解析和控制流程。<init-param>中定义了spring配置文件的路径,这里的路径对应工程路径{project}/{source folder}/spring-context.xml,对应部署包路径{app}/WEB-INF/classes/spring-context.xml。可以不配置此信息,默认的文件在WEB-INF/{servlet名}-servlet.xml。

下面是spring-context.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: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-4.2.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc-4.2.xsd">

	<context:component-scan base-package="com.lz.quick.web.controller"></context:component-scan>

	<mvc:annotation-driven></mvc:annotation-driven>

	<bean id="viewResolver"
		class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/views/" />
		<property name="suffix" value=".jsp" />
	</bean>
</beans>
 <context:component-scan>元素对包进行扫描,实现注解定义Bean,将bean自动注入容器中使用。即解决了@Controller标识的控制器Bean的注入和使用。base-package属性定义了扫描包的范围。
<mvc:annotation-driven>元素自动注册了RequestMappingHandlerMapping、RequestMappingHandlerAdapter、ExceptionHandlerExceptionResolver等,支持控制器中处理请求时使用@RequestMapping、@ExceptionHandler等注解。实现代码参见源码:org.springframework.web.servlet.config.AnnotationDrivenBeanDefinitionParser。
viewResolver视图解析器,如果返回了一个叫“home”的视图,视图解析器就会将请求转发到RequestDispatcher,然后跳转到/WEB-INF/views/home.jsp页面。
 

开发一个控制器和页面

开发一个jsp页面WEB-INF\views\home.jsp,打印一条从控制器设置的信息。

<%@ page language="java" contentType="text/html; charset=UTF-8"
	pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">

<title>Home</title>
</head>
<body>
<br/>${message}
</body>
</html>

 

通过注解@Controller开发一个控制器,将url请求home.pg指向开发的home.jsp,并添加一条信息到请求。

@Controller
public class HomeController {
	@RequestMapping("/home.pg")
	public String home(HttpServletRequest request) {
		request.setAttribute("message", "welcome!");
		return "home";
	}
}

 

部署web项目到Tomcat,启动后访问路径:http://localhost:8080/{工程名称}/home.pg就可以访问到home.jsp,页面打印一句话“welcome!”。在前面的spring配置文件spring-context.xml中添加一个元素:

<mvc:view-controller path="/" view-name="redirect:/home.pg" />

 则直接访问网址根目录时(http://localhost:8080/{工程名称})也会自动重定向到home.pg。

 

这样一个最简单的基于Spring MVC的web工程就创建出来了。后面在这个工程基础上添加更多的特性和功能。

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics