使用maven已经有一段时间了,但项目是别人搭建好的,因此一直想着自己要学习搭建一下。网上找了些资料后,结合自己实验,花了点时间就搞好,老样子,写在博客上,免得日后忘记。


博文中的代码:链接:http://pan.baidu.com/s/1o7F6qEY 密码:rqd1


1.安装maven和配置

1、下载maven.apache.org/download.html,下载apache-maven-3.1.1-bin.zip,**-src.zip为Maven的源码

2、配置环境变量,打开系统环境变量新建一个M2_HOME将解压后的Maven存放路径放在此,然后在path路径下加

入史%M2_HOME%\bin路径

3、检测是否配置成功,打开命令行输入echo %M2_HOME%查看M2_HOME指向的Maven存放安装目录是否正

确,输入mvn -v查看是否能找到正确的mvn执行脚本

4、以后升级的话将M2_HOME的路径换为最新的安装目录就行

5、Maven实践:初次安装完后输入mvn help:system的命令,此时会打印出所有的Java系统属性和环境变量,然后

Maven会执行一个真正的任务将相应的所需的构件下载到本地仓库中包括pom和jar文件,然后用户在

C:\Users\Administrator\.m2下就能看到本地仓库了

6、用户需要复制M2_HOME/conf/setting.xml文件到C:/Users/Administrator/.m2/setting.xml,这样用户每次升

级后就不要在次修改setting.xml文件了

2.MyEclipse配置Maven

1、在本地创建一个文件夹MavenRepository,并在MavenRepository文件夹下创建文件夹repo。

2、进入Maven解压后的文件夹,进入conf文件夹,将settings.xml文件复制到上一步创建的MavenRepository文件

夹下

3、打开MavenRepository文件夹下的settings.xml文件,找到localRepository标签,此时是被注释掉的,我们解除

注释,然后配置步骤1中的repo路径,如<localRepository>E:\MavenRepository\repo</localRepository>

4、在MyEclipse中的Perferences进行如下配置,添加自己的Maven

5、User Settings设置为之前修改过的setting.xml

6、File->New->others,搜索maven,如果看到有Maven Project则代表配置成功。

3.MyEclipse使用maven创建web项目


1、创建一个maven项目

2、按照上面教程,即可创建出一个Maven项目,项目结构如下图

3、将JRE版本设置为1.7,可使用默认的或者自己导入

4、此时index.jsp会报以下错误

在pom.xml文件的dependencies节点下添加如下代码即可,添加完后,会下载对应的jar包

5、右键项目,选择Properties,进行如下配置

4.搭建Spring+SpringMVC+Mybatis框架


1、Maven引入项目用到的jar包,修改pom.xml后保存会自动下载,存放在之前配置的本地仓库中,即:

E:\MavenRepository\repo文件夹

pom.xml
[html] view plain copy print?
  1. <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  2. xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
  3. <modelVersion>4.0.0</modelVersion>
  4. <groupId>com.chillax</groupId>
  5. <artifactId>Maven_Project</artifactId>
  6. <packaging>war</packaging>
  7. <version>0.0.1-SNAPSHOT</version>
  8. <name>Maven_Project Maven Webapp</name>
  9. <url>http://maven.apache.org</url>
  10. <!-- 用来设置版本号 -->
  11. <properties>
  12. <srping.version>4.0.2.RELEASE</srping.version>
  13. <mybatis.version>3.2.8</mybatis.version>
  14. <slf4j.version>1.7.12</slf4j.version>
  15. <log4j.version>1.2.17</log4j.version>
  16. </properties>
  17. <!-- 用到的jar包 -->
  18. <dependencies>
  19. <!-- 单元测试 -->
  20. <dependency>
  21. <groupId>junit</groupId>
  22. <artifactId>junit</artifactId>
  23. <version>4.11</version>
  24. <!-- 表示开发的时候引入,发布的时候不会加载此包 -->
  25. <scope>test</scope>
  26. </dependency>
  27. <!-- java ee包 -->
  28. <dependency>
  29. <groupId>javax</groupId>
  30. <artifactId>javaee-api</artifactId>
  31. <version>7.0</version>
  32. </dependency>
  33. <!-- spring框架包 start -->
  34. <dependency>
  35. <groupId>org.springframework</groupId>
  36. <artifactId>spring-test</artifactId>
  37. <version>${srping.version}</version>
  38. </dependency>
  39. <dependency>
  40. <groupId>org.springframework</groupId>
  41. <artifactId>spring-core</artifactId>
  42. <version>${srping.version}</version>
  43. </dependency>
  44. <dependency>
  45. <groupId>org.springframework</groupId>
  46. <artifactId>spring-oxm</artifactId>
  47. <version>${srping.version}</version>
  48. </dependency>
  49. <dependency>
  50. <groupId>org.springframework</groupId>
  51. <artifactId>spring-tx</artifactId>
  52. <version>${srping.version}</version>
  53. </dependency>
  54. <dependency>
  55. <groupId>org.springframework</groupId>
  56. <artifactId>spring-jdbc</artifactId>
  57. <version>${srping.version}</version>
  58. </dependency>
  59. <dependency>
  60. <groupId>org.springframework</groupId>
  61. <artifactId>spring-aop</artifactId>
  62. <version>${srping.version}</version>
  63. </dependency>
  64. <dependency>
  65. <groupId>org.springframework</groupId>
  66. <artifactId>spring-context</artifactId>
  67. <version>${srping.version}</version>
  68. </dependency>
  69. <dependency>
  70. <groupId>org.springframework</groupId>
  71. <artifactId>spring-context-support</artifactId>
  72. <version>${srping.version}</version>
  73. </dependency>
  74. <dependency>
  75. <groupId>org.springframework</groupId>
  76. <artifactId>spring-expression</artifactId>
  77. <version>${srping.version}</version>
  78. </dependency>
  79. <dependency>
  80. <groupId>org.springframework</groupId>
  81. <artifactId>spring-orm</artifactId>
  82. <version>${srping.version}</version>
  83. </dependency>
  84. <dependency>
  85. <groupId>org.springframework</groupId>
  86. <artifactId>spring-web</artifactId>
  87. <version>${srping.version}</version>
  88. </dependency>
  89. <dependency>
  90. <groupId>org.springframework</groupId>
  91. <artifactId>spring-webmvc</artifactId>
  92. <version>${srping.version}</version>
  93. </dependency>
  94. <dependency>
  95. <groupId>org.springframework</groupId>
  96. <artifactId>spring-aspects</artifactId>
  97. <version>${srping.version}</version>
  98. </dependency>
  99. <!-- spring框架包 end -->
  100. <!-- mybatis框架包 start -->
  101. <dependency>
  102. <groupId>org.mybatis</groupId>
  103. <artifactId>mybatis</artifactId>
  104. <version>${mybatis.version}</version>
  105. </dependency>
  106. <dependency>
  107. <groupId>org.mybatis</groupId>
  108. <artifactId>mybatis-spring</artifactId>
  109. <version>1.2.2</version>
  110. </dependency>
  111. <!-- mybatis框架包 end -->
  112. <!-- 数据库驱动 -->
  113. <dependency>
  114. <groupId>mysql</groupId>
  115. <artifactId>mysql-connector-java</artifactId>
  116. <version>5.1.35</version>
  117. </dependency>
  118. <!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 -->
  119. <dependency>
  120. <groupId>commons-dbcp</groupId>
  121. <artifactId>commons-dbcp</artifactId>
  122. <version>1.4</version>
  123. </dependency>
  124. <!-- jstl标签类 -->
  125. <dependency>
  126. <groupId>jstl</groupId>
  127. <artifactId>jstl</artifactId>
  128. <version>1.2</version>
  129. </dependency>
  130. <dependency>
  131. <groupId>taglibs</groupId>
  132. <artifactId>standard</artifactId>
  133. <version>1.1.2</version>
  134. </dependency>
  135. <!-- log start -->
  136. <dependency>
  137. <groupId>log4j</groupId>
  138. <artifactId>log4j</artifactId>
  139. <version>${log4j.version}</version>
  140. </dependency>
  141. <dependency>
  142. <groupId>org.slf4j</groupId>
  143. <artifactId>slf4j-api</artifactId>
  144. <version>${slf4j.version}</version>
  145. </dependency>
  146. <dependency>
  147. <groupId>org.slf4j</groupId>
  148. <artifactId>slf4j-log4j12</artifactId>
  149. <version>${slf4j.version}</version>
  150. </dependency>
  151. <!-- log END -->
  152. <!-- Json -->
  153. <!-- 格式化对象,方便输出日志 -->
  154. <dependency>
  155. <groupId>com.alibaba</groupId>
  156. <artifactId>fastjson</artifactId>
  157. <version>1.2.6</version>
  158. </dependency>
  159. <dependency>
  160. <groupId>org.codehaus.jackson</groupId>
  161. <artifactId>jackson-mapper-asl</artifactId>
  162. <version>1.9.13</version>
  163. </dependency>
  164. <!-- 上传组件包 start -->
  165. <dependency>
  166. <groupId>commons-fileupload</groupId>
  167. <artifactId>commons-fileupload</artifactId>
  168. <version>1.3.1</version>
  169. </dependency>
  170. <dependency>
  171. <groupId>commons-io</groupId>
  172. <artifactId>commons-io</artifactId>
  173. <version>2.4</version>
  174. </dependency>
  175. <dependency>
  176. <groupId>commons-codec</groupId>
  177. <artifactId>commons-codec</artifactId>
  178. <version>1.10</version>
  179. </dependency>
  180. <!-- 上传组件包 end -->
  181. <!-- AL相关添加 -->
  182. <dependency>
  183. <groupId>net.sourceforge.jexcelapi</groupId>
  184. <artifactId>jxl</artifactId>
  185. <version>2.6</version>
  186. </dependency>
  187. <dependency>
  188. <groupId>org.apache.poi</groupId>
  189. <artifactId>poi</artifactId>
  190. <version>3.8</version>
  191. </dependency>
  192. <dependency>
  193. <groupId>org.apache.poi</groupId>
  194. <artifactId>poi-ooxml</artifactId>
  195. <version>3.9</version>
  196. </dependency>
  197. <!-- AL相关添加 -->
  198. </dependencies>
  199. <build>
  200. <finalName>Maven_Project</finalName>
  201. <plugins>
  202. <plugin>
  203. <groupId>org.apache.maven.plugins</groupId>
  204. <artifactId>maven-compiler-plugin</artifactId>
  205. <version>2.3.2</version>
  206. <configuration>
  207. <source>1.7</source>
  208. <target>1.7</target>
  209. </configuration>
  210. </plugin>
  211. </plugins>
  212. </build>
  213. </project>
