1. 程式人生 > >maven工程搭建ssm框架詳細開發流程

maven工程搭建ssm框架詳細開發流程

一.開啟eclipse建立maven工程 這裡不多說了 二.在pom.xml里加入jar包 注意不同版本之間的jar包可能會有衝突,也不要全都加最新版本的jar包,到時解決起來很麻煩 直接點選官網搜尋jar包名下載相應jar包 基本所需的jar包給大家發出來 1.spring webmvc 4.3.7 2.spring jdbc 4.3.7 3.spring aspects 4.3.7 4.c3p0 0.9.5.2 5.mybatis 3.4.6 6.mysql 5.1.45 7.jstl 1.2 8.servlet-api 3.1.0 9.mybatis-spring 1.3.2 框架整合 10.junit 4.12 測試 11.mybatis-generator1.3.5 逆向工程 12.pagehelper 5.1.7 分頁外掛 13.jackson 2.9.6 返回json物件 14.hibernate-validator 5.4.1 後端驗證 14.fileupload 1.3.1 檔案上傳 這裡把我的pom.xml發出來

<!-- spring-webmvc -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-webmvc</artifactId>
	    <version>4.3.7.RELEASE</version>
	</dependency>
  <!-- spring-jdbc -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-jdbc</artifactId>
	    <version>4.3.7.RELEASE</version>
	</dependency>
  <!-- spring-aspects -->
	<dependency>
	    <groupId>org.springframework</groupId>
	    <artifactId>spring-aspects</artifactId>
	    <version>4.3.7.RELEASE</version>
	</dependency>
  <!-- c3p0 -->
	<dependency>
	    <groupId>com.mchange</groupId>
	    <artifactId>c3p0</artifactId>
	    <version>0.9.5.2</version>
	</dependency>
  <!-- mybatis -->
	<dependency>
	    <groupId>org.mybatis</groupId>
	    <artifactId>mybatis</artifactId>
	    <version>3.4.6</version>
	</dependency>
  <!-- mysql-connector-java -->
	<dependency>
	    <groupId>mysql</groupId>
	    <artifactId>mysql-connector-java</artifactId>
	    <version>5.1.45</version>
	</dependency>
  <!-- jstl -->
	<dependency>
	    <groupId>javax.servlet</groupId>
	    <artifactId>jstl</artifactId>
	    <version>1.2</version>
	</dependency>
  <!-- javax.servlet-api -->
	<dependency>
	    <groupId>javax.servlet</groupId>
	    <artifactId>javax.servlet-api</artifactId>
	    <version>3.1.0</version>
	    <scope>provided</scope>
	</dependency>
  <!-- mybatis-spring -->
	<dependency>
	    <groupId>org.mybatis</groupId>
	    <artifactId>mybatis-spring</artifactId>
	    <version>1.3.2</version>
	</dependency>
  <!-- junit -->
	<dependency>
	    <groupId>junit</groupId>
	    <artifactId>junit</artifactId>
	    <version>4.12</version>
	    <scope>test</scope>
	</dependency>
  <!-- mybatis-generator-core -->
	<dependency>
	    <groupId>org.mybatis.generator</groupId>
	    <artifactId>mybatis-generator-core</artifactId>
	    <version>1.3.5</version>
	</dependency>
  <!-- pagehelper -->
	<dependency>
	    <groupId>com.github.pagehelper</groupId>
	    <artifactId>pagehelper</artifactId>
	    <version>5.1.7</version>
	</dependency>
  <!-- jackson-databind -->
	<dependency>
	    <groupId>com.fasterxml.jackson.core</groupId>
	    <artifactId>jackson-databind</artifactId>
	    <version>2.9.6</version>
	</dependency>
  <!-- hibernate-validator -->
	<dependency>
	    <groupId>org.hibernate</groupId>
	    <artifactId>hibernate-validator</artifactId>
	    <version>5.4.1.Final</version>
	</dependency>
  <!-- commons-fileupload -->
	<dependency>
	    <groupId>commons-fileupload</groupId>
	    <artifactId>commons-fileupload</artifactId>
	    <version>1.3.1</version>
	</dependency>

