[Java,MVC] Eclipse下搭建Spring MVC

转自:http://blog.csdn.net/blue_jjw/article/details/8752466

一、新建Dynamic Web Project

一个web工程最基本的,只看3个地方,在根目录下(这个目录一般习惯叫WebContent或WebRoot)有 :

1.WebRoot/WEB-INF/web.xml  启动引导文件

2.WebRoot/WEB-INF/classes/  编译的class文件,会根据package建立子路径 

3.WebRoot/WEB-INF/lib/      jar包 (注意,lib下不可以再建子目录)

这就是一般比较常用的web工程的结构. 有了这三个结构,
然后把WebRoot的绝对路径告诉tomcat这样的web容器,就可以启动了(当然里面要有相应的东西才行)。
因此虽然我们一般项目的结构是:
projectname/src, projectname/WebRoot
但实际上src里的.java源代码是tomcat完全不关心的,它的解析是从WebRoot开始的, .class才是它认识的.

参考:搭建简单web项目:
spring3.0基础配置(1)

二、添加Spring的依赖包

其中commons-logging-1.1.1.jar是spring日志依赖jar包,jstl-api-1.2.jar与jstl-impl-1.2.jar是Oracle官方的JSTL接口与实现,如果选Apche的也可以。

在打war包时,将这些依赖包拷贝到WebContent/WEB-INF/lib下:

三、配置web.xml

WebContent/WEB-INF/web.xml:


<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
<display-name>ContentManagementSystem</display-name>
<!-- 添加spring3控制器, DispatcherServletDispatcherServlet是Spring MVC 的入口
所有进入Spring Web的 Request都经过 DispatcherServlet
-->
<servlet>
<servlet-name>LoadBalanceAlg</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<!-- 配置spring3的映射规则 -->
<servlet-mapping>
<servlet-name>LoadBalanceAlg</servlet-name>
<url-pattern>*.htm</url-pattern>
</servlet-mapping>
<!-- 配置log4j -->
<!-- spring log4j configuration -->
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>LBAProject</param-value>
</context-param>
<!-- 由Spring加载的log4j配置文件的位置 -->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.conf</param-value>
</context-param>
<!-- Spring刷新log4j配置文件的间隔,单位为millisecond -->
<context-param>
<param-name>log4jRefreshIntercal</param-name>
<param-value>60000</param-value>
</context-param>
<!-- Web项目Spring加载log4j的监听 -->
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>
<!-- 默认跳转到根目录下的页面 -->
<welcome-file-list>
<welcome-file>index.htm</welcome-file>
</welcome-file-list>
<!-- session timeout setup, 10 mins -->
<session-config>
<session-timeout>10</session-timeout>
</session-config>
</web-app>

加载DispatcherServlet时Spring会尝试读取配置文件,默认的配置文件位于web.xml相同的路径下,文件名与注册的Servlet名有关:Servlet注册名跟上"-servlet.xml"。 

例如:上面的Servlet注册名为 LoadBalanceAlg,那么默认的配置文件名为:LoadBalanceAlg-servlet.xml。

当然 也可以明确配置文件,需要在注册servlet时设定初始化参数 :

<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>
<!-- 配置文件名 -->
</param-value>
</init-param>

参考:Spring
mvc的配置

四、Spring配置文件

文件名需与web.xml中的<servlet-name></servlet-name>中的名字一致


<?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-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd"
>

<!-- 开启spring MVC注解功能,完成请求和注解POJO的映射 -->
<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping"/>
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>
<!-- 默认扫描的包路径 -->
<context:component-scan base-package="cn.ac.dsp.controller"/>
<context:component-scan base-package="cn.ac.dsp.service"/>

<!-- 模型视图名称的解析,即模型前后添加前后缀 -->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="viewClass"><value>org.springframework.web.servlet.view.JstlView</value></property>
<property name="prefix"><value>/WEB-INF/jsp/</value></property>
<property name="suffix"><value>.jsp</value></property>
</bean>
</beans>

五、log4j的配置

第一步:导入jar包

第二步:在web.xml中的配置:


<!-- 配置log4j -->
<!-- spring log4j configuration -->
<context-param>
<param-name>webAppRootKey</param-name>
<param-value>LBAProject</param-value>
</context-param>
<!-- 由Spring加载的log4j配置文件的位置 -->
<context-param>
<param-name>log4jConfigLocation</param-name>
<param-value>/WEB-INF/classes/log4j.conf</param-value>
</context-param>
<!-- Spring刷新log4j配置文件的间隔,单位为millisecond -->
<context-param>
<param-name>log4jRefreshIntercal</param-name>
<param-value>60000</param-value>
</context-param>
<!-- Web项目Spring加载log4j的监听 -->
<listener>
<listener-class>org.springframework.web.util.Log4jConfigListener</listener-class>
</listener>

