第一章:Eclipse用Maven搭建SSM框架并部署到Tomcat7

来源:互联网 发布:c语言写个三角形 编辑:程序博客网 时间:2024/06/05 08:35

**一 创建项目
创建SSM项目–>选择Maven Project,然后Next **

这里写图片描述

2设置项目路径,然后Next

这里写图片描述

3选择项目类型 选择Artifact Id为maven-archetype-webapp,然后Next

这里写图片描述

4设置名称,然后Finish

这里写图片描述

5完成后项目结构,此处报错正常,因为没有导入包

这里写图片描述

6项目结构并不完整,完整就忽略,右键项目->Source Folder创建目录

src/main/resourcessrc/main/javasrc/test/resourcessrc/test/java

**若无法创建目录,是因为目录路径存在,只需要在对应目录下右键->Folder创建相应目录就可以

7. 完成后结构如下 **

这里写图片描述

8. 简单的创建几个包,可根据实际和个人爱好创建

src/main/java 目录下如下图

这里写图片描述

9. 在src/mian/webapp/WEB-INF下创建 jsps 目录,如下图

这里写图片描述

二 导入包,并配置pom.xml

先引入以下几种核心包:

 spring核心包   mybatis核心包   spring-mybatis整合包   MySQL连接包    jstl标签类   日志包   json解析包

pom.xml文件如下

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">    <modelVersion>4.0.0</modelVersion>    <groupId>com.demo</groupId>    <artifactId>test</artifactId>    <packaging>war</packaging>    <version>0.0.1-SNAPSHOT</version>    <name>test Maven Webapp</name>    <url>http://maven.apache.org</url>     <properties>            <!-- spring版本号 -->            <spring.version>4.0.2.RELEASE</spring.version>            <!-- mybatis版本号 -->            <mybatis.version>3.2.6</mybatis.version>            <!-- log4j日志文件管理包版本 -->            <slf4j.version>1.7.7</slf4j.version>            <log4j.version>1.2.17</log4j.version>        </properties>    <dependencies>        <dependency>            <groupId>junit</groupId>            <artifactId>junit</artifactId>            <version>3.8.1</version>            <scope>test</scope>        </dependency>        <!-- spring核心包 -->        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-core</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-web</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-oxm</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-tx</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-jdbc</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-webmvc</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-aop</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-context-support</artifactId>            <version>${spring.version}</version>        </dependency>        <dependency>            <groupId>org.springframework</groupId>            <artifactId>spring-test</artifactId>            <version>${spring.version}</version>        </dependency>        <!-- mybatis核心包 -->        <dependency>            <groupId>org.mybatis</groupId>            <artifactId>mybatis</artifactId>            <version>${mybatis.version}</version>        </dependency>        <!-- mybatis/spring包 -->        <dependency>            <groupId>org.mybatis</groupId>            <artifactId>mybatis-spring</artifactId>            <version>1.2.2</version>        </dependency>        <!-- 导入java ee jar 包 -->        <dependency>            <groupId>javax</groupId>            <artifactId>javaee-api</artifactId>            <version>7.0</version>        </dependency>        <!-- 导入Mysql数据库链接jar包 -->        <dependency>            <groupId>mysql</groupId>            <artifactId>mysql-connector-java</artifactId>            <version>5.1.30</version>        </dependency>        <!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 -->        <dependency>            <groupId>commons-dbcp</groupId>            <artifactId>commons-dbcp</artifactId>            <version>1.2.2</version>        </dependency>        <!-- JSTL标签类 -->        <dependency>            <groupId>jstl</groupId>            <artifactId>jstl</artifactId>            <version>1.2</version>        </dependency>        <!-- 日志文件管理包 -->        <!-- log start -->        <dependency>            <groupId>log4j</groupId>            <artifactId>log4j</artifactId>            <version>${log4j.version}</version>        </dependency>        <!-- 格式化对象,方便输出日志 -->        <dependency>            <groupId>com.alibaba</groupId>            <artifactId>fastjson</artifactId>            <version>1.1.41</version>        </dependency>        <dependency>            <groupId>org.slf4j</groupId>            <artifactId>slf4j-api</artifactId>            <version>${slf4j.version}</version>        </dependency>        <dependency>            <groupId>org.slf4j</groupId>            <artifactId>slf4j-log4j12</artifactId>            <version>${slf4j.version}</version>        </dependency>        <!-- log end -->        <!-- 映入JSON -->        <dependency>            <groupId>org.codehaus.jackson</groupId>            <artifactId>jackson-mapper-asl</artifactId>            <version>1.9.13</version>        </dependency>        <!-- 上传组件包 -->        <dependency>            <groupId>commons-fileupload</groupId>            <artifactId>commons-fileupload</artifactId>            <version>1.3.1</version>        </dependency>        <dependency>            <groupId>commons-io</groupId>            <artifactId>commons-io</artifactId>            <version>2.4</version>        </dependency>        <dependency>            <groupId>commons-codec</groupId>            <artifactId>commons-codec</artifactId>            <version>1.9</version>        </dependency>    </dependencies>    <build>        <finalName>test</finalName>    </build></project>

