zoukankan      html  css  js  c++  java
  • 使用maven搭建ssm框架的javaweb项目

    目前主流的javaweb项目,常会用到ssm(Spring+Spring MVC+Mybatis)框架来搭建项目的主体框架,本篇介绍搭建SSM框架的maven项目的实施流程。记之共享!

    一、SSM框架介绍

     SSM框架是指:Spring+Spring MVC+Mybatis。

    【Spring】

      轻量——从大小与开销两方面而言Spring都是轻量的,此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于Spring的特定类。简单说就是自己需要什么就导入对应的jar的即可,而不是侵入式的。

      控制反转——Spring通过一种称作控制反转(IoC)的技术促进了低耦合,当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象。

      面向切面——Spring提供了面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统级服务(例如审计(auditing)和事务(transaction)管理)进行内聚性的开发。应用对象只实现它们应该做的——完成业务逻辑——仅此而已。它们并不负责(甚至是意识)其它的系统级关注点,例如日志或事务支持。

      框架——Spring可以将简单的组件配置、第三方框架组合成为复杂的应用。如下图:

       

    【Spring MVC】

      MVC框架是一个全功能的构建 Web应用程序的 MVC 实现。通过策略接口,MVC框架变成为高度可配置的,MVC 容纳了大量视图技术,其中包括 JSP、Velocity、Tiles、iText 和 POI。模型由javabean构成,存放于Map;视图是一个接口,负责显示模型;控制器表示逻辑代码,是Controller的实现。

    【Mybatis】

        MyBatis是一个基于Java的持久层框架。MyBatis 消除了几乎所有的JDBC代码和参数的手工设置以及结果集的检索。MyBatis 使用简单的 XML或注解用于配置和原始映射,将接口和 Java 的POJOs(普通的 Java对象)映射成数据库中的记录.

    二、SSM框架工作机制

         

      

      1、web服务器启动,会自动加载web.xml配置文件(web.xml配置有:spring.xml的配置文件、spring的监听器)

      2、浏览器发送一个请求,会被spring的拦截器拦截,截取对应的url;

      3、将截取的到url提交给DispatcherServlet(分发请求),DispatcherServlet查询一个或多个HandlerMapping,找到处理请求的Controller.

      4、在service里进行一系列的业务判断,例如判断前台传过来的用户名和密码是否正确,通过spring的依赖注入数据访问层的接口;

      5、在dao(数据访问层)层通过方法名找到在mybatis的mapper映射文件里与之对应的id=“login”语句来查询数据库,将查询到的result返回dao层;

      6、Controller进行业务逻辑处理后,会返回一个ModelAndView

      7、Dispathcher查询一个或多个ViewResolver视图解析器,找到ModelAndView对象指定的视图对象

      8、视图对象负责渲染返回给客户端。 

    三、SSM框架搭建流程

       使用maven搭建ssm框架步骤如下:

    1. 首先创建一个Maven的Project如下图:

      

      

      

      

      注意:若项目中的index.jsp报错,则原因是: src/main/webapp/index.jsp里面没有用标准jsp标签。只需在pom.xml导入javaee-api的jar包即可。

      

       修改项目属性:

       

      若修改过程中报错,无法完成修改。则可以修改项目工作目录下的.settings文件夹,找到org.eclipse.wst.common.project.facet.core.xml,修改其中的信息如下:

      

     

      2、导入对应的spring mvc、mybatis、spring的依赖包以及对应的配置文件

      本框架使用的框架版本:Spring 4.2.5 RELEASE、Spring MVC 4.2.5 RELEASE、MyBatis 3.4.1、jdk 1.7

      1)   在maven的配置文件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.cmsz</groupId>
      <artifactId>vframe</artifactId>
      <packaging>war</packaging>
      <version>0.0.1-SNAPSHOT</version>
      <name>vframe Maven Webapp</name>
      <url>http://maven.apache.org</url>
      
      <!-- 版本参量设置-->
      <properties>
          <spring-version>4.2.5.RELEASE</spring-version>
          <mybatis-version>3.4.1</mybatis-version>
      </properties>
      
      <dependencies>
        <dependency>
          <groupId>junit</groupId>
          <artifactId>junit</artifactId>
          <version>3.8.1</version>
          <scope>test</scope>
        </dependency>
        <!-- spring核心包 start-->
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-web</artifactId>
            <version>${spring-version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-test</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-core</artifactId>
            <version>${spring-version}</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-context</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-aop</artifactId>
            <version>${spring-version}</version>
        </dependency>
        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.8.5</version>
        </dependency>
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-beans</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-orm</artifactId>
            <version>${spring-version}</version>
        </dependency>
        <!-- spring核心包 end-->
        <!-- 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.3.0</version>
        </dependency>
            
        <!-- logback 日志 -->  
        <dependency>  
            <groupId>ch.qos.logback</groupId>  
            <artifactId>logback-classic</artifactId>  
            <version>1.1.7</version>  
         </dependency>
          
        <!-- servlet -->  
         <dependency>  
            <groupId>javax.servlet</groupId>  
            <artifactId>jsp-api</artifactId>  
            <version>2.0</version>  
            <scope>provided</scope>  
         </dependency>  
            
         <dependency>  
            <groupId>javax.servlet</groupId>  
            <artifactId>servlet-api</artifactId>  
            <version>2.5</version>  
            <scope>provided</scope>  
         </dependency> 
            
        <!-- mysql -->
         <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.26</version>
         </dependency>
            
         <!-- druid数据库连接池 -->
         <dependency>  
            <groupId>com.alibaba</groupId>  
            <artifactId>druid</artifactId>  
            <version>1.0.18</version>  
         </dependency>
             
         <!--json解析包  -->
         <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.3</version>
         </dependency>
         <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
            <version>2.5.4</version>
         </dependency>
         <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.5.4</version>
         </dependency>
         <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
            <version>2.5.4</version>
         </dependency>      
      </dependencies>

    <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>3.5.1</version> <configuration> <source>1.7</source> <target>1.7</target> </configuration> </plugin> </plugins> <finalName>vframe</finalName> </build> </project>

           更新maven:项目右键——Maven——Update Project

      2)   配置服务器加载的web.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
             xmlns:web="http://java.sun.com/xml/ns/javaee" 
             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" id="WebApp_ID" version="3.0">
        <display-name>Archetype Created Web Application</display-name>
        <context-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring.xml</param-value>
        </context-param>
        <filter>
            <description>字符集过滤器</description>
            <filter-name>encodingFilter</filter-name>
            <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
            <init-param>
                <description>字符集编码</description>
                <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>
        <listener>
            <description>spring监听器</description>
            <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
        </listener>
        <listener>
            <listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class>
        </listener>
        <servlet>
            <servlet-name>dispatcher</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>
        </servlet>
        <servlet-mapping>
            <servlet-name>dispatcher</servlet-name>
            <url-pattern>/</url-pattern>
        </servlet-mapping>
        <filter>
            <filter-name>DruidWebStatFilter</filter-name>
            <filter-class>com.alibaba.druid.support.http.WebStatFilter</filter-class>
            <init-param>
                <param-name>exclusions</param-name>
                <param-value>*.js,*.gif,*.jpg,*.png,*.css,*.ico,*.jsp,/druid/*,/download/*</param-value>
            </init-param>
            <init-param>
                <param-name>sessionStatMaxCount</param-name>
                <param-value>2000</param-value>
            </init-param>
            <init-param>
                <param-name>sessionStatEnable</param-name>
                <param-value>true</param-value>
            </init-param>
            <init-param>
                <param-name>principalSessionName</param-name>
                <param-value>session_user_key</param-value>
            </init-param>
            <init-param>
                <param-name>profileEnable</param-name>
                <param-value>true</param-value>
            </init-param>
        </filter>
        <filter-mapping>
            <filter-name>DruidWebStatFilter</filter-name>
            <url-pattern>/*</url-pattern>
        </filter-mapping>
        <welcome-file-list>
            <welcome-file>index.html</welcome-file>
        </welcome-file-list>
    </web-app>

      3)   配置日志管理logback.xml(类似于log4j)

    <?xml version="1.0" encoding="UTF-8"?>  
    <configuration>  
    <property name="LOG_HOME" value="D:/logs" />
        <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">  
            <encoder class="ch.qos.logback.classic.encoder.PatternLayoutEncoder">  
                <Pattern>%d{HH:mm:ss.SSS} %-5level %logger{80} - %msg%n</Pattern>  
            </encoder>  
        </appender>  
        <appender name="FILE"  
      class="ch.qos.logback.core.rolling.RollingFileAppender">  
              <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">  
                   <FileNamePattern>${LOG_HOME}/debug.%d{yyyy-MM-dd}.log</FileNamePattern>  
                   <MaxHistory>30</MaxHistory>  
              </rollingPolicy>  
              <encoder>  
                   <pattern>%date [%thread] %-5level %logger{80} - %msg%n</pattern>  
             </encoder>  
           </appender>  
        <root>  
            <level value="INFO" />  
            <appender-ref ref="FILE" />  
        </root>  
    </configuration>  

      4)   添加spring配置文件spring.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:aop="http://www.springframework.org/schema/aop"
        xmlns:lang="http://www.springframework.org/schema/lang"
        xmlns:tx="http://www.springframework.org/schema/tx"
        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/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
        http://www.springframework.org/schema/lang http://www.springframework.org/schema/lang/spring-lang-3.0.xsd
        http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd">
    
        <!--加载配置文件-->
        <context:property-placeholder location="classpath:config.properties" ignore-unresolvable="true"/>
        <!--依赖注入,扫描-->
        <context:component-scan base-package="com.cmsz.vframe"></context:component-scan>
        <!--开启注解-->
        <context:annotation-config />
        <!--把查询慢的sql写到日志里面 -->
        <bean id="stat-filter" class="com.alibaba.druid.filter.stat.StatFilter">
            <property name="slowSqlMillis" value="1" />
            <property name="logSlowSql" value="true" />
            <!-- 合并同样的sql语句 -->
            <property name="mergeSql" value="true" />
        </bean>
        <!-- 配置要写入日志哪种dataSource信息 -->
        <bean id="log-filter" class="com.alibaba.druid.filter.logging.Slf4jLogFilter">
            <property name="dataSourceLogEnabled" value="true" />
            <property name="resultSetLogEnabled" value="true"/>
        </bean>
        <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
        <!--加载数据源-->
            <property name="url" value="${jdbc.url}" />
            <property name="username" value="${jdbc.user}" />
            <property name="password" value="${jdbc.password}" />
            <!-- 配置初始化大小、最小、最大 -->
            <property name="initialSize" value="${druid.initialSize}" />
            <property name="minIdle" value="${druid.minIdle}" /> 
            <property name="maxActive" value="${druid.maxActive}" />
    
            <!-- 配置获取连接等待超时的时间 -->
            <property name="maxWait" value="${druid.maxWait}" />
    
            <!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
            <property name="timeBetweenEvictionRunsMillis" value="${druid.timeBetweenEvictionRunsMillis}" />
    
            <!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
            <property name="minEvictableIdleTimeMillis" value="${druid.minEvictableIdleTimeMillis}" />
    
            <property name="validationQuery" value="SELECT 'x'" />
            <!-- 建议配置为true,不影响性能,并且保证安全性。 申请连接的时候检测 -->
            <property name="testWhileIdle" value="${druid.testWhileIdle}" />
            <!-- 申请连接时执行validationQuery检测连接是否有效, 做了这个配置会降低性能 -->
            <property name="testOnBorrow" value="${druid.testOnBorrow}" />
            <!-- 归还连接时执行validationQuery检测连接是否有效, 做了这个配置会降低性能 -->
            <property name="testOnReturn" value="${druid.testOnReturn}" />
    
            <!-- 打开PSCache,并且指定每个连接上PSCache的大小 -->
            <property name="poolPreparedStatements" value="${druid.poolPreparedStatements}" />
            <property name="maxPoolPreparedStatementPerConnectionSize" value="${druid.maxPoolPreparedStatementPerConnectionSize}" />
            <!-- 监控数据库 -->
            <property name="filters" value="slf4j" />
            <property name="proxyFilters">
                <list>
                    <ref bean="stat-filter"/>
                    <ref bean="log-filter"/>
                </list>
            </property>
        </bean>
        <!-- mybatis -->
        <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
            <property name="dataSource" ref="dataSource" />
            <property name="configLocation" value="classpath:mybatis.xml"></property>
            <!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 -->
            <property name="mapperLocations" value="classpath:com/cmsz/vframe/dao/mapper/*.xml" />
        </bean>
        <!-- 扫描mapper映射文件-->
        <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
            <property name="basePackage" value="com.cmsz.vframe.dao" />
            <!-- 指定引用的sqlsessionFactory -->
            <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
        </bean>
        <!--配置事务管理器-->
        <bean id="transactionManager"
            class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
            <property name="dataSource" ref="dataSource" />
        </bean>
        <!-- 配置事务的传播 -->
        <tx:advice id="transactionAdvice" transaction-manager="transactionManager">
            <tx:attributes>
                <!-- 需要事务处理的方法名结尾 -->
                <tx:method name="*Affairs" propagation="REQUIRED" />
            </tx:attributes>
        </tx:advice>    
        <!-- 需要事务处理的切面 -->
        <aop:config>
            <aop:pointcut id="transactionPointcut"
                expression="execution(* com.cmsz.vframe..*.*(..))" />
            <aop:advisor pointcut-ref="transactionPointcut"
                advice-ref="transactionAdvice" />
        </aop:config>
        <!-- 事物 end -->
    </beans>

      5)   添加spring mvc的配置文件spring-mvc.xml

    <?xml version="1.0" encoding="UTF-8"?>
    <beans xmlns="http://www.springframework.org/schema/beans"
        xmlns:mvc="http://www.springframework.org/schema/mvc"
        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 
    http://www.springframework.org/schema/mvc 
    http://www.springframework.org/schema/mvc/spring-mvc-3.0.xsd">
    <!--依赖注入,扫描-->
        <context:component-scan base-package="com.cmsz.vframe" />
        <mvc:annotation-driven />
        <mvc:default-servlet-handler />
    <!-- 以下是当实现每次请求都返回json格式数据时配置 -->
        <!-- json数据转换器。将请求对象与返回值转换程json格式 与POJO对象映射 -->
        <bean id="mappingjacksonHttpMessageConverter"
            class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
            <property name="supportedMediaTypes">
                <list>
                    <value>text/html;charset=UTF-8</value>
                </list>
            </property>
        </bean>
        <bean
            class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
            <property name="messageConverters">
                <list>
                    <ref bean="mappingjacksonHttpMessageConverter" />
                </list>
            </property>
        </bean>
        
    </beans>

      6)   添加用于存放数据库信息的配置文件config.properties

    jdbc.url=jdbc:mysql://localhost:3306/user?autoReconnect=true&useUnicode=yes&amp;characterEncoding=UTF8&allowMultiQueries=true
    jdbc.user=root
    jdbc.password=
    druid.initialSize=3
    druid.minIdle=3
    druid.maxActive=200
    druid.maxWait=60000
    druid.timeBetweenEvictionRunsMillis=60000
    druid.minEvictableIdleTimeMillis=300000
    druid.testWhileIdle=true
    druid.testOnBorrow=true
    druid.testOnReturn=false
    druid.poolPreparedStatements=true
    druid.maxPoolPreparedStatementPerConnectionSize=20

      7) 添加mybits的配置文件mybatis.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>
            <!-- 这个配置使全局的映射器启用或禁用缓存 -->
            <setting name="cacheEnabled" value="true" />
            <!-- 允许 JDBC 支持生成的键。需要适合的驱动。如果设置为 true 则这个设置强制生成的键被使用,尽管一些驱动拒绝兼容但仍然有效(比如 
                Derby) -->
            <setting name="useGeneratedKeys" value="true" />
            <!-- 配置默认的执行器。SIMPLE 执行器没有什么特别之处。REUSE 执行器重用预处理语句。BATCH 执行器重用语句和批量更新 -->
            <setting name="defaultExecutorType" value="REUSE" />
            <!-- 全局启用或禁用延迟加载。当禁用时,所有关联对象都会即时加载。 -->
            <setting name="lazyLoadingEnabled" value="true" />
            <!-- 设置超时时间,它决定驱动等待一个数据库响应的时间。 -->
            <setting name="defaultStatementTimeout" value="25000" />
        </settings>
    
        <!-- 别名配置,查找该包内的所有bean,bean实例名为类名 -->
        <typeAliases>
            <package name="com.cmsz.vframe.model" />
        </typeAliases>
    
    </configuration> 

      

     

    简单的才是最好的。
  • 相关阅读:
    python---RabbitMQ
    Apicloud学习第四天
    Apicloud学习第三天——获取云数据库的数据方法
    APICloud学习第二天——操作云数据库
    font-spider问题【已解决】
    Apicloud学习第一天
    sass补充(2019-3-9)
    sublime中编译的sass如何改变css输出风格?【这里有答案】
    SEO总结
    Sass学习第一天
  • 原文地址:https://www.cnblogs.com/vikezhu/p/6655557.html
Copyright © 2011-2022 走看看