三.配置檔案 springmvc的配置檔案 springMVC-servlet.xml 1.包掃描(只包含controller層) 2.靜態資源的處理方式 3.提供一些高階功能 4.檢視解析器

 <!-- 包掃描(只包含controller) -->
	<context:component-scan base-package="com.zhiyou.bg.controller">
		<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
	</context:component-scan>
	<!-- 靜態資源處理方式 -->
	<mvc:default-servlet-handler/>
	<!-- 高階功能 -->
	<mvc:annotation-driven></mvc:annotation-driven>
	<!-- 註冊攔截器 -->
	<mvc:interceptors>
		<mvc:interceptor>
			<mvc:mapping path="/**"/><!-- 過濾所有 -->
			<mvc:exclude-mapping path="/adminLogin"/><!-- 不過濾登入 -->
			<mvc:exclude-mapping path="/**/*.js"/><!-- 不過濾靜態資源 -->
			<mvc:exclude-mapping path="/**/*.css"/> 
			<bean class="com.zhiyou.bg.interceptor.LoginInterceptor"></bean>
		</mvc:interceptor>
	</mvc:interceptors>
	<!-- 檢視解析器 -->
	<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
		<property name="prefix" value="/WEB-INF/"></property>
		<property name="suffix" value=".jsp"></property>
	</bean>

spring的配置檔案 application.xml 1引入屬性檔案 2.包掃描(排除controller層) 3.配置資料來源 4.配置SqlSessionFactory 5.配置mybatis介面的掃描 6.配置事物管理類 7.配置意見 8.配置切面 9.配置檔案上傳

<!-- 屬性檔案 -->
	<context:property-placeholder location="classpath:db.properties" />
	<!-- 包掃描 -->
	<context:component-scan base-package="com.zhiyou.bg">
		<!-- 排除controller層 -->
		<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
	</context:component-scan>
	<!-- 資料來源 -->
	<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
		<property name="user" value="${jdbc.user}"></property>
		<property name="password" value="${jdbc.password}"></property>
		<property name="jdbcUrl" value="${jdbc.url}"></property>
		<property name="driverClass" value="${jdbc.driver}"></property>
	</bean>
	<!-- 配置sqlSessionFectoryBean -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource"></property>
<!-- 	<property name="configLocation" value="classpath:mybatis.xml"></property> -->
 		<property name="mapperLocations" value="classpath:com/zhiyou/bg/mapper/*.xml"></property>
		<property name="plugins">
		    <array>
		      <bean class="com.github.pagehelper.PageInterceptor">
		        <property name="properties">
		          <!--使用下面的方式配置引數,一行配置一個 -->
		          <value>reasonable=true</value>
		        </property>
		      </bean>
		    </array>
		  </property>
	</bean>
	<!-- mybatis介面的掃描 -->
	<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
		<property name="basePackage" value="com.zhiyou.bg.dao"></property>
	</bean>
	<!-- 配置事務管理類 -->
	<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
		<property name="dataSource" ref="dataSource"></property>
	</bean>
	<!-- 配置意見 -->
	<tx:advice id="advice" transaction-manager="transactionManager">
		<tx:attributes>
			<tx:method name="query*" read-only="true"/>
			<tx:method name="*"/>
		</tx:attributes>
	</tx:advice>
	<!-- 切面 -->
	<aop:config>
		<aop:pointcut expression="execution(* com.zhiyou.bg.*.*(..))" id="pointcut"/>
		<aop:advisor advice-ref="advice" pointcut-ref="pointcut"/>
	</aop:config>

該配置檔案裡的<property name="configLocation" value="classpath:mybatis.xml"></property>是引用mybatis的配置檔案,mybatis的配置基本上都能在該配置檔案裡寫全,所以不需要再寫mybatis的配置檔案. 該配置檔案裡的

<property name="plugins">
		    <array>
		      <bean class="com.github.pagehelper.PageInterceptor">
		        <property name="properties">
		          <!--使用下面的方式配置引數,一行配置一個 -->
		          <value>reasonable=true</value>
		        </property>
		      </bean>
		    </array>
  </property>

是設定pagehelper分頁外掛的

屬性檔案 db.properties

jdbc.user=root
jdbc.password=root
jdbc.url=jdbc:mysql://localhost:3306/crowdfunding?characterEncoding=utf-8
jdbc.driver=com.mysql.jdbc.Driver

