【Java教程】SSM : 環境搭建

來源:互聯網
上載者:User

SSM 環境搭建

  1. 目錄建立

  2. pom.xml

  3. SSM 逐層配置

一、目錄

1.1 src/main/java 目錄下的包(以下包要放在項目包下,如:com.imooc.項目名)

  • entity: 存放實體類

  • web: 存放controller,相當於Struts中的action

  • service: 商務邏輯層 -> 內部再建立一個packeage .impl (eg:com.imooc.項目名.service.impl)

  • dao: 主要與資料庫打交道,檔案讀寫操作,Redis快取作業等與資料相關的操作。不用內建impl包,因為用的mybatis,在設定檔中實現介面的方法,就是在resources.mapper中,

  • dto: 主要彌補entity的不足,封裝一層

  • enums: 存放枚舉

  • interceptor: 攔截器

  • util: 通用的工具類存放

1.2 src/main/resources

  • mapper: 存放DAO中每個方法對應的SQL,不用去寫DAO的實作類別

  • spring: 存放spring的設定檔

1.3 src/test 存放測試

  • java

  • resources

二、pom.xml配置

jar包可以查詢:http://mvnrepository.com/

2.1 測試jar包

junit:指定範圍<scope>test</scope>

    <dependency>      <groupId>junit</groupId>      <artifactId>junit</artifactId>      <version>4.12</version>      <scope>test</scope>    </dependency>

2.2 日誌jar包

logback

    <dependency>      <groupId>ch.qos.logback</groupId>      <artifactId>logback-classic</artifactId>      <version>1.2.3</version>    </dependency>

2.3 Spring相關jar包

2.3.1 spring-core

Spring架構基本的核心工具類。Spring其他組件都要用到這個包裡的類,其他組件的基本核心

2.3.2 spring-beans

所有應用都要用到,包含訪問設定檔,建立和管理bean以及進行IOS/DI操作相關的所有類。類似Java的反射機制

如果應用只需基本的IOC/DI支援,引入spring-core.jar及spring-beans.jar檔案就可以了

2.3.3 spring-context

為Spring提供了大量擴充,可以找到使用Spring ApplicationContext特性所需的全部類,instrumentation組件以及校正validation方面的相關類

2.3.4 spring-jdbc

Spring對JDBC資料訪問進行封裝的所有類

2.3.5 spring-tx

為JDBC,Hibernate,JDO,JPA等提供一致的聲明式和編程式交易管理

2.3.6 spring-web

包含web應用開發時,用到Spring架構時所需的核心類,包括自動載入WebApplicationContext

2.3.7 spring-webmvc

包含SpringMVC架構相關的所有類,其中比較重要的類是dispatcher-servlet

2.3.8 spring-test

對JUNIT等測試架構的簡單封裝

指定範圍:<scope>test</scope>

2.4 引入與資料庫相關的jar包

2.4.1 mybatis

包含mybatis基礎的類庫

2.4.2 mybatis-spring

與Spring架構銜接的

2.4.3 mysql-connector-java

支援JDBC與MySQL的互動

2.4.4 c3p0

串連池

2.5 其他jar包

2.5.1 javax.servlet-api

提供servlet服務的

2.5.2 jackson-databind

用於解析JSON,

SpringMVC中Controller跟前端互動的時候,很多情況下都會用到JSON解析的

2.5.6 commons-collections

Map工具類,對JAVA collection的擴充
spring-core.jar需要commons-collections.jar提供基礎類的支援

2.6 完整的pom.xml需要修改的部分

建立maven項目的pom.xml檔案
① 填寫剛才說明需要的jar包依賴

