從零開始寫專案第一篇【搭建環境】
使用Maven搭建SSM環境
SSM需要的基礎jar包有哪些??整理一下:
c3p0資料連線池
springMVC的JSON
springAOP
springCore
springPersitence
springWeb
myBatis
myBatisSpring
mysql
mybatis逆向工程外掛
2017/10/24 16:00:31
我去的是:這個網站中找jar包,大多數使用最新的jar包
本來是使用spring5來進行整合的,結果與asm衝突了,網上又沒什麼解決方案。
最後妥協了改成3.2.2
pom.xml檔案配置
pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns=" xmlns:xsi="
xsi:schemaLocation=" >
<modelVersion>4.0.0</modelVersion>
<packaging>war</packaging>
<name>fuchengWeb</name>
<groupId>fuchengWeb</groupId>
<artifactId>fuchengWeb</artifactId>
<version>1.0-SNAPSHOT</version>
<!--逆向工程外掛-->
<build>
<finalName>zhongfucheng</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>
<dependencies>
<!--c3p0-->
<dependency>
<groupId>c3p0</groupId>
<artifactId>c3p0</artifactId>
<version>0.9.1.2</version>
</dependency>
<!--json-->
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-asl</artifactId>
<version>1.9.13</version>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>
<!--mybatis-spring-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.3.1</version>
</dependency>
<!--mysql-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.34</version>
</dependency>
<!--spring aop-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.11</version>
</dependency>
<dependency>
<groupId>org.aopalliance</groupId>
<artifactId>com.springsource.org.aopalliance</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>net.sourceforge.cglib</groupId>
<artifactId>com.springsource.net.sf.cglib</artifactId>
<version>2.1.3</version>
</dependency>
<!--spring-core-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>com.springsource.org.apache.commons.logging</artifactId>
<version>1.1.1</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>3.2.2.RELEASE</version>
<scope>test</scope>
</dependency>
<!--spring-persitence-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>org.springframework.transaction</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<!--spring-web-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>3.2.2.RELEASE</version>
</dependency>
<!--mybatis-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.4.5</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.25</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>1.7.25</version>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>org.javassist</groupId>
<artifactId>javassist</artifactId>
<version>3.22.0-CR2</version>
</dependency>
<dependency>
<groupId>cglib</groupId>
<artifactId>cglib</artifactId>
<version>3.2.5</version>
</dependency>
<dependency>
<groupId>org.objectweb.asm</groupId>
<artifactId>com.springsource.org.objectweb.asm</artifactId>
<version>2.2.3</version>
</dependency>
</dependencies>
</project>
如果覺得下載太慢的話,我們可以使用阿里雲的私服。只要在settings下配置如下程式碼即可:
<mirror>
<id>nexus-aliyun</id>
<mirrorOf>*</mirrorOf>
<name>Nexus aliyun</name>
<url></url>
</mirror>
建立mysql使用者和資料庫
mysql使用者:
使用者名稱:xxxx
密碼:xxxx
資料庫:
xxxx
mybatis配置檔案
myBatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"
<configuration>
<!-- 透過別名簡化對類的使用 -->
<typeAliases>
<package name="zhongfucheng.entity"/>
</typeAliases>
</configuration>
application-context配置檔案
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="
xmlns:xsi=" xmlns:tx="
xmlns:aop="
xmlns:context="
xsi:schemaLocation="
/spring-beans-3.2.xsd
/spring-context-3.2.xsd
/spring-tx-3.2.xsd
/spring-aop-3.2.xsd">
<!--配置資料來源-->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"/>
<property name="jdbcUrl"
value="jdbc:mysql://localhost:3306/xxxx?useUnicode=true&characterEncoding=UTF-8"/>
<property name="user" value="xxxx"/>
<property name="password" value="xxxx"/>
</bean>
<!-- 配置session工廠,載入mybatis配置檔案 -->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="configLocation" value="classpath:myBatis-config.xml"/>
<!--配置掃描式載入SQL對映檔案,那麼在mybatis配置檔案中就不用載入了-->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
</bean>
<!-- 配置事務管理器,管理資料來源事務處理 -->
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!-- 配置事務通知 -->
<tx:advice id="advice" transaction-manager="transactionManager">
<tx:attributes>
<!-- 預設只處理執行時異常,可加rollback-for="Exception/Throwable"等處理所有異常或包括錯誤 -->
<tx:method name="insert*" propagation="REQUIRED"
rollback-for="Exception"/>
<tx:method name="update*" propagation="REQUIRED"
rollback-for="Exception"/>
<tx:method name="delete*" propagation="REQUIRED"
rollback-for="Exception"/>
<tx:method name="*" propagation="SUPPORTS"/>
</tx:attributes>
</tx:advice>
<!-- 配置切面織入的範圍,後邊要把事務邊界定在service層 -->
<aop:config>
<aop:advisor advice-ref="advice"
pointcut="execution(* zhongfucheng.service.impl.*.*(..))"/>
</aop:config>
<!-- 配置SessionTemplate,已封裝了繁瑣的資料操作,提交事務都不用做了。 -->
<bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate">
<constructor-arg name="sqlSessionFactory" ref="sqlSessionFactory"/>
</bean>
<!-- 自動掃描元件,要把controller去除,他們是在spring-mvc.xml中配置,如果不去除會影響事務管理。 -->
<context:component-scan base-package="zhongfucheng">
<context:exclude-filter type="annotation"
expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
<!--使用Mapper代理-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory" />
<property name="basePackage" value="zhongfucheng.dao" />
</bean>
</beans>
配置spring-mvc
spring-mvc.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="
xmlns:xsi="
xmlns:mvc="
xmlns:context="
xmlns:p="
xsi:schemaLocation=" /spring-beans-3.2.xsd
/spring-context-3.2.xsd
/spring-mvc-3.2.xsd
">
<!-- 同時開啟json格式的支援 -->
<mvc:annotation-driven></mvc:annotation-driven>
<!-- 掃描所有的controller 但是不掃描service -->
<context:component-scan base-package="zhongfucheng">
<context:include-filter type="annotation"
expression="org.springframework.stereotype.Controller" />
<context:exclude-filter type="annotation"
expression="org.springframework.stereotype.Service" />
</context:component-scan>
<!--檢視解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
</beans>
逆向生成的配置檔案
generatorConfig.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE generatorConfiguration PUBLIC
"-//mybatis.org//DTD MyBatis Generator Configuration
1.0//EN"
"
>
<generatorConfiguration>
<!-- 制定mysql的驅動包的路徑 千萬別放中文路徑下 -->
<classPathEntry
location="X:\Users\ozc\Desktop\zhongfuchengWeb\mysql\mysql-connector-java\5.1.34\mysql-connector-java-5.1.34.jar"/>
<!-- 配置資料來源和生成的程式碼所存放的位置 -->
<context id="context1">
<commentGenerator>
<!-- 是否取消註釋 -->
<property name="suppressAllComments" value="true"/>
<!-- 是否生成註釋代時間戳 -->
<property name="suppressDate" value="true"/>
</commentGenerator>
<jdbcConnection driverClass="com.mysql.jdbc.Driver"
connectionURL="jdbc:mysql://localhost:3306/zhongfucheng" userId="zhongfucheng"
password="zhong"/>
<!-- 所生成的實體類的位置預設資源包src -->
<javaModelGenerator targetPackage="zhongfucheng.entity" targetProject="src/main/java"/>
<!-- 所生成的sqlMap的影射檔案的位置,預設資源包src -->
<sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"/>
<!-- 配置dao介面生成資訊-->
<javaClientGenerator type="XMLMAPPER" targetPackage="zhongfucheng.dao" targetProject="src/main/java"/>
<!-- 為哪些表生成程式碼 tableName:表名 schema:不用填寫 -->
<table schema="" tableName="EB_ORDER_DETAIL" enableCountByExample="false"
enableUpdateByExample="false" enableDeleteByExample="false"
enableSelectByExample="false" selectByExampleQueryId="false"
>
</table>
</context>
</generatorConfiguration>
web.xml配置
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="
xmlns:xsi="
xsi:schemaLocation=" /web-app_2_4.xsd">
<!--Spring監聽器-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicatoin-context.xml</param-value>
</context-param>
<!--springMVC核心分配器-->
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<!--中文亂碼過濾器-->
<filter>
<filter-name>SpringCharacterEncodingFilter</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>SpringCharacterEncodingFilter</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
</web-app>
log4j配置檔案
log4j.properties
# Rules reminder:
# DEBUG < INFO < WARN < ERROR < FATAL
# Global logging configuration
log4j.rootLogger=debug,stdout
# My logging configuration...
log4j.logger.cn.jbit.mybatisdemo=DEBUG
## Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p %d %C: %m%n
log4j.logger.org.apache.ibatis=DEBUG
## log4j.logger.org.apache.jdbc.SimpleDataSource=DEBUG
log4j.logger.org.apache.ibatis.jdbc.ScriptRunner=DEBUG
## log4j.logger.com.ibatis.sqlmap.engine.impl.SqlMapclientDelegate=DEBUG
log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG
測試逆向工程
不知道是不是我的mysql驅動包太高了,出現瞭如下的問題:
The server time zone value '�й���ʱ��' is unrecognized or represents more than one time zone.
於是乎我就去找到了解決方案,只要在url後面加上時區就好了:
jdbc:mysql://localhost:3306/zhongfucheng?serverTimezone=UTC
隨後又出現了下面的問題:
Column name pattern can not be NULL or empty
找到的解決方案,又是往後面加引數:
jdbc:mysql://localhost:3306/zhongfucheng?serverTimezone=UTC&useSSL=false&nullNamePatternMatchesAll=true
最終就成功了…
…還有問題:在剛開始的時候沒注意到:Mybatis Generator 生成的mapper只有insert方法
連結:http://blog.csdn.net/qq_15127715/article/details/78139228
又去查了一大堆的資料,發現還是因為mysql的驅動包太高的問題。只能往下轉了。
Failed to read candidate component class錯誤分析:
spring 3.2不支援1.8編譯環境,解決辦法就是降為1.7編譯環境
解決連線:http://www.cnblogs.com/cxj20160928/p/5954336.html
編寫BaseMapper
/**
* 將通用的方法抽取在BaseMapper中,那麼就不用在每個單獨的Mapper都要寫對應的方法了。
* @param <T>
*/
public interface BaseMapper<T> {
int insert(T entity);
int insertSelective(T entity);
int deleteByPrimaryKey(String id);
T selectByPrimaryKey(String id);
int updateByPrimaryKeySelective(T entity);
int updateByPrimaryKey(T entity);
}
編寫BaseService
/**
* 將通用的業務方法抽取到BaseService中,那麼實現它的Service都有這些方法了。
* @param <T>
*/
public interface BaseService<T> {
int insert(T entity);
int insertSelective(T entity);
int deleteByPrimaryKey(String id);
T selectByPrimaryKey(String id);
int updateByPrimaryKeySelective(T entity);
int updateByPrimaryKey(T entity);
}
BaseServiceImpl
/**
* 使用initBaseMapper()將baseMapper例項化,service實現類是什麼型別,baseMapper就是什麼型別
* 將所有的Mapper都定義出來,那麼子類service就可以直接使用了
* @param <T>
*/
public class BaseServiceImpl<T> implements BaseService<T> {
protected BaseMapper<T> baseMapper;
@Autowired
protected StoreHouseMapper storeHouseMapper;
@PostConstruct
private void initBaseMapper() throws Exception{
//獲取泛型的資訊
ParameterizedType type =(ParameterizedType) this.getClass().getGenericSuperclass();
Class clazz = (Class)type.getActualTypeArguments()[0];
//拼接成“泛型”Mapper字串
String localField = clazz.getSimpleName().substring(0,1).toLowerCase()+clazz.getSimpleName().substring(1)+"Mapper";
//透過反射來獲取成員變數的值
Field field=this.getClass().getSuperclass().getDeclaredField(localField);
Field baseField = this.getClass().getSuperclass().getDeclaredField("baseMapper");
//將baseDao來進行例項化
baseField.set(this, field.get(this));
System.out.println("------this:" + this);
System.out.println("------baseMapper:" + baseMapper);
}
public int insert(T entity) {
return baseMapper.insert(entity);
}
public int insertSelective(T entity) {
return baseMapper.insertSelective(entity);
}
public int deleteByPrimaryKey(String id) {
return baseMapper.deleteByPrimaryKey(id);
}
public T selectByPrimaryKey(String id) {
return baseMapper.selectByPrimaryKey(id);
}
public int updateByPrimaryKeySelective(T entity) {
return baseMapper.updateByPrimaryKeySelective(entity);
}
public int updateByPrimaryKey(T entity) {
return baseMapper.updateByPrimaryKey(entity);
}
}
測試Spring和Mybatis是否整合完成
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"/application-context.xml"})
public class TestSpringAndMybatis {
@Autowired
private StoreHouseService hoseService;
@Test
public void add() {
StoreHouse storeHouse = hoseService.selectByPrimaryKey("1");
System.out.println(storeHouse);
}
}
編寫BaseAction
/**
* 將所有的service實現都定義出來,controller子類使用的使用就不需要定義了。
*/
public class BaseController {
@Autowired
protected StoreHouseService storeHoseService;
}
StoreHouseController
@Controller
@RequestMapping("/store")
public class StoreHouseController extends BaseController {
@RequestMapping("/getById.do")
public void getById(String id ) {
StoreHouse storeHouse = storeHoseService.selectByPrimaryKey(id);
System.out.println(storeHouse);
}
}
測試spring-mvc
在測試的時候出現了: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found)
的異常。
上網上檢視之後,****。因此我就將StoreHouseMapper.xml放到resouces下了。
同時,我們的application-context.xml載入配置檔案和generator.xml逆向配置檔案的位置也要修改。
說要把生成出來的mapper.xml放在resouces目錄下才能識別出來
<!--配置掃描式載入SQL對映檔案,那麼在mybatis配置檔案中就不用載入了-->
<property name="mapperLocations" value="classpath:mapper/*.xml"/>
<!-- 所生成的sqlMap的影射檔案的位置,預設資源包src -->
<sqlMapGenerator targetPackage="mapper" targetProject="src/main/resources"/>
測試JSON
測試程式碼:
@RequestMapping("/getById.do")
@ResponseBody
public Object getById(String id ) {
StoreHouse storeHouse = storeHoseService.selectByPrimaryKey(id);
System.out.println(storeHouse);
return storeHouse;
}
開發環境總結
到目前為止、SSM已整合完成。
建立web常用的目錄結構。
Intellij idea
Spring 3.2.2
Mybatis3.4.5
mysql 5.1.34
Tomcat 7.0
jdk1.7
花了一個晚上總結出:不能太裝逼去玩新的jar包、資料太少了,非常容易出錯!
想用新版本的jar包遇到了很多的麻煩
使用spring5.0與asm發生衝突,無法啟動Tomcat,降為3.2.2
使用Mysql 6.0在逆向工程的時候出現時區、無法建立表的問題,經過一輪解決,最後生成的SqlMapper只有insert語句。隨後降為5.1.34
使用JDK1.8有提示過時的錯誤,後來在pom加入一段配置解決。
在初始化Spring容器的時候,無法建立物件。Spring3.2.2與JDK1.8發生衝突。隨後降為JDK1.7
在Intellij idea降JDK版本需要指定4個部分,詳情可參見上面的連線。
如果文章有錯的地方歡迎指正,大家互相交流。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69900354/viewspace-2285628/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- VUE從零開始環境搭建Vue
- 從零開始搭建本地 Docker 開發環境Docker開發環境
- 從零開始搭建webpack+react開發環境WebReact開發環境
- 從零開始搭建一個vue專案Vue
- 從零開始使用 Webpack 搭建 Vue3 開發環境WebVue開發環境
- 【Java EE】從零開始寫專案【總結】Java
- M1版Mac從零開始搭建Golang開發環境MacGolang開發環境
- 從零開始搭建一個 Webpack 開發環境配置(附 Demo)Web開發環境
- 從零開始搭建Java開發環境第一篇:Java工程師必備軟體大合集Java開發環境工程師
- 從零開始使用 webpack5 搭建 react 專案WebReact
- 從0開始搭建preact開發環境React開發環境
- 從零開始react實戰:雲書籤-1 react環境搭建React
- 從零搭建嵌入式開發環境開發環境
- 從零開始實踐大模型 - 配置環境大模型
- django專案開發環境搭建Django開發環境
- 從零開始配置基本的前端開發環境(windows)前端開發環境Windows
- 從零搭建Golang開發環境--go修仙序章Golang開發環境
- 手把手教你從零開始搭建SpringBoot後端專案框架Spring Boot後端框架
- 從零開始React:一檔 React環境搭建,語法規則,基礎使用React
- 學習Vue3.0,先從搭建環境開始Vue
- Vue搭建專案環境Vue
- 從零開始仿寫一個抖音App——跨平臺影片編輯SDK專案搭建APP
- 從零開始的爬蟲專案(一)爬蟲
- 從零開始React專案架構(六)React架構
- 從零開始React專案架構(五)React架構
- 從零開始React專案架構(三)React架構
- 從零開始React專案架構(一)React架構
- 從零開始React專案架構(二)React架構
- 從零開始React專案架構(四)React架構
- Opencl從零實戰(一)--windows搭建開發環境Windows開發環境
- PHP開發環境 03 - 使用KFKDock搭建PHP專案環境PHP開發環境
- 從零開始 Mask RCNN 實戰:基於 Win10 的 Mask RCNN 環境搭建CNNWin10
- vuePress從零開始搭建自己專屬的文件集合Vue
- 從零開始寫 Docker(十五)---實現 mydocker run -e 支援環境變數傳遞Docker變數
- 從零開始仿寫一個抖音App——跨平臺視訊編輯SDK專案搭建APP
- [ 從零開始配置一個 Windows 前端開發環境 ] - 二:vscodeWindows前端開發環境VSCode
- 從零搭建前端開發環境----React+Ts+Webpack基礎搭建前端開發環境ReactWeb
- 原生專案如何從零開始整合 React NativeReact Native