以上三個檔案全部放在src/main/resources目錄下 三.web.xml 1.配置編碼的過濾器 2.DispatcherServlet配置springMvc 3. 配置spring啟動的listener

 <!-- 配置編碼的過濾器 -->
	  <filter>
	  	<filter-name>encoding</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>encoding</filter-name>
	  	<url-pattern>/*</url-pattern>
	  </filter-mapping>
	  
	  <!-- 配置springMVC -->
	<servlet>
		<servlet-name>springDispatcherServlet</servlet-name>
		<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
		<init-param>
			<param-name>contextConfigLocation</param-name>
			<param-value>classpath:springMvc-servlet.xml</param-value>
		</init-param>
		<load-on-startup>1</load-on-startup>
	</servlet>
	<servlet-mapping>
		<servlet-name>springDispatcherServlet</servlet-name>
		<url-pattern>/</url-pattern>
	</servlet-mapping>
	
	<!-- 配置spring啟動的listener -->
	<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>

四.逆向工程 1.配置檔案 mybatisGenerator.xml 2.測試驅動 該配置檔案直接建在工程下,與pom.xml同級

<generatorConfiguration>
  <classPathEntry location="D:\ziliao\mysql-connector-java-5.1.45.jar" />

  <context id="DB2Tables" targetRuntime="MyBatis3">
  	<!-- 去掉註釋 -->
  	<commentGenerator>
  		<property name="suppressAllComments" value="true" />
	</commentGenerator>
  	<!-- 資料庫資訊源 -->
    <jdbcConnection driverClass="com.mysql.jdbc.Driver"
        connectionURL="jdbc:mysql://localhost:3306/ssm"
        userId="root"
        password="root">
    </jdbcConnection>

    <javaTypeResolver >
      <property name="forceBigDecimals" value="false" />
    </javaTypeResolver>

    <javaModelGenerator targetPackage="com.zhiyou.lsh.bean" targetProject=".\src\main\java">
      <property name="enableSubPackages" value="true" />
      <property name="trimStrings" value="true" />
    </javaModelGenerator>

    <sqlMapGenerator targetPackage="com.zhiyou.lsh.mapper"  targetProject=".\src\main\java">
      <property name="enableSubPackages" value="true" />
    </sqlMapGenerator>

    <javaClientGenerator type="XMLMAPPER" targetPackage="com.zhiyou.lsh.dao"  targetProject=".\src\main\java">
      <property name="enableSubPackages" value="true" />
    </javaClientGenerator>

    <table tableName="emp" domainObjectName="Emp" >
      <property name="useActualColumnNames" value="true"/>
      <generatedKey column="ID" sqlStatement="DB2" identity="true" />
      <columnOverride column="DATE_FIELD" property="startDate" />
      <ignoreColumn column="FRED" />
      <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" />
    </table>
    <table tableName="dept" domainObjectName="Dept" >
      <property name="useActualColumnNames" value="true"/>
      <generatedKey column="ID" sqlStatement="DB2" identity="true" />
      <columnOverride column="DATE_FIELD" property="startDate" />
      <ignoreColumn column="FRED" />
      <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" />
    </table>

  </context>
</generatorConfiguration>

寫我們的測試類來驅動生成

public class Test1 {
	public static void main(String[] args) throws Exception{
		List<String> warnings = new ArrayList<String>();
		boolean overwrite = true;
		File configFile = new File("mybatisGenerator.xml");
		ConfigurationParser cp = new ConfigurationParser(warnings);
		Configuration config = cp.parseConfiguration(configFile);
		DefaultShellCallback callback = new DefaultShellCallback(overwrite);
		MyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);
		myBatisGenerator.generate(null);	
	}
}

五. 在dao層和mapper對映中,增加自己想要的方法 mybatis是沒有連結串列查詢的,我們可以自己增加自己想要的連結串列查詢sql語句或者其他 六. service層編寫介面和介面實現類,編寫自己的方法來呼叫dao層的方法 然後可以先寫測試類來測試我們service層的方法是否可行 七. 再通過controller層編寫自己的方法來呼叫service層的方法並連線到jsp頁面 八. 最後編寫我們的jsp頁面