<dependencies>    <dependency>      <groupId>junit</groupId>      <artifactId>junit</artifactId>      <version>4.12</version>      <scope>test</scope>    </dependency>    <!-- https://mvnrepository.com/artifact/ch.qos.logback/logback-classic -->    <dependency>      <groupId>ch.qos.logback</groupId>      <artifactId>logback-classic</artifactId>      <version>1.2.3</version>    </dependency>    <!-- Spring -->    <!-- 1)包含Spring 架構基本的核心工具類。Spring 其它組件要都要使用到這個包裡的類,是其它組件的基本核心 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-core</artifactId>      <version>${spring.version}</version>    </dependency>    <!-- 2)這個jar 檔案是所有應用都要用到的,它包含訪問設定檔、建立和管理bean 以及進行Inversion of Control        / Dependency Injection(IoC/DI)操作相關的所有類。如果應用只需基本的IoC/DI 支援,引入spring-core.jar        及spring-beans.jar 檔案就可以了。 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-beans</artifactId>      <version>${spring.version}</version>    </dependency>    <!-- 3)這個jar 檔案為Spring 核心提供了大量擴充。可以找到使用Spring ApplicationContext特性時所需的全部類,JDNI        所需的全部類,instrumentation組件以及校正Validation 方面的相關類。 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-context</artifactId>      <version>${spring.version}</version>    </dependency>    <!-- 4) 這個jar 檔案包含對Spring 對JDBC 資料訪問進行封裝的所有類。 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-jdbc</artifactId>      <version>${spring.version}</version>    </dependency>    <!-- 5) 為JDBC、Hibernate、JDO、JPA等提供的一致的聲明式和編程式交易管理。 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-tx</artifactId>      <version>${spring.version}</version>    </dependency>    <!-- 6)Spring web 包含Web應用開發時,用到Spring架構時所需的核心類,包括自動載入WebApplicationContext特性的類、Struts與JSF整合類、檔案上傳的支援類、Filter類和大量工具輔助類。 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-web</artifactId>      <version>${spring.version}</version>    </dependency>    <!-- 7)包含SpringMVC架構相關的所有類。 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-webmvc</artifactId>      <version>${spring.version}</version>    </dependency>    <!-- 8)Spring test 對JUNIT等測試架構的簡單封裝 -->    <dependency>      <groupId>org.springframework</groupId>      <artifactId>spring-test</artifactId>      <version>${spring.version}</version>      <scope>test</scope>    </dependency>    <!-- Servlet web -->    <dependency>      <groupId>javax.servlet</groupId>      <artifactId>javax.servlet-api</artifactId>      <version>3.1.0</version>    </dependency>    <!-- json解析 -->    <dependency>      <groupId>com.fasterxml.jackson.core</groupId>      <artifactId>jackson-databind</artifactId>      <version>2.8.7</version>    </dependency>    <!-- Map工具類 對標準java Collection的擴充 spring-core.jar需commons-collections.jar -->    <dependency>      <groupId>commons-collections</groupId>      <artifactId>commons-collections</artifactId>      <version>3.2</version>    </dependency>    <!-- DAO: MyBatis -->    <dependency>      <groupId>org.mybatis</groupId>      <artifactId>mybatis</artifactId>      <version>3.4.2</version>    </dependency>    <dependency>      <groupId>org.mybatis</groupId>      <artifactId>mybatis-spring</artifactId>      <version>1.3.1</version>    </dependency>    <!-- 資料庫 -->    <dependency>      <groupId>mysql</groupId>      <artifactId>mysql-connector-java</artifactId>      <version>5.1.37</version>    </dependency>    <dependency>      <groupId>c3p0</groupId>      <artifactId>c3p0</artifactId>      <version>0.9.1.2</version>    </dependency>    <!-- 圖片處理 -->    <!-- https://mvnrepository.com/artifact/net.coobird/thumbnailator -->    <dependency>      <groupId>net.coobird</groupId>      <artifactId>thumbnailator</artifactId>      <version>0.4.8</version>    </dependency>    <!-- https://mvnrepository.com/artifact/com.github.penggle/kaptcha -->    <dependency>      <groupId>com.github.penggle</groupId>      <artifactId>kaptcha</artifactId>      <version>2.3.2</version>    </dependency>    <dependency>      <groupId>commons-fileupload</groupId>      <artifactId>commons-fileupload</artifactId>      <version>1.3.2</version>    </dependency>    <!-- redis用戶端:Jedis -->    <dependency>      <groupId>redis.clients</groupId>      <artifactId>jedis</artifactId>      <version>2.9.0</version>    </dependency>  </dependencies>