三 配置整合

在src/main/resources目录下创建配置文件如下

这里写图片描述

log4j.properties 文件如下

#定义LOG输出级别      log4j.rootLogger=INFO,Console,File      #定义日志输出目的地为控制台      log4j.appender.Console=org.apache.log4j.ConsoleAppender      log4j.appender.Console.Target=System.out      #可以灵活地指定日志输出格式,下面一行是指定具体的格式      log4j.appender.Console.layout = org.apache.log4j.PatternLayout      log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n      #文件大小到达指定尺寸的时候产生一个新的文件      log4j.appender.File = org.apache.log4j.RollingFileAppender      #指定输出目录      log4j.appender.File.File = logs/test.log      #定义文件最大大小      log4j.appender.File.MaxFileSize = 10MB      # 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志      log4j.appender.File.Threshold = ALL      log4j.appender.File.layout = org.apache.log4j.PatternLayout      log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH:mm:ss}][%c]%m%n 

jdbc.properties 文件如下

driver=com.mysql.jdbc.Driverurl=jdbc:mysql://127.0.0.1/testusername=rootpassword=root#定义初始连接数  initialSize=0  #定义最大连接数  maxActive=20  #定义最大空闲  maxIdle=20  #定义最小空闲  minIdle=1  #定义最长等待时间  maxWait=60000

spring-mybatis.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:p="http://www.springframework.org/schema/p"          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-3.1.xsd                                http://www.springframework.org/schema/context                                http://www.springframework.org/schema/context/spring-context-3.1.xsd                                http://www.springframework.org/schema/mvc                                http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">        <!-- 自动扫描 -->          <context:component-scan base-package="com.test" />          <!-- 引入配置文件 -->          <bean id="propertyConfigurer"              class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">              <property name="location" value="classpath:jdbc.properties" />          </bean>          <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"              destroy-method="close">              <property name="driverClassName" value="${driver}" />              <property name="url" value="${url}" />              <property name="username" value="${username}" />              <property name="password" value="${password}" />              <!-- 初始化连接大小 -->              <property name="initialSize" value="${initialSize}"></property>              <!-- 连接池最大数量 -->              <property name="maxActive" value="${maxActive}"></property>              <!-- 连接池最大空闲 -->              <property name="maxIdle" value="${maxIdle}"></property>              <!-- 连接池最小空闲 -->              <property name="minIdle" value="${minIdle}"></property>              <!-- 获取连接最大等待时间 -->              <property name="maxWait" value="${maxWait}"></property>          </bean>          <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->          <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">              <property name="dataSource" ref="dataSource" />              <property name="configLocation" value="classpath:com/test/mybatis/mybatis-config.xml"></property>            <!-- 自动扫描mapping.xml文件 -->              <property name="mapperLocations" value="classpath:com/test/mybatis/mapping/*.xml"></property>          </bean>          <!-- DAO接口所在包名,Spring会自动查找其下的类 -->          <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">              <property name="basePackage" value="com.test.dao" />              <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>          </bean>          <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->          <bean id="transactionManager"              class="org.springframework.jdbc.datasource.DataSourceTransactionManager">              <property name="dataSource" ref="dataSource" />          </bean>  </beans>