其中webAppRootKey表示Web项目根目录的绝对路径,如果不配置webAppRootKey参数,则webAppRootKey
就是缺省的"webapp.root",最好设置,以免项目之间的名称冲突。然后,log4j配置文件中就可以用${LBAProject}表示Web项目目录的绝对路径,如果不设置webAppRootKey,可用${webapp.root}表示Web项目目录的绝对路径。

注意:

1、log4j的配置文件的文件名不能为"log4j.properties",而要改为别的名字,要不然报异常:
log4j:ERROR
setFile(null,true) call failed. 
java.io.FileNotFoundException:
\WEB-INF\log\abc.log (系统找不到指定的路径。)

原因是log4j.properties与tomcat的log4j重名,改个名字就好了.因为在tomcat启动是默认去找log4j.properties,但此时Listener还没有起来,tomcat就要往\WEB-INF\log\abc.log
写日志就找不到了.

2、${webapp.root}表示工程目录,可以把它加入到log4j配置文件中输入路径的前面,如:

log4j.appender.appender_demo.File = ${webapp.root}/WEB-INF/log/abc.log

3.该配置文件一定要放在src目录下,使其自动生成到/WEB-INF/classes/目录下.否则,spring报异常:
log4j:WARN
No appenders could be found for logger (...).
log4j:WARN Please initialize
the log4j system properly.

第三步:在src下创建配置文件log4j.conf
log4j.conf:


log4j.rootLogger = INFO, stdout, A1, A2

##log message to console
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss.SSS} %5p [%t] %c:%l - %m%n

##log message to file
log4j.appender.A1.Threshold = INFO
log4j.appender.A1 = org.apache.log4j.DailyRollingFileAppender
log4j.appender.A1.File = ${LBAProject}/WEB-INF/log/LBA-info.log
log4j.appender.A1.DatePattern = ‘-‘yyyy-MM-dd‘.log‘
log4j.appender.A1.layout = org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss.SSS} %5p [%t] %c:%l - %m%n

##log warn/error to file
log4j.appender.A2.Threshold = WARN
log4j.appender.A2 = org.apache.log4j.DailyRollingFileAppender
log4j.appender.A2.File = ${LBAProject}/WEB-INF/log/LBA-error.log
log4j.appender.A2.DatePattern = ‘-‘yyyy-MM-dd‘.log‘
log4j.appender.A2.layout = org.apache.log4j.PatternLayout
log4j.appender.A2.layout.ConversionPattern = %d{yyyy-MM-dd HH:mm:ss,SSS} %5p [%t] %c:%l - %m%n

参考:log4j注意的问题

Spring中配置log4j问题

搭建简单web项目:spring3.0基本配置(2)

在Spring的项目中配置Log4j存放日志文件到指定目录下

六、前后台代码

