1. 程式人生 > >一、使用IDEA,利用maven整合ssm框架(spring+springmvc+mybatis+mysql))

一、使用IDEA,利用maven整合ssm框架(spring+springmvc+mybatis+mysql))

1.工具

  • apache-tomcat 7
  • apache-maven(後面詳細講!這東西我一開始也很懵逼)
  • mysql 5以上的版本
  • navicat(有了這個就不用cmd了,可以直接顯示資料庫,如下圖,請自行百度綠色版QAQ)這裡寫圖片描述

2.前言

前不久學完了spring和mybatis基礎,於是決定來整合ssm。但是跟著學長的部落格教程走的時候,出現了很多問題,於是打算轉載一下他的部落格,並加上我自己的理解,來寫這麼一篇部落格。那麼,請務必包含耐性,內容較多,慢慢來實現ssm的helloworld入門專案(原出處:http://blog.csdn.net/lxfhahaha/article/details/57078994

3.步驟

1)準備工作

1.3 maven安裝
(安裝教程:https://jingyan.baidu.com/article/fd8044fadc1ac15031137a12.html
此處我是下載到D盤,然後自己在maven目錄下建立了一個repository資料夾(隨便取名)這裡寫圖片描述
然後開啟conf資料夾下的settings.xml,在大約100行左右,修改圈中的目錄,此處目錄寫你剛剛建立的repository資料夾的目錄,如上圖中,我的repository目錄是 D:\maven\repository,那此處就改成我的目錄(沒有<localRepository>

的話就自己新增就是的了)
這裡寫圖片描述
接下來在大約150行左右,在<mirrors> 元素之間新增如下程式碼

<mirror>
    <id>alimaven</id>
    <name>aliyun maven</name>
    <url>http://maven.aliyun.com/nexus/content/groups/public/</url>
    <mirrorOf>central</mirrorOf>        
 </mirror>
 <mirror
>
<id>jboss-public-repository-group</id> <mirrorOf>central</mirrorOf> <name>JBoss Public Repository Group</name> <url>http://repository.jboss.org/nexus/content/groups/public</url> </mirror> <mirror> <id>alimaven</id> <mirrorOf>central</mirrorOf> <name>aliyun maven</name> <url>http://maven.aliyun.com/nexus/content/repositories/central/</url> </mirror>

最後效果如下
這裡寫圖片描述

1.3.1 maven是幹嘛的?
答:百度上也有,說是管理jar包的。通俗點就是:如果你以前有過使用eclipse的經驗,就會知道,那麼當我們需要引用外來jar包的時候,都會自己找jar包,然後下載並新增到專案執行環境中。而使用maven,則可以自動下載,不用我們自己去下載了。或者有時候我們用eclipse匯入spring支援的包時候,也需要自己新增所需要的jar包,運用maven就可以自動添加了。
1.3.2 建立repository資料夾幹嘛?
答:這個資料夾是用來存放maven自動下載的jar包的。我們第一次使用的時候,會進行下載,這樣會耗一點時間,以後我們再用就直接用這個資料夾下的jar包了。
1.3.3 為什麼要修改setting.xml中的<localRepository>
答:我們上面說了,maven會下載jar包並存放到自己創好的repository資料夾下。這個操作就是設定讓maven把下載下來的jar包放入repository資料夾
1.3.4 為什麼要修改setting.xml中的<mirror>
答:我們說了,maven會自動下載。那麼它從哪個網站下載呢?此處就要用到這個<mirror> 了。由於maven預設的下載地址是國外的網站,可能由於牆的原因下載會超級超級慢。因此我們自動新增幾個國內的網站,此處就用了阿里雲。可以多新增幾個網站,因為有些網站可能jar包不是很全,因此多新增幾個以防萬一
1.3.5 要是添加了好幾個網站後也沒有我想要的jar包呢?
答:要麼再加幾個網站,要麼自己手動新增(方法後面講)

1.4 自行安裝IDEA,這裡不多說了

2)建立maven專案

在建立之前,請自行在資料庫中建立名為”example”的資料庫,裡面有個user表。如下:
這裡寫圖片描述

這裡寫圖片描述

這裡寫圖片描述

點選next,填寫對應的GroupId,ArtifactId(GroupId隨意填,我也不太知道有什麼用。ArtifactId就是你專案名)
(PS:接下來不要糾結我的專案名稱,因為我是同時開一個helloworld2,然後又用到了我已經架構好了的helloworld專案)
這裡寫圖片描述