spring-mvc.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:p="http://www.springframework.org/schema/p"          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-3.1.xsd                                http://www.springframework.org/schema/context                                http://www.springframework.org/schema/context/spring-context-3.1.xsd                                http://www.springframework.org/schema/mvc                                http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">          <!-- 自动扫描该包,使SpringMVC认为包下用了@controller注解的类是控制器 -->          <context:component-scan base-package="com.test.controller" />          <!--避免IE执行AJAX时,返回JSON出现下载文件 -->          <bean id="mappingJacksonHttpMessageConverter"              class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">              <property name="supportedMediaTypes">                  <list>                      <value>text/html;charset=UTF-8</value>                  </list>              </property>          </bean>          <!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 -->          <bean              class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">              <property name="messageConverters">                  <list>                      <ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON转换器 -->                  </list>              </property>          </bean>          <!-- 定义跳转的文件的前后缀 ,视图模式配置-->          <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">              <!-- 这里的配置自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 -->              <property name="prefix" value="/WEB-INF/jsps/" />              <property name="suffix" value=".jsp" />          </bean>          <!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 -->          <bean id="multipartResolver"                class="org.springframework.web.multipart.commons.CommonsMultipartResolver">                <!-- 默认编码 -->              <property name="defaultEncoding" value="utf-8" />                <!-- 文件大小最大值 -->              <property name="maxUploadSize" value="10485760000" />                <!-- 内存中的最大值 -->              <property name="maxInMemorySize" value="40960" />            </bean>       </beans> 

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"      xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"      version="3.0">     <display-name>Archetype Created Web Application</display-name>      <!-- Spring和mybatis的配置文件 -->      <context-param>          <param-name>contextConfigLocation</param-name>          <param-value>classpath:spring-mybatis.xml</param-value>      </context-param>      <!-- 编码过滤器 -->      <filter>          <filter-name>encodingFilter</filter-name>          <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>          <async-supported>true</async-supported>          <init-param>              <param-name>encoding</param-name>              <param-value>UTF-8</param-value>          </init-param>      </filter>      <filter-mapping>          <filter-name>encodingFilter</filter-name>          <url-pattern>/*</url-pattern>      </filter-mapping>      <!-- Spring监听器 -->      <listener>          <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>      </listener>      <!-- 防止Spring内存溢出监听器 -->      <listener>          <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>      </listener>      <!-- Spring MVC servlet -->      <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-mvc.xml</param-value>          </init-param>          <load-on-startup>1</load-on-startup>          <async-supported>true</async-supported>      </servlet>      <servlet-mapping>          <servlet-name>SpringMVC</servlet-name>           <url-pattern>/</url-pattern>      </servlet-mapping>      <welcome-file-list>          <welcome-file>/index.jsp</welcome-file>      </welcome-file-list>  </web-app> 

此时若启动项目会报一个找不到位置的错误,因为我们配置了mybatis配置文件的路径,但却没有这个文件

这里写图片描述

解决方法如下:
在com.test.mybatis包中新建mybatis-config.xml文件

mybatis-config.xml 文件如下

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE configuration        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"        "http://mybatis.org/dtd/mybatis-3-config.dtd"><configuration>    <!-- settings是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。 -->    <settings>     <!-- 这个配置使全局的映射器启用或禁用缓存 -->         <setting name="cacheEnabled" value="true" />          <!-- 全局启用或禁用延迟加载。当禁用时,所有关联对象都会即时加载 -->          <setting name="lazyLoadingEnabled" value="false" />        <!-- 允许或不允许多种结果集从一个单独的语句中返回(需要适合的驱动) -->          <setting name="multipleResultSetsEnabled" value="true" />        <!-- 使用列标签代替列名。不同的驱动在这方便表现不同。参考驱动文档或充分测试两种方法来决定所使用的驱动 -->          <setting name="useColumnLabel" value="true" />        <!-- 允许JDBC支持生成的键。需要适合的驱动。如果设置为true则这个设置强制生成的键被使用,尽管一些驱动拒绝兼容但仍然有效(比如Derby) -->          <setting name="useGeneratedKeys" value="false" />        <!-- 配置默认的执行器。SIMPLE执行器没有什么特别之处。REUSE执行器重用预处理语句。BATCH执行器重用语句和批量更新 -->          <setting name="defaultExecutorType" value="SIMPLE" />        <!-- 设置超时时间,它决定驱动等待一个数据库响应的时间 -->         <setting name="defaultStatementTimeout" value="25000" />        <!-- 打印查询语句 -->        <!--<setting name="logImpl" value="STDOUT_LOGGING" />-->    </settings></configuration>

目录如下图

这里写图片描述

此时就可以删除这个包下的占位文件了

四 配置Tomcat7并发布项目

1.打开Window->preferences 选择service ->Runtime Environments

这里写图片描述

2点击add

这里写图片描述

3选择tomcat 7.0,然后Next下一步

这里写图片描述

4选择本地jdk,然后Finish,将项目添加进tomcat并启动

这里写图片描述

出现这些的时候表示成功启动

5进入浏览器运行项目

这里写图片描述

项目成功配置完成

扩展:写法和步骤

第二章中会将数据库数据显示到页面,想了解具体的写法和步骤

点击 第二章:ssm执行数据库操作的具体写法和步骤
个人源代码(http://download.csdn.net/download/qq_29132907/10118504)