<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.chillax</groupId><artifactId>Maven_Project</artifactId><packaging>war</packaging><version>0.0.1-SNAPSHOT</version><name>Maven_Project Maven Webapp</name><url>http://maven.apache.org</url><!-- 用来设置版本号 --><properties><srping.version>4.0.2.RELEASE</srping.version><mybatis.version>3.2.8</mybatis.version><slf4j.version>1.7.12</slf4j.version><log4j.version>1.2.17</log4j.version></properties><!-- 用到的jar包 --><dependencies><!-- 单元测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.11</version><!-- 表示开发的时候引入,发布的时候不会加载此包 --><scope>test</scope></dependency><!-- java ee包 --><dependency><groupId>javax</groupId><artifactId>javaee-api</artifactId><version>7.0</version></dependency><!-- spring框架包 start --><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-oxm</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-aop</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-expression</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-orm</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>${srping.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-aspects</artifactId><version>${srping.version}</version></dependency><!-- spring框架包 end --><!-- mybatis框架包 start --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>${mybatis.version}</version></dependency><dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>1.2.2</version></dependency><!-- mybatis框架包 end --><!-- 数据库驱动 --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.35</version></dependency><!-- 导入dbcp的jar包,用来在applicationContext.xml中配置数据库 --><dependency><groupId>commons-dbcp</groupId><artifactId>commons-dbcp</artifactId><version>1.4</version></dependency><!-- jstl标签类 --><dependency><groupId>jstl</groupId><artifactId>jstl</artifactId><version>1.2</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>${log4j.version}</version></dependency><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>${slf4j.version}</version></dependency><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-log4j12</artifactId><version>${slf4j.version}</version></dependency><!-- log END --><!-- Json --><!-- 格式化对象,方便输出日志 --><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.6</version></dependency><dependency><groupId>org.codehaus.jackson</groupId><artifactId>jackson-mapper-asl</artifactId><version>1.9.13</version></dependency><!-- 上传组件包 start --><dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.1</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.4</version></dependency><dependency><groupId>commons-codec</groupId><artifactId>commons-codec</artifactId><version>1.10</version></dependency><!-- 上传组件包 end --><!-- AL相关添加 --><dependency><groupId>net.sourceforge.jexcelapi</groupId><artifactId>jxl</artifactId><version>2.6</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.8</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.9</version></dependency><!-- AL相关添加 --></dependencies><build><finalName>Maven_Project</finalName><plugins><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>2.3.2</version><configuration><source>1.7</source><target>1.7</target></configuration></plugin></plugins></build>
</project>

2、在src/main/resources下添加如下配置文件