點選next,此處就用到maven了。
這裡寫圖片描述
然後next,最後finish,然後慢慢等。剛剛開始建立專案的時候,IDEA要花點時間來建立專案,等一下就好了(ps:有點慢的,慢慢等)
這裡寫圖片描述

建立完了後,原生態目錄應該如下(目錄說明:.idea和helloworld.iml不用管,也不要刪,是IDEA本身的配置檔案;src就是我們寫專案的地方了。pom.xml是用來配合maven的。我們要用什麼jar包,寫在pom.xml中,d盤中的maven就會自動從<mirror> 中下載到repository資料夾中
這裡寫圖片描述

接著,執行如下操作:
1. 在main的java資料夾上,滑鼠右鍵,找到 make directory as,選擇Sources root
2. 在main的resources資料夾上,滑鼠右鍵,找到make directory as,選擇Resources root
3. 在test的java資料夾上,滑鼠右鍵,找到make directory as,選擇Test Sources root
4. 在test的resources資料夾上,滑鼠右鍵,找到make directory as,選擇Test Resources root

繼續修改目錄結構,增加一些資料夾及檔案,這些都是等一下要用的到的
1. src->main->java下新建package com,再新建package springmvc,這兩個對應我們剛開始的groupid
2. springmvc包下新建四個包,controller包用來放前臺url對映檔案,dao用來放與資料庫的介面檔案,entity用來放實體類檔案,service用來放自己定義的介面
3. applicationContext.xml是spring配置檔案
4. sqlmap資料夾裡面放實體與資料庫的對映檔案
5. generator.xml和generator.properties是mybatis的配置檔案
6. jdbc.properties是資料庫相關資訊
7. log4j.properties是日誌配置檔案
8. webapp下新建css、images等檔案,用來放前端資源
9. web-inf下新建views檔案件,jsp檔案就放這裡面了
修改後目錄如下:
這裡寫圖片描述
PS:此處有些人專案可能不會像我這樣是“樹枝狀”,而是變成了”com.springmvc.controller.dao.entity.service”。即包都擠在一起去了。解決方案:如圖,把劃線部分勾掉就好了
這裡寫圖片描述

3)專案配置檔案

3.1、配置pom.xml檔案,引入所需要的jar包

