1. 程式人生 > >使用maven整合spring+springmvc+mybatis

使用maven整合spring+springmvc+mybatis

cti 監聽 package 基於接口 mysql 5.7 spring 整合 rri ext inter

使用maven整合spring+springmvc+mybatis

開發環境:

    1.  jdk1.8

    2.  eclipse4.7.0 (Oxygen)

    3.  mysql 5.7

  在pom.xml文件中,引入我們需要的jar包:(按需引入jar包)

   <properties>
    <!-- 自定義的spring的版本號 -->
    <spring.version>4.3.18.RELEASE</spring.version>
    <!-- 自定義的mybaits的版本號 -->
    <
mybatis.version>3.4.5</mybatis.version> <!-- 自定義的mybaits-spring的版本號 --> <mybatis.spring.version>1.3.1</mybatis.spring.version> </properties> <dependencies> <!-- springMVC的jar包,由於springMVC依賴 springBeans,springContext,springCore 所以這些jar包會被導入進來-->
<dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> <scope>compile</scope> </dependency> <!-- spring-tx 事務 --> <
dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> <scope>compile</scope> </dependency> <!-- spring-jdbc --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> <scope>compile</scope> </dependency> <!-- aspectjweaver aop 依賴該jar包--> <dependency> <groupId>org.aspectj</groupId> <artifactId>aspectjweaver</artifactId> <version>1.8.13</version> </dependency> <!-- servlet的jar包 --> <dependency> <groupId>javax.servlet</groupId> <artifactId>javax.servlet-api</artifactId> <version>4.0.1</version> <scope>provided</scope> <!-- 編譯時,不會被打包 --> </dependency> <!-- servlet.jsp-api --> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>javax.servlet.jsp-api</artifactId> <version>2.3.1</version> <scope>provided</scope> </dependency> <!-- javax.servlet.jsp.jstl-api --> <dependency> <groupId>javax.servlet.jsp.jstl</groupId> <artifactId>javax.servlet.jsp.jstl-api</artifactId> <version>1.2.2</version> </dependency> <!-- taglibs-standard-impl jstl的實現 --> <dependency> <groupId>org.apache.taglibs</groupId> <artifactId>taglibs-standard-impl</artifactId> <version>1.2.5</version> </dependency> <!-- mybatis --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis</artifactId> <version>${mybatis.version}</version> <scope>compile</scope> </dependency> <!-- mybatis-spring --> <dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>${mybatis.spring.version}</version> <scope>compile</scope> </dependency> <!--druid 連接池 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>druid</artifactId> <version>1.1.10</version> <scope>compile</scope> </dependency> <!-- mysql的連接驅動 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.46</version> </dependency> <!--log4j/log4j --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.17</version> </dependency> </dependencies>

  在Maven dependencies中可以看到jar包,說明引入成功了

   技術分享圖片

  定義目錄結構:

  技術分享圖片

  配置文件:

   db.properties

jdbc_driverClassName=com.mysql.jdbc.Driver
jdbc_url=jdbc:mysql://localhost:3306/db_ssm
jdbc_username=root
jdbc_password=123456

  mybatis-config.xml

<!--mybatis的總配置文件! -->
  <settings>
    <!--  配置mybatis的日誌  -->
     <setting name="logImpl" value="LOG4J"/>
     <!--開啟延遲加載  -->
     <setting name="lazyLoadingEnabled" value="true"/>
     <!--設置不要積極去加載  -->
     <setting name="aggressiveLazyLoading" value="false"/>
     <!--延遲加載的觸發方法  -->
     <setting name="lazyLoadTriggerMethods" value="clone"/>
  </settings>
  <!-- 別名 -->
  <typeAliases>
      <package name="com.login.dao"/>
  </typeAliases>

  applicationContext-dao.xml