applicationContext.xml
[html] view plain copy print?
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-3.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
  12. <!-- 使用注解式注入 -->
  13. <context:annotation-config />
  14. <!-- 自动扫描 -->
  15. <context:component-scan base-package="com.chillax" />
  16. <!-- 导入DAO配置 -->
  17. <import resource="spring-dao.xml"/>
  18. <!-- 导入数据库配置 -->
  19. <import resource="spring-db.xml"/>
  20. <!-- 导入数据库配置 -->
  21. <import resource="spring-tx.xml"/>
  22. </beans>
<?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:p="http://www.springframework.org/schema/p"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-3.1.xsd  http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-3.1.xsd  http://www.springframework.org/schema/mvc  http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"><!-- 使用注解式注入 --><context:annotation-config /><!-- 自动扫描 --><context:component-scan base-package="com.chillax" /><!-- 导入DAO配置 --><import resource="spring-dao.xml"/><!-- 导入数据库配置 --><import resource="spring-db.xml"/><!-- 导入数据库配置 --><import resource="spring-tx.xml"/></beans>

jdbc.properties,有多人反映直接复制时,第一行的driver最后面多了个空格,请注意

[html] view plain copy print?
  1. driver=com.mysql.jdbc.Driver
  2. url=jdbc:mysql://127.0.0.1:3306/maventest
  3. username=root
  4. password=root
  5. #定义初始连接数
  6. initialSize=0
  7. #定义最大连接数
  8. maxActive=20
  9. #定义最大空闲
  10. maxIdle=20
  11. #定义最小空闲
  12. minIdle=1
  13. #定义最长等待时间
  14. maxWait=60000
driver=com.mysql.jdbc.Driver
url=jdbc:mysql://127.0.0.1:3306/maventest
username=root
password=root
#定义初始连接数
initialSize=0
#定义最大连接数
maxActive=20
#定义最大空闲
maxIdle=20
#定义最小空闲
minIdle=1
#定义最长等待时间
maxWait=60000

log4j.properties

[html] view plain copy print?
  1. #定义LOG输出级别
  2. log4j.rootLogger=INFO,Console,File
  3. #定义日志输出目的地为控制台
  4. log4j.appender.Console=org.apache.log4j.ConsoleAppender
  5. log4j.appender.Console.Target=System.out
  6. #可以灵活地指定日志输出格式,下面一行是指定具体的格式
  7. log4j.appender.Console.layout = org.apache.log4j.PatternLayout
  8. log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n
  9. #文件大小到达指定尺寸的时候产生一个新的文件
  10. log4j.appender.File = org.apache.log4j.RollingFileAppender
  11. #指定输出目录
  12. log4j.appender.File.File = logs/ssm.log
  13. #定义文件最大大小
  14. log4j.appender.File.MaxFileSize = 10MB
  15. # 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志
  16. log4j.appender.File.Threshold = ALL
  17. log4j.appender.File.layout = org.apache.log4j.PatternLayout
  18. log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n
#定义LOG输出级别
log4j.rootLogger=INFO,Console,File
#定义日志输出目的地为控制台
log4j.appender.Console=org.apache.log4j.ConsoleAppender
log4j.appender.Console.Target=System.out
#可以灵活地指定日志输出格式,下面一行是指定具体的格式
log4j.appender.Console.layout = org.apache.log4j.PatternLayout
log4j.appender.Console.layout.ConversionPattern=[%c] - %m%n#文件大小到达指定尺寸的时候产生一个新的文件
log4j.appender.File = org.apache.log4j.RollingFileAppender
#指定输出目录
log4j.appender.File.File = logs/ssm.log
#定义文件最大大小
log4j.appender.File.MaxFileSize = 10MB
# 输出所以日志,如果换成DEBUG表示输出DEBUG以上级别日志
log4j.appender.File.Threshold = ALL
log4j.appender.File.layout = org.apache.log4j.PatternLayout
log4j.appender.File.layout.ConversionPattern =[%p] [%d{yyyy-MM-dd HH\:mm\:ss}][%c]%m%n

spring-dao.xml

[html] view plain copy print?
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-3.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
  12. <!-- DAO接口所在包名,Spring会自动查找其下的类 -->
  13. <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
  14. <!--basePackage指定要扫描的包,在此包之下的映射器都会被搜索到。
  15. 可指定多个包,包与包之间用逗号或分号分隔-->
  16. <property name="basePackage" value="com.chillax.dao" />
  17. <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property>
  18. </bean>
  19. </beans>
<?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:p="http://www.springframework.org/schema/p"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-3.1.xsd  http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-3.1.xsd  http://www.springframework.org/schema/mvc  http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"><!-- DAO接口所在包名,Spring会自动查找其下的类 --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!--basePackage指定要扫描的包,在此包之下的映射器都会被搜索到。可指定多个包,包与包之间用逗号或分号分隔--><property name="basePackage" value="com.chillax.dao" /><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"></property></bean>                       </beans>

spring-db.xml

[html] view plain copy print?
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-3.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
  12. <!-- 引入配置文件 -->
  13. <bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
  14. <property name="location" value="classpath:jdbc.properties" />
  15. </bean>
  16. <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
  17. <property name="driverClassName" value="${driver}" />
  18. <property name="url" value="${url}" />
  19. <property name="username" value="${username}" />
  20. <property name="password" value="${password}" />
  21. <!-- 初始化连接大小 -->
  22. <property name="initialSize" value="${initialSize}"></property>
  23. <!-- 连接池最大数量 -->
  24. <property name="maxActive" value="${maxActive}"></property>
  25. <!-- 连接池最大空闲 -->
  26. <property name="maxIdle" value="${maxIdle}"></property>
  27. <!-- 连接池最小空闲 -->
  28. <property name="minIdle" value="${minIdle}"></property>
  29. <!-- 获取连接最大等待时间 -->
  30. <property name="maxWait" value="${maxWait}"></property>
  31. </bean>
  32. <!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 -->
  33. <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
  34. <property name="dataSource" ref="dataSource" />
  35. <!-- 自动扫描mapping.xml文件 -->
  36. <property name="mapperLocations" value="classpath:com/chillax/mapper/*.xml"></property>
  37. </bean>
  38. </beans>
<?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:p="http://www.springframework.org/schema/p"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-3.1.xsd  http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-3.1.xsd  http://www.springframework.org/schema/mvc  http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"><!-- 引入配置文件 --><bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="location" value="classpath:jdbc.properties" /></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="${initialSize}"></property><!-- 连接池最大数量 --><property name="maxActive" value="${maxActive}"></property><!-- 连接池最大空闲 --><property name="maxIdle" value="${maxIdle}"></property><!-- 连接池最小空闲 --><property name="minIdle" value="${minIdle}"></property><!-- 获取连接最大等待时间 --><property name="maxWait" value="${maxWait}"></property></bean><!-- spring和MyBatis完美整合,不需要mybatis的配置映射文件 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSource" /><!-- 自动扫描mapping.xml文件 --><property name="mapperLocations" value="classpath:com/chillax/mapper/*.xml"></property></bean></beans>