② 填充spring.version聲明

  <properties>    <spring.version>4.3.7.RELEASE</spring.version>  </properties>
放在<dependencies>之前

三、SSM 逐層配置

  1. jdbc.properties

  2. mybatis-config.xml

  3. spring-dao.xml,spring-service.xml,spring-web.xml

  4. web.xml

3.1 jdbc.properties

資料庫設定檔建立在src/main/resources目錄下,檔案內容如下:

jdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://localhost:3306/{填寫項目名}?useUnicode=true&characterEncoding=utf8jdbc.username={databases的username}jdbc.password={databases的password}

暫時用明文寫帳號和密碼。

jdbc就會用到mysql.jdbc.Driver這個磁碟機去訪問jdbc.url的地址的資料庫,用username和password就能和MySQL串連了。

3.2 mybatis-config.xml

mybatis設定檔建立在src/main/resources目錄下,檔案內容如下:

<?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>        <!-- 使用jdbc的getGeneratedKeys擷取資料庫自增主索引值 -->        <setting name="useGeneratedKeys" value="true" />        <!-- 使用欄標籤替換列別名 預設:true -->        <setting name="useColumnLabel" value="true" />        <!-- 開啟駝峰命名轉換:Table{create_time} -> Entity{createTime} -->        <setting name="mapUnderscoreToCamelCase" value="true" />    </settings></configuration>

3.3 Spring相關配置

存放在 src/main/resources/spring 目錄

3.3.1 建立spring-dao.xml

  1. 讀取jdbd設定檔

  2. 資料庫連接池配置

  3. 建立資料庫連接池的對象 [注意裡面的包名修改]

  4. 配置需要到哪個包掃描DAO層,並將自動建立串連池的對象傳進去 [注意裡面的包名修改]

注意包名的填寫:我用中文寫了的位置,IDE會標紅
<?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"       xsi:schemaLocation="http://www.springframework.org/schema/beans    http://www.springframework.org/schema/beans/spring-beans.xsd    http://www.springframework.org/schema/context    http://www.springframework.org/schema/context/spring-context.xsd">    <!-- 配置整合mybatis過程 -->    <!-- 1.設定資料庫相關參數properties的屬性:${url} -->    <context:property-placeholder location="classpath:jdbc.properties"/>    <!-- 2.資料庫連接池 -->    <bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">        <!-- 配置串連池屬性 -->        <property name="driverClass" value="${jdbc.driver}" />        <property name="jdbcUrl" value="${jdbc.url}" />        <property name="user" value="${jdbc.username}" />        <property name="password" value="${jdbc.password}" />        <!-- c3p0串連池的私人屬性 -->        <property name="maxPoolSize" value="30" />        <property name="minPoolSize" value="10" />        <!-- 關閉串連後不自動commit -->        <property name="autoCommitOnClose" value="false" />        <!-- 擷取連線逾時時間 -->        <property name="checkoutTimeout" value="10000" />        <!-- 當擷取串連失敗重試次數 -->        <property name="acquireRetryAttempts" value="2" />    </bean>    <!-- 3.配置SqlSessionFactory對象 -->    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">        <!-- 注入資料庫連接池 -->        <property name="dataSource" ref="dataSource" />        <!-- 配置MyBaties全域設定檔:mybatis-config.xml -->        <property name="configLocation" value="classpath:mybatis-config.xml" />        <!-- 掃描entity包 使用別名 -->        <property name="typeAliasesPackage" value="{實體類包所在的位置}" />        <!-- 掃描sql設定檔:mapper需要的xml檔案 -->        <property name="mapperLocations" value="classpath:mapper/*.xml" />    </bean>    <!-- 4.配置掃描Dao介面包,動態實現Dao介面,注入到spring容器中 -->    <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">        <!-- 注入sqlSessionFactory -->        <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />        <!-- 給出需要掃描Dao介面包 -->        <property name="basePackage" value="{找到需要填寫的dao包}" />    </bean></beans>

