maven整合SSM项目的步骤

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_39859824/article/details/83573241

1、创建一个maven的简单项目,点击项目右键,找到它的Project Facets ;将里面web.xml勾选,会让你重新配置,点击即可

2、首先要配置web.xml,web.xml里面主要需要配置的是项目启动时,会加载spring配置;并且将所有的请求都过滤给Spring Mvc

来处理;还可以在web.xml里面配置字符集过滤器 、 Rest风格的URI过滤器

<!--  启动spring的容器 -->
  <context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:applicationContext.xml</param-value>
  </context-param>
  <listener>
    <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>

<!--  字符集过滤器-->
  <filter>
    <filter-name>encodingFilter</filter-name>
    <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
    <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>
  <!-- springmvc的前端过滤器  -->
  <servlet>
    <servlet-name>springMVC</servlet-name>
    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>springMVC</servlet-name>
    <url-pattern>/</url-pattern>
  </servlet-mapping>

<!-- REST风格的URI过滤器  -->
  <filter>
    <filter-name>HiddenHttpMethodFilter</filter-name>
    <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>HiddenHttpMethodFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
</web-app>

3、对SpringMVC的配置文件进行配置,包含网站跳转逻辑的控制

 第一步:<!-- SpringMVC 的配置文件,包含网站跳转逻辑的控制, 配置 -->
     <context:component-scan base-package="com.atguigu" use-default-filters="false">
         <!-- 只扫描控制器 -->
         <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller" />
     </context:component-scan>

第二步:配置视图解析器,方便页面返回

  <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"> 
         <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> 
         <property name="prefix" value="/WEB-INF/views/"/> 
         <property name="suffix" value=".jsp"/> 
      </bean> 

第三步:两个标准配置

<!-- 将springmvc 不能处理的请求交给 tomcat -->
      <mvc:default-servlet-handler />
      <!-- 能支持 springmvc 更高级的一些功能 -->
 <mvc:annotation-driven/> 

4、Spring的配置文件ApplicationContext.xml的配置

首先要配置全局扫描,当然Spring是不需要配置Controller层的

<context:component-scan base-package="com.atguigu">
          <!-- 不扫描控制器 -->
          <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller" />
      </context:component-scan>

然后是需要配置数据源以及事务控制

<context:property-placeholder location="classpath:dbconfig.properties" />
      
      <bean id="pooledDataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
          <property name="jdbcUrl" value="${jdbc.jdbcUrl}"></property>
          <property name="driverClass" value="${jdbc.driverClass}"></property>
          <property name="user" value="${jdbc.user}"></property>
          <property name="password" value="${jdbc.password}"></property>
      </bean>

    <!-- 配置和 MyBatis 整合 -->
    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <property name="configLocation" value="classpath:mybatis-config.xml"></property>
          <property name="dataSource" ref="pooledDataSource" />
          <property name="mapperLocations" value="classpath:mapper/*.xml" />
    </bean>

    <!-- 配置扫描器,将mybatis 接口的实现加入到 IOC 容器中 -->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
          <property name="basePackage" value="com.atguigu.crud.dao" />
    </bean>
    

    <!-- 配置一个可以批量操作的 sqlSession -->
    <bean id="sqlSession" class="org.mybatis.spring.SqlSessionTemplate">
        <constructor-arg name="sqlSessionFactory" ref="sqlSessionFactory"></constructor-arg>
        <constructor-arg name="executorType" value="BATCH"></constructor-arg>
    </bean>

    <!-- 事务控制 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
          <property name="dataSource" ref="pooledDataSource" />
    </bean>
    
    <!-- 开启基于注解的事务 -->
    <aop:config>
        <aop:pointcut expression="execution(* com.atguigu.crud.service..*(..))" id="txPoint"/>
        <aop:advisor advice-ref="txAdvice"  pointcut-ref="txPoint"/>
    </aop:config>
    
    <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="*" />
            <tx:method name="get" read-only="true" />
        </tx:attributes>
    </tx:advice>
</beans>

5、mybatis的配置文件

<!-- 配置全局属性 -->
    <settings>
        <!--  使用jdbc的getGeneratedKeys获取数据库自增主键值  -->
        <setting name="useGeneratedKeys" value="true" />

        <setting name="useColumnLabel" value="true" />

        <!-- 开启驼峰命名转换:Table{create_time} -> Entity{createTime} -->
        <setting name="mapUnderscoreToCamelCase" value="true" />
    </settings>

    <typeAliases>
        <package name="com.atguigu.crud.bean"/>
    </typeAliases>
    

<!-- 配置分页组件 -->
    <plugins>
    <plugin interceptor="com.github.pagehelper.PageInterceptor">
        <!-- config params as the following -->
    </plugin>
</plugins>

猜你喜欢

转载自blog.csdn.net/qq_39859824/article/details/83573241