spring-tx.xml

[html] view plain copy print?
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:aop="http://www.springframework.org/schema/aop"
  6. xmlns:tx="http://www.springframework.org/schema/tx"
  7. xmlns:mvc="http://www.springframework.org/schema/mvc"
  8. xsi:schemaLocation="http://www.springframework.org/schema/beans
  9. http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
  10. http://www.springframework.org/schema/context
  11. http://www.springframework.org/schema/context/spring-context-3.1.xsd
  12. http://www.springframework.org/schema/aop
  13. http://www.springframework.org/schema/aop/spring-aop-3.1.xsd
  14. http://www.springframework.org/schema/tx
  15. http://www.springframework.org/schema/tx/spring-tx-3.1.xsd">
  16. <!-- (事务管理)transaction manager, use JtaTransactionManager for global tx -->
  17. <bean id="transactionManager"
  18. class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  19. <property name="dataSource" ref="dataSource" />
  20. </bean>
  21. <!--  配置参与事务的类 -->
  22. <aop:config>
  23. <aop:pointcut id="allServiceMethod" expression="execution(* com.chillax.service.*.*(..))"/>
  24. <aop:advisor pointcut-ref="allServiceMethod" advice-ref="TxAdvice" />
  25. </aop:config>
  26. <!-- 使用声明方式配置事务 -->
  27. <tx:advice id="TxAdvice" transaction-manager="transactionManager">
  28. <tx:attributes>
  29. <tx:method name="*" propagation="REQUIRED" rollback-for="java.lang.Exception"/>
  30. </tx:attributes>
  31. </tx:advice>
  32. </beans>
<?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:p="http://www.springframework.org/schema/p"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop"xmlns:tx="http://www.springframework.org/schema/tx"xmlns:mvc="http://www.springframework.org/schema/mvc"xsi:schemaLocation="http://www.springframework.org/schema/beans  http://www.springframework.org/schema/beans/spring-beans-3.1.xsd  http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-3.1.xsd  http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx-3.1.xsd"><!-- (事务管理)transaction manager, use JtaTransactionManager for global tx --><bean id="transactionManager"class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource" /></bean><!--  配置参与事务的类 --><aop:config><aop:pointcut id="allServiceMethod" expression="execution(* com.chillax.service.*.*(..))"/><aop:advisor pointcut-ref="allServiceMethod" advice-ref="TxAdvice" /></aop:config><!-- 使用声明方式配置事务 --><tx:advice id="TxAdvice" transaction-manager="transactionManager"><tx:attributes><tx:method name="*" propagation="REQUIRED" rollback-for="java.lang.Exception"/></tx:attributes></tx:advice></beans>

3、在WEB-INF文件夹下添加/修改以下配置文件

spring-mvc.xml

[html] view plain copy print?
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
  4. xmlns:context="http://www.springframework.org/schema/context"
  5. xmlns:mvc="http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation="http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.1.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context-3.1.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd">
  12. <!--避免IE执行AJAX时,返回JSON出现下载文件 -->
  13. <bean id="mappingJacksonHttpMessageConverter"
  14. class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter">
  15. <property name="supportedMediaTypes">
  16. <list>
  17. <value>text/html;charset=UTF-8</value>
  18. </list>
  19. </property>
  20. </bean>
  21. <!-- 添加注解驱动 -->
  22. <mvc:annotation-driven />
  23. <mvc:default-servlet-handler/>
  24. <!-- 设置使用注解的类所在的包 -->
  25. <context:component-scan base-package="com.chillax.controller" />
  26. <!-- 完成请求和注解POJO的映射 -->
  27. <bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
  28. <property name="messageConverters">
  29. <list>
  30. <ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON转换器 -->
  31. </list>
  32. </property>
  33. </bean>
  34. <!-- 定义跳转的文件的前后缀 ,视图模式配置-->
  35. <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
  36. <!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 -->
  37. <property name="prefix" value="/WEB-INF/jsp/" />
  38. <property name="suffix" value=".jsp" />
  39. </bean>
  40. <!-- SpringMVC上传文件时,需要配置MultipartResolver处理器-->
  41. <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  42. <!-- 默认编码 -->
  43. <property name="defaultEncoding" value="utf-8" />
  44. <!-- 文件大小最大值 -->
  45. <property name="maxUploadSize" value="10485760000" />
  46. <!-- 内存中的最大值 -->
  47. <property name="maxInMemorySize" value="40960" />
  48. </bean>
  49. </beans>
<?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:p="http://www.springframework.org/schema/p"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-3.1.xsd  http://www.springframework.org/schema/context  http://www.springframework.org/schema/context/spring-context-3.1.xsd  http://www.springframework.org/schema/mvc  http://www.springframework.org/schema/mvc/spring-mvc-4.0.xsd"><!--避免IE执行AJAX时,返回JSON出现下载文件 --><bean id="mappingJacksonHttpMessageConverter"class="org.springframework.http.converter.json.MappingJacksonHttpMessageConverter"><property name="supportedMediaTypes"><list><value>text/html;charset=UTF-8</value></list></property></bean><!-- 添加注解驱动 -->  <mvc:annotation-driven /><mvc:default-servlet-handler/><!-- 设置使用注解的类所在的包 --><context:component-scan base-package="com.chillax.controller" /><!-- 完成请求和注解POJO的映射 --><bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"><property name="messageConverters"><list><ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON转换器 --></list></property></bean><!-- 定义跳转的文件的前后缀 ,视图模式配置--><bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 --><property name="prefix" value="/WEB-INF/jsp/" /><property name="suffix" value=".jsp" /></bean><!-- SpringMVC上传文件时,需要配置MultipartResolver处理器--><bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  <!-- 默认编码 --><property name="defaultEncoding" value="utf-8" />  <!-- 文件大小最大值 --><property name="maxUploadSize" value="10485760000" />  <!-- 内存中的最大值 --><property name="maxInMemorySize" value="40960" />  </bean> </beans>

web.xml