<!-- 
   spring 整合 mybatis 的配置
         配置數據庫連接池
         配置sqlSessionFactory
         配置掃描器
         配置掃描所有的service類
 -->
 <!-- 加載db.properties文件 -->
 <context:property-placeholder location="classpath:db.properties"/>
 
 <!-- 配置數據庫連接池 -->
 <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
     <property name="driverClassName" value="${jdbc_driverClassName}"></property>
     <property name="url" value="${jdbc_url}"></property>
     <property name="username" value="${jdbc_username}"></property>
     <property name="password" value="${jdbc_password}"></property>
 </bean>
 
 <!-- 配置sqlSessionFactory -->
 <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!-- 數據庫連接池 -->
     <property name="dataSource" ref="dataSource"></property>
    <!-- mapper文件 -->
     <property name="mapperLocations">
     <!--加載所有的mapper文件  -->
      <list>
          <value>classpath:mappers/*.xml</value>
      </list>
     </property>    
    <!-- mybatis的配置文件 -->
     <property name="configLocation" value="classpath:mybatis/mybatis-config.xml"></property>
 </bean>
 
 <!-- 配置mapper掃描器 -->
 <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.login.dao"></property>
    <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
 </bean>
 <!--掃描所有的service  -->
 <context:component-scan base-package="com.login.service"></context:component-scan>

  applicationContext-tx.xml

<!-- 配置spring的事務
          mybatis采用的是spring中的jdbc中的事務管理(配置事務管理器)
          事務增強
          aop切面
  -->
  <!--事務管理  -->
  <bean id="tx" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
     <!-- 這裏的DataSource是引用的applicationContext dao文件中的 -->
     <property name="dataSource" ref="dataSource"></property>
  </bean>

  <!-- 增強 -->
  <tx:advice id="tx_advice" transaction-manager="tx" >
    <tx:attributes>
        <!-- 事務傳播規則 -->
         <tx:method name="save*" propagation="REQUIRED"/>
         <tx:method name="add*" propagation="REQUIRED"/>
         <tx:method name="delete*" propagation="REQUIRED"/>
         <tx:method name="update*" propagation="REQUIRED"/>
         <tx:method name="do*" propagation="REQUIRED"/>
         
         <tx:method name="get*" propagation="SUPPORTS" read-only="true"/>
         <tx:method name="list*" propagation="SUPPORTS" read-only="true"/>
         <tx:method name="find*" propagation="SUPPORTS" read-only="true"/>
         <tx:method name="query*" propagation="SUPPORTS" read-only="true"/>
         <tx:method name="count*" propagation="SUPPORTS" read-only="true"/>
    </tx:attributes>
  </tx:advice>
  
  <!-- Aop 切面 
       proxy-target-class="false"  是默認的 =====》 默認使用jdk動態代理 基於接口
       proxy-target-class="true"   =============》使用cglib動態代理 基於類
  -->
  
  <aop:config  proxy-target-class="false">
    <aop:advisor advice-ref="tx_advice" pointcut="execution(* com.login.service.*Service.*(..) )"/>
  </aop:config>

  springmvc.xml

<!--
      springmvc的配置文件
                  掃描handler對象
                  配置註解的處理器映射器和處理器適配器
                  配置內部資源視圖解析器
                  處理不了的靜態資源交給tomcat
   -->
   
   <context:component-scan base-package="com.login.web.controller"></context:component-scan>
   
   <mvc:annotation-driven></mvc:annotation-driven>
 
   <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
   
      <property name="prefix" value="/"></property>
      
      <property name="suffix" value=".jsp"></property>
   
   </bean>
   
   <mvc:default-servlet-handler/>

  web.xml

 <!-- 配置編碼  -->
<filter>
  <filter-name>characterEncodingFilter</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>
  <init-param>
         <param-name>forceRequestEncoding</param-name>
         <param-value>true</param-value>
  </init-param>
  <init-param>
         <param-name>forceResponseEncoding</param-name>
         <param-value>true</param-value>
  </init-param>
</filter>
<filter-mapping>
  <filter-name>characterEncodingFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

<!-- web IOC容器  -->
<context-param>
    <param-name>contextConfigLocation</param-name>
    <param-value>classpath:spring/applicationContext-*.xml</param-value>
</context-param>
<!-- 加載監聽器 -->
<listener>
  <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>

<!-- 配置spring mvc的前端控制器 -->
    <servlet>
        <servlet-name>spring-mvc</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <!-- 本地的上下文配置   加載springmvc的配置文件 -->
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <param-value>classpath:spring/spring-mvc.xml</param-value>
        </init-param>
        <!-- 啟動容器的時候加載 -->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>spring-mvc</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

  配置完成後,寫一個簡單的用戶登錄操作:

@Controller
public class UserController {
    
    @Autowired
    private IUserService service;
    
    @RequestMapping(path="/login")
    public String login(String username,String password,Model m) {
        
        User user = service.login(username, password);
        
        m.addAttribute("user", user);
        
        return "success";
        
    }

}
@Service
public class UserServiceImpl implements IUserService {

    @Autowired
    private UserMapper mapper;
    
    @Override
    public User login(String username, String password) {
        
        //參數驗證是否為空
        
        //參數判斷--》賬號,密碼是否正確
        
        return  mapper.getUserByUsername(username);
    }

}
 <mapper namespace="com.login.dao.UserMapper">
  
  <select id="getUserByUsername"  resultType="com.login.entity.User">
  
      SELECT * FROM user WHERE username = #{username}
  
  </select>
  
  </mapper>

  然後啟動tomcat:

技術分享圖片

技術分享圖片

總結: 使用maven可以讓我們不用擔心找不到jar包。maven同時也為我們規定好了一些目錄結構,方便我們的開發,但是maven的強大遠不如此。讓我們一起來學習吧!希望以上這些可以幫到需要幫助的朋友!

使用maven整合spring+springmvc+mybatis