之前說了,pom.xml是用來配合maven使用的,我們想要什麼jar包,直接在pom.xml中寫出來,maven就會自動幫我們下載。當你剛剛開始用maven時候,repository資料夾裡面還是空的,因此要花時間來下載,請直接把接下來的程式碼複製黏貼。在這裡,我們只需要關注<dependency>標籤就好了
<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.springtest</groupId>
  <artifactId>helloworld</artifactId>
  <packaging>war</packaging>
  <version>1.0-SNAPSHOT</version>
  <name>helloworld Maven Webapp</name>
  <url>http://maven.apache.org</url>
  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>3.8.1</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-core</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-web</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-tx</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-jdbc</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-webmvc</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-aop</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-context-support</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>

    <dependency>
      <groupId>org.springframework</groupId>
      <artifactId>spring-test</artifactId>
      <version>3.1.1.RELEASE</version>
    </dependency>
    <!-- springframe end -->

    <!-- mybatis核心包 -->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis</artifactId>
      <version>3.3.1</version>
    </dependency>
    <!-- mybatis/spring包 -->
    <dependency>
      <groupId>org.mybatis</groupId>
      <artifactId>mybatis-spring</artifactId>
      <version>1.2.2</version>
    </dependency>
    <!-- mysql驅動包 -->
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.29</version>
    </dependency>
    <!-- junit測試包 -->
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
    <!-- jstl -->
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>jstl</artifactId>
      <version>1.2</version>
    </dependency>
    <dependency>
      <groupId>javax.servlet.jsp</groupId>
      <artifactId>jsp-api</artifactId>
      <version>2.2.1-b03</version>
      <scope>provided</scope>
    </dependency>

    <!-- servlet -->
    <dependency>
      <groupId>javax.servlet</groupId>
      <artifactId>servlet-api</artifactId>
      <version>2.5</version>
      <scope>provided</scope>
    </dependency>
    <!-- json資料 -->
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-core</artifactId>
      <version>2.8.5</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-databind</artifactId>
      <version>2.8.5</version>
    </dependency>
    <dependency>
      <groupId>com.fasterxml.jackson.core</groupId>
      <artifactId>jackson-annotations</artifactId>
      <version>2.8.5</version>
    </dependency>
    <dependency>
      <groupId>org.codehaus.jackson</groupId>
      <artifactId>jackson-mapper-asl</artifactId>
      <version>1.9.4</version>
    </dependency>
    <dependency>
      <groupId>net.sf.json-lib</groupId>
      <artifactId>json-lib</artifactId>
      <version>2.4</version>
      <classifier>jdk15</classifier>
    </dependency>
    <!-- commons -->
    <dependency>
      <groupId>commons-lang</groupId>
      <artifactId>commons-lang</artifactId>
      <version>2.4</version>
    </dependency>
    <dependency>
      <groupId>commons-logging</groupId>
      <artifactId>commons-logging</artifactId>
      <version>1.1</version>
    </dependency>
    <dependency>
      <groupId>commons-pool</groupId>
      <artifactId>commons-pool</artifactId>
      <version>1.5.6</version>
    </dependency>
    <dependency>
      <groupId>commons-dbcp</groupId>
      <artifactId>commons-dbcp</artifactId>
      <version>1.4</version>
    </dependency>
    <dependency>
      <groupId>commons-beanutils</groupId>
      <artifactId>commons-beanutils</artifactId>
      <version>1.8.3</version>
    </dependency>
    <dependency>
      <groupId>commons-httpclient</groupId>
      <artifactId>commons-httpclient</artifactId>
      <version>3.1</version>
    </dependency>
    <dependency>
      <groupId>commons-collections</groupId>
      <artifactId>commons-collections</artifactId>
      <version>3.1</version>
    </dependency>
    <dependency>
      <groupId>commons-codec</groupId>
      <artifactId>commons-codec</artifactId>
      <version>1.9</version>
    </dependency>
    <dependency>
      <groupId>javax.annotation</groupId>
      <artifactId>jsr250-api</artifactId>
      <version>1.0</version>
    </dependency>

    <dependency>
      <groupId>net.sf.ezmorph</groupId>
      <artifactId>ezmorph</artifactId>
      <version>1.0.6</version>
    </dependency>
    <dependency>
      <groupId>javax.activation</groupId>
      <artifactId>activation</artifactId>
      <version>1.1</version>
    </dependency>
    <dependency>
      <groupId>taglibs</groupId>
      <artifactId>standard</artifactId>
      <version>1.1.2</version>
    </dependency>
    <!-- 日誌檔案管理包 -->
    <!-- log start -->
    <dependency>
      <groupId>log4j</groupId>
      <artifactId>log4j</artifactId>
      <version>1.2.17</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-api</artifactId>
      <version>1.7.5</version>
    </dependency>
    <dependency>
      <groupId>org.slf4j</groupId>
      <artifactId>slf4j-log4j12</artifactId>
      <version>1.7.21</version>
    </dependency>
  </dependencies>
  <build>
    <finalName>helloworld</finalName>
    <plugins>
      <plugin>
        <groupId>org.mybatis.generator</groupId>
        <artifactId>mybatis-generator-maven-plugin</artifactId>
        <version>1.3.2</version>
        <configuration>
          <!--允許移動生成的檔案-->
          <verbose>true</verbose>
          <!--允許覆蓋生成的檔案-->
          <overwrite>true</overwrite>
        </configuration>
      </plugin>
    </plugins>
  </build>
</project>

3.2、jdbc.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/example?useUnicode=true&characterEncoding=utf-8
username=root
#下面輸入自己資料庫的密碼
password=輸入自己資料庫的密碼吧
#定義初始連線數
initialSize=0
#定義最大連線數
maxActive=20
#定義最大空閒
maxIdle=20
#定義最小空閒
minIdle=1
#定義最長等待時間
maxWait=60000

3.3、applicationContext.xml(配置spring)