3.3.2 spring-service.xml

  1. 掃描Service包下所有使用注釋的類型 [注意填寫包名]

  2. 配置交易管理員:多個DAO的協同操作,保證操作的原子性

  3. 配置基於註解的聲明式事務

<?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:tx="http://www.springframework.org/schema/tx"       xsi:schemaLocation="http://www.springframework.org/schema/beans    http://www.springframework.org/schema/beans/spring-beans.xsd    http://www.springframework.org/schema/context    http://www.springframework.org/schema/context/spring-context.xsd    http://www.springframework.org/schema/tx    http://www.springframework.org/schema/tx/spring-tx.xsd">    <!-- 掃描service包下所有使用註解的類型 -->    <context:component-scan base-package="{service包所在的目錄,如com.cat.o2o.service}" />    <!-- 配置交易管理員 -->    <bean id="transactionManager"          class="org.springframework.jdbc.datasource.DataSourceTransactionManager">        <!-- 注入資料庫連接池 -->        <property name="dataSource" ref="dataSource" />    </bean>    <!-- 配置基於註解的聲明式事務 -->    <tx:annotation-driven transaction-manager="transactionManager" /></beans>

3.3.3 spring-web.xml

  • 開啟Spring註解模式,自動實現Controller,不用做bean的配置

  • 靜態資源預設servlet配置,需要在webapp下建立resource目錄,圖片等靜態資源存放位置

  • 視圖解析器配置

  • 掃描controller所在的包[需要填寫你的controller所在的包]

檔案內容如下:

<?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:mvc="http://www.springframework.org/schema/mvc"       xsi:schemaLocation="http://www.springframework.org/schema/beans    http://www.springframework.org/schema/beans/spring-beans.xsd    http://www.springframework.org/schema/context    http://www.springframework.org/schema/context/spring-context.xsd    http://www.springframework.org/schema/mvc    http://www.springframework.org/schema/mvc/spring-mvc-3.2.xsd">    <!-- 配置SpringMVC -->    <!-- 1.開啟SpringMVC註解模式 -->    <mvc:annotation-driven />    <!-- 2.靜態資源預設servlet配置 (1)加入對靜態資源的處理:js,gif,png (2)允許使用"/"做整體映射 告知SpringMVC的核心類dispatcher-servlet不要對此攔截,交由預設的servlet-handler處理-->    <mvc:resources mapping="/resources/**" location="/resources/" />    <mvc:default-servlet-handler />    <!-- 3.定義視圖解析器 -->    <bean id="viewResolver"          class="org.springframework.web.servlet.view.InternalResourceViewResolver">        <property name="prefix" value="/WEB-INF/html/"></property>        <property name="suffix" value=".html"></property>    </bean>    <!-- 4.掃描web(放置controller的包)相關的bean -->    <context:component-scan base-package="需要修改的地方" /></beans>

3.4 配置web.xml

  • 配置index檔案,暫時預設即可

  • 配置SpringMVC的Servlet,注意填寫初始參數(指定目錄)

  • 配置Servlet-mapping,預設匹配所有的請求(url-pattern填寫/即可)

<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee                      http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"         version="3.1" metadata-complete="true">  <display-name>Archetype Created Web Application</display-name>  <welcome-file-list>    <welcome-file>index.jsp</welcome-file>  </welcome-file-list>  <servlet>    <servlet-name>spring-dispatcher</servlet-name>    <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>    <init-param>      <param-name>contextConfigLocation</param-name>      <param-value>classpath:spring/spring-*.xml</param-value>    </init-param>  </servlet>  <servlet-mapping>    <servlet-name>spring-dispatcher</servlet-name>    <!-- 預設匹配所有的請求 -->    <url-pattern>/</url-pattern>  </servlet-mapping></web-app>
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.