[html] view plain copy print?
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns="http://java.sun.com/xml/ns/javaee"
  4. xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
  5. version="3.0">
  6. <display-name>Archetype Created Web Application</display-name>
  7. <welcome-file-list>
  8. <welcome-file>/index.jsp</welcome-file>
  9. </welcome-file-list>
  10. <!-- 加载spring bean -->
  11. <context-param>
  12. <param-name>contextConfigLocation</param-name>
  13. <param-value>classpath:applicationContext.xml</param-value>
  14. </context-param>
  15. <listener>
  16. <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  17. </listener>
  18. <!-- 编码过滤器 -->
  19. <filter>
  20. <filter-name>encodingFilter</filter-name>
  21. <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
  22. <async-supported>true</async-supported>
  23. <init-param>
  24. <param-name>encoding</param-name>
  25. <param-value>UTF-8</param-value>
  26. </init-param>
  27. </filter>
  28. <filter-mapping>
  29. <filter-name>encodingFilter</filter-name>
  30. <url-pattern>/*</url-pattern>
  31. </filter-mapping>
  32. <!-- Spring MVC servlet -->
  33. <servlet>
  34. <servlet-name>SpringMVC</servlet-name>
  35. <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
  36. <init-param>
  37. <param-name>contextConfigLocation</param-name>
  38. <param-value>/WEB-INF/spring-mvc.xml</param-value>
  39. </init-param>
  40. <load-on-startup>1</load-on-startup>
  41. <async-supported>true</async-supported>
  42. </servlet>
  43. <servlet-mapping>
  44. <servlet-name>SpringMVC</servlet-name>
  45. <url-pattern>/</url-pattern>
  46. </servlet-mapping>
  47. </web-app>
<?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>Archetype Created Web Application</display-name><welcome-file-list><welcome-file>/index.jsp</welcome-file></welcome-file-list><!-- 加载spring bean --><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><!-- 编码过滤器 --><filter><filter-name>encodingFilter</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class><async-supported>true</async-supported><init-param><param-name>encoding</param-name><param-value>UTF-8</param-value></init-param></filter><filter-mapping><filter-name>encodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping><!-- Spring MVC servlet --><servlet><servlet-name>SpringMVC</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>/WEB-INF/spring-mvc.xml</param-value></init-param><load-on-startup>1</load-on-startup><async-supported>true</async-supported></servlet><servlet-mapping><servlet-name>SpringMVC</servlet-name><url-pattern>/</url-pattern></servlet-mapping></web-app>

4、在src/main/java下添加如下包和类

UserController.java
[java] view plain copy print?
  1. package com.chillax.controller;
  2. import java.util.List;
  3. import javax.annotation.Resource;
  4. import javax.servlet.http.HttpServletRequest;
  5. import org.springframework.stereotype.Controller;
  6. import org.springframework.ui.Model;
  7. import org.springframework.web.bind.annotation.RequestMapping;
  8. import com.chillax.dto.User;
  9. import com.chillax.service.IUserService;
  10. @Controller
  11. @RequestMapping("/user")
  12. public class UserController {
  13. @Resource
  14. private IUserService userService;
  15. @RequestMapping("/userList")
  16. public String userList(HttpServletRequest request,Model model){
  17. List<User> uList = userService.getAllUser();
  18. model.addAttribute("uList", uList);
  19. return "userList";
  20. }
  21. @RequestMapping("/showUser")
  22. public String showUser(HttpServletRequest request,Model model){
  23. int userId = Integer.parseInt(request.getParameter("id"));
  24. User user = userService.getUserById(userId);
  25. model.addAttribute("user", user);
  26. return "showUser";
  27. }
  28. @RequestMapping("/addUserUI")
  29. public String addUserUI(){
  30. return "addUser";
  31. }
  32. @RequestMapping("/addUser")
  33. public String addUser(HttpServletRequest request,Model model){
  34. User user = new User();
  35. user.setName(String.valueOf(request.getParameter("name")));
  36. user.setPassword(String.valueOf(request.getParameter("password")));
  37. user.setAge(Integer.parseInt(String.valueOf(request.getParameter("age"))));
  38. userService.addUser(user);
  39. return "redirect:/user/userList";
  40. }
  41. }
package com.chillax.controller;import java.util.List;import javax.annotation.Resource;
import javax.servlet.http.HttpServletRequest;import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;import com.chillax.dto.User;
import com.chillax.service.IUserService;@Controller
@RequestMapping("/user")
public class UserController {@Resourceprivate IUserService userService;@RequestMapping("/userList")public String userList(HttpServletRequest request,Model model){List<User> uList = userService.getAllUser();model.addAttribute("uList", uList);return "userList";}@RequestMapping("/showUser")public String showUser(HttpServletRequest request,Model model){int userId = Integer.parseInt(request.getParameter("id"));User user = userService.getUserById(userId);model.addAttribute("user", user);return "showUser";}@RequestMapping("/addUserUI")public String addUserUI(){return "addUser";}@RequestMapping("/addUser")public String addUser(HttpServletRequest request,Model model){User user = new User();user.setName(String.valueOf(request.getParameter("name")));user.setPassword(String.valueOf(request.getParameter("password")));user.setAge(Integer.parseInt(String.valueOf(request.getParameter("age"))));userService.addUser(user);return "redirect:/user/userList";}
}
IUserDao.java
[java] view plain copy print?
  1. package com.chillax.dao;
  2. import java.util.List;
  3. import java.util.Map;
  4. import com.chillax.dto.User;
  5. public interface IUserDao {
  6. public User queryByPrimaryKey(Integer id);
  7. public List<User> queryUserByBatch(Map<String,Object> params);
  8. public void insertUser(User user);
  9. public void insertUserByBatch(List<User> list);
  10. public void deleteByPrimaryKey(Integer id);
  11. public void delteUserByBatch(Map<String,Object> params);
  12. public void updateByPrimaryKey(Integer id);
  13. public List<User> getAllUser();
  14. }
package com.chillax.dao;import java.util.List;
import java.util.Map;import com.chillax.dto.User;public interface IUserDao {public User queryByPrimaryKey(Integer id);public List<User> queryUserByBatch(Map<String,Object> params);public void insertUser(User user);public void insertUserByBatch(List<User> list);public void deleteByPrimaryKey(Integer id);public void delteUserByBatch(Map<String,Object> params);public void updateByPrimaryKey(Integer id);public List<User> getAllUser();}

User.java

[java] view plain copy print?
  1. package com.chillax.dto;
  2. public class User {
  3. private Integer id;
  4. private String name;
  5. private String password;
  6. private Integer age;
  7. public Integer getId() {
  8. return id;
  9. }
  10. public void setId(Integer id) {
  11. this.id = id;
  12. }
  13. public String getName() {
  14. return name;
  15. }
  16. public void setName(String name) {
  17. this.name = name;
  18. }
  19. public String getPassword() {
  20. return password;
  21. }
  22. public void setPassword(String password) {
  23. this.password = password == null ? null : password.trim();
  24. }
  25. public Integer getAge() {
  26. return age;
  27. }
  28. public void setAge(Integer age) {
  29. this.age = age;
  30. }
  31. }
package com.chillax.dto;public class User {private Integer id;private String name;private String password;private Integer age;public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public String getPassword() {return password;}public void setPassword(String password) {this.password = password == null ? null : password.trim();}public Integer getAge() {return age;}public void setAge(Integer age) {this.age = age;}
}

UserMapper.xml

[html] view plain copy print?
  1. <?xml version="1.0" encoding="UTF-8" ?>
  2. <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
  3. <mapper namespace="com.chillax.dao.IUserDao" >
  4. <resultMap id="BaseResultMap" type="com.chillax.dto.User">
  5. <result column="id" property="id" jdbcType="INTEGER" />
  6. <result column="name" property="name" jdbcType="VARCHAR" />
  7. <result column="password" property="password" jdbcType="VARCHAR" />
  8. <result column="age" property="age" jdbcType="INTEGER" />
  9. </resultMap>
  10. <sql id="Base_Column_List">
  11. id, name, password, age
  12. </sql>
  13. <!-- 查询用户-->
  14. <select id="queryByPrimaryKey" resultMap="BaseResultMap"
  15. parameterType="java.lang.Integer">
  16. select
  17. <include refid="Base_Column_List" />
  18. from user
  19. where id = #{id,jdbcType=INTEGER}
  20. </select>
  21. <!-- 查询用户-->
  22. <select id="getAllUser" resultMap="BaseResultMap">
  23. select
  24. <include refid="Base_Column_List" />
  25. from user
  26. </select>
  27. <!-- 批量查询用户-->
  28. <select id="queryUserByBatch" resultMap="BaseResultMap"
  29. parameterType="java.util.Map">
  30. select
  31. <include refid="Base_Column_List" />
  32. from user
  33. where id in
  34. <foreach collection="idList" item="userId" index="index" open="(" separator="," close=")">
  35. #{userId,jdbcType=DECIMAL}
  36. </foreach>
  37. </select>
  38. <!-- 插入用户 -->
  39. <insert id="insertUser" parameterType="com.chillax.dto.User">
  40. insert into user
  41. <trim prefix="(" suffix=")" suffixOverrides="," >
  42. <if test="id != null" >
  43. id,
  44. </if>
  45. <if test="name != null" >
  46. name,
  47. </if>
  48. <if test="password != null" >
  49. password,
  50. </if>
  51. <if test="age != null" >
  52. age,
  53. </if>
  54. </trim>
  55. <trim prefix="values (" suffix=")" suffixOverrides="," >
  56. <if test="id != null" >
  57. #{id,jdbcType=INTEGER},
  58. </if>
  59. <if test="name != null" >
  60. #{name,jdbcType=VARCHAR},
  61. </if>
  62. <if test="password != null" >
  63. #{password,jdbcType=VARCHAR},
  64. </if>
  65. <if test="age != null" >
  66. #{age,jdbcType=INTEGER},
  67. </if>
  68. </trim>
  69. </insert>
  70. <!-- 批量插入用户 -->
  71. <insert id="insertUserByBatch" parameterType="java.util.List" >
  72. insert into USER
  73. (ID,
  74. NAME,
  75. PASSWORD,
  76. AGE)
  77. select A.* from
  78. (
  79. <foreach collection="list" item="user" index="index" separator="union">
  80. select
  81. #{user.id,jdbcType=INTEGER},
  82. #{user.name,jdbcType=VARCHAR},
  83. #{user.password,jdbcType=VARCHAR},
  84. #{user.age,jdbcType=INTEGER}
  85. from dual
  86. </foreach>
  87. ) A
  88. </insert>
  89. <!-- 删除用户 -->
  90. <delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">
  91. delete from user
  92. where id = #{id,jdbcType=INTEGER}
  93. </delete>
  94. <!-- 批量删除用户 -->
  95. <delete id="deleteUserByBatch" parameterType="java.util.Map" >
  96. delete from user
  97. where id IN
  98. <foreach item="ids" collection="iList" open="(" separator="," close=")">
  99. #{ids,jdbcType=DECIMAL}
  100. </foreach>
  101. </delete>
  102. <!-- 更新用户 -->
  103. <update id="updateByPrimaryKey" parameterType="com.chillax.dto.User" >
  104. update user
  105. <set >
  106. <if test="name != null" >
  107. name = #{name,jdbcType=VARCHAR},
  108. </if>
  109. <if test="password != null" >
  110. password = #{password,jdbcType=VARCHAR},
  111. </if>
  112. <if test="age != null" >
  113. age = #{age,jdbcType=INTEGER},
  114. </if>
  115. </set>
  116. where id = #{id,jdbcType=INTEGER}
  117. </update>
  118. </mapper>
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.chillax.dao.IUserDao" >  <resultMap id="BaseResultMap" type="com.chillax.dto.User"><result column="id" property="id" jdbcType="INTEGER" /><result column="name" property="name" jdbcType="VARCHAR" /><result column="password" property="password" jdbcType="VARCHAR" /><result column="age" property="age" jdbcType="INTEGER" /></resultMap><sql id="Base_Column_List">id, name, password, age</sql><!-- 查询用户--><select id="queryByPrimaryKey" resultMap="BaseResultMap"parameterType="java.lang.Integer">select<include refid="Base_Column_List" />from userwhere id = #{id,jdbcType=INTEGER}</select><!-- 查询用户--><select id="getAllUser" resultMap="BaseResultMap">select<include refid="Base_Column_List" />from user</select><!-- 批量查询用户--><select id="queryUserByBatch" resultMap="BaseResultMap"parameterType="java.util.Map">select<include refid="Base_Column_List" />from userwhere id in<foreach collection="idList" item="userId" index="index" open="(" separator="," close=")">#{userId,jdbcType=DECIMAL}</foreach></select><!-- 插入用户 --><insert id="insertUser" parameterType="com.chillax.dto.User">insert into user  <trim prefix="(" suffix=")" suffixOverrides="," >  <if test="id != null" >  id,  </if>  <if test="name != null" >  name,  </if>  <if test="password != null" >  password,  </if>  <if test="age != null" >  age,  </if>  </trim>  <trim prefix="values (" suffix=")" suffixOverrides="," >  <if test="id != null" >  #{id,jdbcType=INTEGER},  </if>  <if test="name != null" >  #{name,jdbcType=VARCHAR},  </if>  <if test="password != null" >  #{password,jdbcType=VARCHAR},  </if>  <if test="age != null" >  #{age,jdbcType=INTEGER},  </if>  </trim>   </insert><!-- 批量插入用户 --><insert id="insertUserByBatch" parameterType="java.util.List" >insert into USER(ID,NAME,PASSWORD,AGE)select A.* from(<foreach collection="list" item="user" index="index" separator="union">select #{user.id,jdbcType=INTEGER},#{user.name,jdbcType=VARCHAR},#{user.password,jdbcType=VARCHAR},#{user.age,jdbcType=INTEGER}from dual</foreach>) A</insert><!-- 删除用户 --><delete id="deleteByPrimaryKey" parameterType="java.lang.Integer">delete from userwhere id = #{id,jdbcType=INTEGER}  </delete><!-- 批量删除用户 --><delete id="deleteUserByBatch" parameterType="java.util.Map" >delete from userwhere id IN <foreach item="ids" collection="iList" open="(" separator="," close=")">#{ids,jdbcType=DECIMAL}</foreach></delete><!-- 更新用户 --><update id="updateByPrimaryKey" parameterType="com.chillax.dto.User" >  update user  <set >  <if test="name != null" >  name = #{name,jdbcType=VARCHAR},  </if>  <if test="password != null" >  password = #{password,jdbcType=VARCHAR},  </if>  <if test="age != null" >  age = #{age,jdbcType=INTEGER},  </if>  </set>  where id = #{id,jdbcType=INTEGER} </update></mapper>

IUserService.java
[java] view plain copy print?
  1. package com.chillax.service;
  2. import java.util.List;
  3. import com.chillax.dto.User;
  4. public interface IUserService {
  5. public User getUserById(int userId);
  6. public void insertUser(User user);
  7. public void addUser(User user);
  8. public List<User> getAllUser();
  9. }
package com.chillax.service;import java.util.List;import com.chillax.dto.User;public interface IUserService {public User getUserById(int userId);public void insertUser(User user);public void addUser(User user);public List<User> getAllUser();
}
UserServiceImpl.java
[java] view plain copy print?
  1. package com.chillax.service.Impl;
  2. import java.util.List;
  3. import javax.annotation.Resource;
  4. import org.springframework.stereotype.Service;
  5. import com.chillax.dao.IUserDao;
  6. import com.chillax.dto.User;
  7. import com.chillax.service.IUserService;
  8. @Service("userService")
  9. public class UserServiceImpl implements IUserService {
  10. @Resource
  11. private IUserDao userDao;
  12. public User getUserById(int userId) {
  13. return userDao.queryByPrimaryKey(userId);
  14. }
  15. public void insertUser(User user) {
  16. userDao.insertUser(user);
  17. }
  18. public void addUser(User user) {
  19. userDao.insertUser(user);
  20. }
  21. @Override
  22. public List<User> getAllUser() {
  23. return userDao.getAllUser();
  24. }
  25. }
package com.chillax.service.Impl;import java.util.List;import javax.annotation.Resource;import org.springframework.stereotype.Service;import com.chillax.dao.IUserDao;
import com.chillax.dto.User;
import com.chillax.service.IUserService;@Service("userService")
public class UserServiceImpl implements IUserService {@Resourceprivate IUserDao userDao;public User getUserById(int userId) {return userDao.queryByPrimaryKey(userId);}public void insertUser(User user) {userDao.insertUser(user);}public void addUser(User user) {userDao.insertUser(user);}@Overridepublic List<User> getAllUser() {return userDao.getAllUser();}}

5、在WEB-INF文件夹下创建jsp文件夹,并添加userList.jsp,showUser.jsp、addUser.jsp

userList.jsp
[html] view plain copy print?
  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
  2. <%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
  3. <%
  4. String path = request.getContextPath();
  5. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  6. %>
  7. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  8. <html>
  9. <head>
  10. <base href="<%=basePath%>">
  11. <title>My JSP 'showUser.jsp' starting page</title>
  12. <meta http-equiv="pragma" content="no-cache">
  13. <meta http-equiv="cache-control" content="no-cache">
  14. <meta http-equiv="expires" content="0">
  15. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  16. <meta http-equiv="description" content="This is my page">
  17. <!--
  18. <link rel="stylesheet" type="text/css" href="styles.css">
  19. -->
  20. </head>
  21. <body>
  22. <c:forEach items="${uList }" var="u">
  23. 用户名称:${u.name}
  24. 用户年龄:${u.age }
  25. <br/>
  26. </c:forEach>
  27. </body>
  28. </html>
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>My JSP 'showUser.jsp' starting page</title><meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0">    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">--></head><body><c:forEach items="${uList }" var="u">用户名称:${u.name}用户年龄:${u.age }<br/></c:forEach></body>
</html>

addUser.jsp

[html] view plain copy print?
  1. <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
  2. <%
  3. String path = request.getContextPath();
  4. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  5. %>
  6. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  7. <html>
  8. <head>
  9. <base href="<%=basePath%>">
  10. <title>My JSP 'addUser.jsp' starting page</title>
  11. <meta http-equiv="pragma" content="no-cache">
  12. <meta http-equiv="cache-control" content="no-cache">
  13. <meta http-equiv="expires" content="0">
  14. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  15. <meta http-equiv="description" content="This is my page">
  16. <!--
  17. <link rel="stylesheet" type="text/css" href="styles.css">
  18. -->
  19. </head>
  20. <body>
  21. <form id="addUser" action="user/addUser" method="post">
  22. userName: <input id="name" name="name" /><br/>
  23. password: <input id="password" name="password" /><br/>
  24. age: <input id="age" name="age"/><br/>
  25. <input type="submit" value="添加新用户"/>
  26. </form>
  27. </body>
  28. </html>
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>My JSP 'addUser.jsp' starting page</title><meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0">    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">--></head><body><form id="addUser" action="user/addUser" method="post"> userName: <input id="name" name="name" /><br/> password: <input id="password" name="password" /><br/> age: <input id="age" name="age"/><br/> <input type="submit" value="添加新用户"/> </form></body>
</html>
showUser.jsp
[html] view plain copy print?
  1. <%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
  2. <%
  3. String path = request.getContextPath();
  4. String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
  5. %>
  6. <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
  7. <html>
  8. <head>
  9. <base href="<%=basePath%>">
  10. <title>My JSP 'showUser.jsp' starting page</title>
  11. <meta http-equiv="pragma" content="no-cache">
  12. <meta http-equiv="cache-control" content="no-cache">
  13. <meta http-equiv="expires" content="0">
  14. <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
  15. <meta http-equiv="description" content="This is my page">
  16. <!--
  17. <link rel="stylesheet" type="text/css" href="styles.css">
  18. -->
  19. </head>
  20. <body>
  21. ${user.name }<br>
  22. </body>
  23. </html>
<%@ page language="java" import="java.util.*" pageEncoding="utf-8"%>
<%
String path = request.getContextPath();
String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
%><!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><base href="<%=basePath%>"><title>My JSP 'showUser.jsp' starting page</title><meta http-equiv="pragma" content="no-cache"><meta http-equiv="cache-control" content="no-cache"><meta http-equiv="expires" content="0">    <meta http-equiv="keywords" content="keyword1,keyword2,keyword3"><meta http-equiv="description" content="This is my page"><!--<link rel="stylesheet" type="text/css" href="styles.css">--></head><body>${user.name }<br></body>
</html>

6、创建数据库,并创建表

[sql] view plain copy print?
  1. DROP TABLE IF EXISTS `user`;
  2. CREATE TABLE `user` (
  3. `id` int(12) NOT NULL AUTO_INCREMENT,
  4. `name` varchar(50) NOT NULL,
  5. `password` varchar(50) NOT NULL,
  6. `age` int(9) NOT NULL,
  7. PRIMARY KEY (`id`)
  8. ) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8;
  9. insert  into `user`(`id`,`name`,`password`,`age`) values (1,'admin','admin',22);
DROP TABLE IF EXISTS `user`;CREATE TABLE `user` (`id` int(12) NOT NULL AUTO_INCREMENT,`name` varchar(50) NOT NULL,`password` varchar(50) NOT NULL,`age` int(9) NOT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=12 DEFAULT CHARSET=utf8;insert  into `user`(`id`,`name`,`password`,`age`) values (1,'admin','admin',22);

7、整个项目文件结构图

8、部署发布项目,进行测试

至此,框架搭建完成。

5.常见问题

问题1:pom.xml文件里的代码到哪里找?

解答:http://www.mvnrepository.com/

问题2:新建MAVEN项目过程中,出现下图错误?

解决:在MyEclipse的安装目录找到myeclipse.ini,将分配的内存加大

问题3:新建完工程后出现以下错误?

解答:在pom.xml添加以下代码即可,添加完代码就会自动下载好jar包

问题4:修改pom.xml时出现以下错误?




解答:这是由于jar包没有正确下载导致的,找到错误的jar包位置,将文件夹里的文件删掉,将pom.xml里该jar包的配置代码删除后再重新写上,让MAVEN重新下载jar包即可。
问题5:出现以下错误?



解答:



问题6:出现以下错误?



解答:将项目的jre版本换成1.7或者以上的版本即可
问题7:出现以下错误,并且已经确定jre是1.7版本或者以上版本。
解答:在pom.xml文件的<build></build>的标签中加入以下代码,然后Update Project(参照问题5)
[html] view plain copy print?
  1. <plugins>
  2. <plugin>
  3. <groupId>org.apache.maven.plugins</groupId>
  4. <artifactId>maven-compiler-plugin</artifactId>
  5. <version>2.3.2</version>
  6. <configuration>
  7. <source>1.7</source>
  8. <target>1.7</target>
  9. </configuration>
  10. </plugin>
  11. </plugins>

MyEclipse使用Maven创建web项目+搭建SSM框架教相关推荐

  1. MyEclipse使用Maven创建web项目+搭建SSM框架教程

    MyEclipse使用Maven创建web项目+搭建SSM框架教程 博文中的代码:链接:http://pan.baidu.com/s/1o8tqIMI 密码:m3si 安装maven和配置 1.下载m ...

  2. MyEclipse中用Maven创建Web项目

    MyEclipse中用Maven创建Web项目 工具/原料 MyEclipse2014 Maven-3.3.3 方法/步骤 1 new --> other 2 1.Wizards: mvaen ...

  3. ajax动态加载公共模块,Maven多模块项目搭建+SSM框架整合(四、Ajax异步获取数据,jq动态添加)...

    最近有点小忙,但是还是在晚上抽出来点时间更新文章,希望对初学者有帮助(都是从那时候过来的,哈哈)一起努力. 开始正题~~~~ 封装类ResultVo 在与前台页面交互的过程中我们一般会用到一个封装类, ...

  4. Eclipse+Maven创建web项目

    有时候我们想用eclipse+maven创建web项目,怎么操作呢,下面我来给大家来分享一下方法 所需工具 已经安装了maven插件的elipse 步骤 1.打开eclipse,右键new--othe ...

  5. Maven学习总结(七)——eclipse中使用Maven创建Web项目

    2019独角兽企业重金招聘Python工程师标准>>> Maven学习总结(七)--eclipse中使用Maven创建Web项目 一.创建Web项目 1.1 选择建立Maven Pr ...

  6. (转)Maven学习总结(七)——eclipse中使用Maven创建Web项目

    孤傲苍狼 只为成功找方法,不为失败找借口! Maven学习总结(七)--eclipse中使用Maven创建Web项目 一.创建Web项目 1.1 选择建立Maven Project 选择File -& ...

  7. maven创建web项目

    转载记录: 方法Ⅰ: 第一步:用maven创建web项目 报错:Description    Resource    Path    Location    Type The superclass & ...

  8. eclipse maven创建web项目

    记录地址 jdk设置及文件包miss 实例下载地址 创建SSM整合项目 一.使用Eclipse中的maven插件创建web项目 1: 2: 3: 4: 5:maven web项目创建成功.(去掉ind ...

  9. Maven学习总结(7)——eclipse中使用Maven创建Web项目

    一.创建Web项目 1.1 选择建立Maven Project 选择File -> New ->Project,如下图所示:

最新文章

  1. 基于cnn的短文本分类_自然语言理解之(二)短文本多分类TextCNN实践
  2. 架构师之路 — 部署架构 — 高可用集群 — N+1 高可用模型
  3. Android中个人推崇的数据库使用方式
  4. VS Code,请还我文件!!!
  5. [翻译]延迟着色(1)
  6. 【AngularJS学习笔记】Java Script use strict 严格模式
  7. spring-security-学习笔记-03-spring-security快速上手
  8. 百万年薪大佬熬夜写作,Python高级编程之反爬虫及应对方案
  9. npm 全局安装node module并查看安装路径
  10. Css中实现一个盒子固定宽度,另一个盒子宽度自适应的方法
  11. 用python做数学题_「文山玩Python做测试」用python做算术题,很简单
  12. import torch 找不到模块_15天Python入门-15-模块与包
  13. Android计算器简单实现
  14. linux数字小键盘,银行工作者必备!小郭数字小键盘练习软件:免费数字键小键盘指法练习...
  15. FontLab 7 for Mac(字体编辑器)
  16. word设置多级标题
  17. 运放全波整流电路_万能整流电路:运放+整流二极管
  18. 全网最简单的RFM模型制作方法,3岁小孩都能学会!
  19. 雷鸣的游戏人生(七) --- 如何谈一场失败的恋爱?
  20. ajax 中的contentType

热门文章

  1. springboot导出excel(easyexcel和poi 列下拉及表格锁定)
  2. 关于global_step参数
  3. 关于3D机器视觉检测与双目相机
  4. 如何申请ATT官方解锁iPhone4
  5. Win7下实现磁盘软Raid1
  6. [bzoj1812][IOI2006]riv_多叉树转二叉树_树形dp
  7. 《天下无谋》读后感 --- 度心术卷2御心篇
  8. 达梦 DM 执行SQL报字符串截断如何分析定位/超长文本截取
  9. 视频教程-基于Java的WebSocket的聊天室-Java
  10. 千万别删VS之ProgramData目录(血泪教训)