<?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:context="http://www.springframework.org/schema/context"
       xmlns:beans="http://www.springframework.org/schema/beans"
       xmlns:mvc="http://www.springframework.org/schema/mvc"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
         http://www.springframework.org/schema/beans/spring-beans-4.3.xsd
         http://www.springframework.org/schema/context
         http://www.springframework.org/schema/context/spring-context-4.3.xsd
         http://www.springframework.org/schema/mvc
         http://www.springframework.org/schema/mvc/spring-mvc-4.3.xsd"  >

    <!-- ①:對com.springmvc包中的所有類進行掃描,以完成Bean建立和自動依賴注入的功能 -->
    <context:component-scan base-package="com.springmvc"/>
    <mvc:annotation-driven />
    <!-- 靜態資源訪問 -->
    <!--如果webapp下你新建了資料夾,想訪問裡面的靜態資源,那麼就要在這配置一下-->
    <mvc:resources location="/images/" mapping="/images/**"/>
    <mvc:resources location="/css/" mapping="/css/**"/>
    <mvc:resources location="/styles/" mapping="/styles/**"/>
    <mvc:resources location="/js/" mapping="/js/**"/>

    <!-- Configures the @Controller programming model
    <mvc:annotation-driven />-->
    <!-- ②:啟動Spring MVC的註解功能,完成請求和註解POJO的對映 -->
    <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
        <property name="messageConverters">
            <list>
                <ref bean="mappingJacksonHttpMessageConverter"/>
            </list>
        </property>
    </bean>

    <bean id="mappingJacksonHttpMessageConverter" class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
        <property name="supportedMediaTypes">
            <list>
                <value>application/json;charset=UTF-8</value>
            </list>
        </property>
    </bean>





    <!-- 配置檢視解析器,把控制器的邏輯視訊對映為真正的檢視 -->
    <!-- /WEB-INF/jsp/start.jsp -->
    <bean 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>




    <!-- 配置dbcp資料庫連線池 -->

    <!-- <context:property-placeholder location="classpath:db.properties"/> -->
    <!--資料庫配置 -->
    <bean id = "propertyConfigurer" class = "org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
        <property name="locations">
            <list>
                <value>classpath:jdbc.properties</value>
            </list>
        </property>

    </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="1"/>
        <property name="maxActive" value="100"/>
        <property name="maxIdle" value="5"/>
        <property name="maxWait" value="80000"/>
    </bean>


    <!-- 配置事務管理器 -->
    <bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
        <property name="dataSource" ref="dataSource" />
    </bean>


    <!-- 攔截器 -->
    <mvc:interceptors>
        <!-- 國際化操作攔截器 如果採用基於(請求/Session/Cookie)則必需配置 -->
        <bean class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor" />
    </mvc:interceptors>
    <!-- 定義無Controller的path<->view直接對映 -->
    <mvc:view-controller path="/" view-name="redirect:/" />
    <!-- 配置會話工廠SqlSessionFactory -->

    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
        <!-- 資料來源 -->
        <property name="dataSource" ref="dataSource"/>
        <property name="mapperLocations" value="classpath:sqlmap/*Mapper.xml"/>
        <property name="typeAliasesPackage" value="com.springmvc.entity" />

    </bean>

    <!-- 在spring容器中配置mapper的掃描器產生的動態代理物件在spring的容器中自動註冊,bean的id就是mapper類名(首字母小寫)-->
    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
        <!-- 指定掃描包的路徑,就是mapper介面的路徑,多個包中間以 半形逗號隔開   -->
        <property name="basePackage" value="com.springmvc.dao"/>
        <!-- 配置sqlSessionFactoryBeanName -->
        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>
    </bean>

</beans>

3.4、log4j.properties

### set log levels ###
log4j.rootLogger = INFO,D

###輸出到控制檯###
log4j.logger.toConsole=debug,stdout
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} [%5p] - %c -%F(%L) -%m%n

### 輸出到日誌檔案 ###
##  其中File 可以採用絕對路徑 亦可以採用相對路徑 catalina.home 是tomcat目錄  如果沒有logs資料夾 將會報錯  ##
##  更加傾向於將日誌檔案放在  tomcat的日誌目錄下${catalina.home}/logs/salesmanb2bError.log ##
##  絕對路徑如:e:/salesmanb2bError.log ##
log4j.logger.daily=INFO,D
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = ${catalina.home}/logs/helloworld/helloworld.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = INFO
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern =%d{yyyy-MM-dd HH\:mm\:ss} [%5p] - %c -%F(%L) -%m%n


##log4j.logger.org.apache.ibatis=debug,stdout
##log4j.logger.java.sql=debug,stdout

3.5、web.xml(在WEB-INF下)

<?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>helloworld</display-name>
  <!-- 配置編碼方式-->
  <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>
    <init-param>
      <param-name>forceEncoding<