首先,在WEB-INF/jsp下新建一个jsp包,与上文中prefix的值相对应(LoadBalanceAlg-servlet.xml中配置了视图解析模块


<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!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=ISO-8859-1">
<title>DB Operation</title>
</head>
<body>
DB Operation Success!
</body>
</html>

在src下编写后台代码(在LoadBalanceAlg-servlet.xml配置的包中),如DBOperation.java:


package cn.ac.dsp.controller;

import java.util.List;

import org.apache.log4j.Logger;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import cn.ac.dsp.dao.ResourceDAO;
import cn.ac.dsp.entity.ResourceEntity;

@Controller
public class DBOperation {

private final static Logger log = Logger.getLogger(DBOperation.class);

@RequestMapping("/dbOperation.htm")
public String start(){
log.info("request for dbOperation");
List<ResourceEntity> resDAOList = ResourceDAO.getInstance().selectAll();
for(ResourceEntity re : resDAOList){
System.out.println(re.hashCode());
}
return "dbOperation";
}
/**
* @param args
*/
public static void main(String[] args) {
DBOperation d = new DBOperation();
d.start();
}
}

七、测试

将Eclipse中的项目打成war包(注意要将依赖包拷贝到WEB-INF/lib下),放到tomcat的webapps下,启动tomcat。

浏览器中打开页面如下:


参考:spring3
mvc系列一:架构基本配置(注解版)

时间: 2025-01-21 21:10:51

[Java,MVC] Eclipse下搭建Spring MVC的相关文章

Windows Eclipse下为Spring MVC 添加Tomcat环境配置

1. 假设已经安装好Eclipse+Tomcat: 检查Tomcat服务器的状态,如果服务器已经启动,停止服务器,否则在Eclipse中运行项目会提示端口已经被占用: 2. 在Eclipse中添加Server Runtime: Eclipse->Windows->Preferences->Runtime Enviornment->Add 选择你安装的Tomcat版本并且选择Tomcat的安装目录: 3. 为你的project添加Tomcat Library: 你的Project右键

快速搭建Spring MVC 4开发环境

Spring MVC作为SpringFrameWork的产品,自诞生之日,就受到广泛开发者的关注,如今Spring MVC在Java中的发展可谓是蒸蒸日上,如今如果再有开发者说,不了解Spring MVC,或许就被人笑掉大牙.煽情的话就不说了,先告诉大家如何搭建Spring MVC开发环境. (一)工作环境准备: JDK 1.7 Eclipse Kepler Apache Tomcat 8.0 (二)在Eclipse中新建Maven工程,在Archetype类型中,选择"maven-archet

搭建Spring MVC 4开发环境八步走

Spring MVC作为SpringFrameWork的产品,自诞生之日,就受到广泛开发者的关注,如今Spring MVC在Java中的发展可谓是蒸蒸日上,如今如果再有开发者说,不了解Spring MVC,或许就被人笑掉大牙.煽情的话就不说了,先告诉大家如何搭建Spring MVC开发环境. (一)工作环境准备: JDK 1.7 Eclipse Kepler Apache Tomcat 8.0 (二)在Eclipse中新建Maven工程,在Archetype类型中,选择"maven-archet

零基础搭建 spring mvc 4 项目(本文基于 Servlet 3.0)

作者各必备工具的版本如下: Tomcat:apache-tomcat-7.0.63 (下载链接) Java EE - Eclipse:Luna Service Release 1 v4.4.1 (下载链接) Spring:4.2.0.RELEASE (无须下载) JDK:1.7.0_67 (下载链接) 步骤 1 使用 Java EE - Eclipse 新建一 Dynamic Web Project. 步骤 2 输入项目名 bdp.Target Runtime 选 Apache Tomcat 7

搭建 Spring MVC 框架

如果创建一个 Spring 项目 Spring MVC 框架在 Java 的 Web 项目中应该是无人不知的吧,你不会搭建一个 Spring 框架?作为身为一个刚刚学习Java的我都会,如果你不会的话,那可真令人忧伤. 1.在 MyEclipse 创建项目后,可以以选择的方式去配置一个 Spring 项目,这里不在讨论.因为我只用 Eclipse. 2.手动搭建.就是动手. 新建一个 Java Web 项目 1.打开 Eclipse ,在Project Explorer选项卡下面点击右键,选择W

Eeclipse集成Maven搭建Spring MVC

一.下载Maven 1.下载地址:https://maven.apache.org/ 2.将下载的zip包解压到指定目录下,如:E:\Tools\apache-maven-3.3.3 3.配置maven环境变量,新增环境变量 M2_HOME:E:\Tools\apache-maven-3.3.3,然后在环境变量的值后新增%M2_HOME%\bin 4.win+R,输入cmd启动dos命令行,输入mvn -version,出现如下图,即安装完成. 二.Eclipse集成Maven 1.如果你下载了

Spring MVC篇一、搭建Spring MVC框架

本项目旨在搭建一个简单的Spring MVC框架,了解Spring MVC的基础配置等内容. 一.项目结构 本项目使用idea intellij创建,配合maven管理.整体的目录结构如图: 其中java文件夹是sources文件夹,resources是资源文件夹.spring文件夹里是Spring上下文配置和Spring MVC配置文件. 需要注意的是,项目自动生成以后会有两个web文件目录,一个是web文件夹(我这里已经删除了),另一个是默认的webapp文件夹.我这里使用默认的目录,也就是

MAC OS X El CAPITAN 搭建SPRING MVC (1)- 目录、包名、创建web.xml

一. 下载STS(Spring Tool Suite) 官方地址:http://spring.io/tools/sts 下载spring tool suite for mac 最新版本.这个IDE是很不错的,其中spring插件已经配置好了.下载解压缩(一定要英文目录下),直接运行STS.app. 二.搭建spring mvc 结构目录 1.选择new - dynamic web project project name (键入项目名称 同样必须英文) Dynamic web module ve

Java-Spring MVC:JAVA之常用的一些Spring MVC的路由写法以及参数传递方式

ylbtech-Java-Spring MVC:JAVA之常用的一些Spring MVC的路由写法以及参数传递方式 1.返回顶部 1. 常用的一些Spring MVC的路由写法以及参数传递方式. 这是一些测试代码: package com.my.controller; import java.io.PrintWriter; import java.util.Date; import javax.servlet.http.HttpServletRequest; import javax.servl