超级详细配置SSM (Intellij idea + Maven + Spring + SpringMVC + MyBatis + c3p0 )
时间2018/12/31,使用的包都是最新的和用的人最多的QAQ。
Maven仓库查找包的地址
https://mvnrepository.com/
在经历了70多个小时的奋斗后(花了60个小时学习了下SSM框架和Maven仓库),终于搭建成功了,这一篇将超级详细的讲诉如何Maven环境下搭建Spring,SpringMvc,MyBatis
最后对他们进行整合(整合这一块我整了10多个小时,终于整出来了( ̄﹏ ̄;))
附上项目地址:
里面包含一个c3p0配置的和druid配置的,其中c3p0配置的就是下面教程里配置的最终结果
想偷懒的可以直接去下载
https://github.com/296326173/SSM/tree/master
本来是不打算写的,但是自己配置这个东西走的路程太过坎坷,还是想分享出来让别人少走点弯路,因为去网上看其他博客的SSM配置,没有一个成功的,可能和我无脑拷贝有关系吧QAQ。所以,我将详细的说每一个配置,告诉你哪里需要修改成你自己的路径
这里先将配置C3P0的数据库连接池,下一篇继续更改为Druid连接池(这东西挺好整出来的,就是很配置的多了点)。
第一次写这个东西,不知道如何做树形图,以后知道了再修改吧。懒得百度了。QAQQQQQQ
所以这一篇将会超级长,超级详细。(不要管前后又没逻辑关系QAQ,紧张(/▽\))
有基础的下面的可以不看(主要给像我一样什么都不懂看的,可以直接跳哒)
先上结果图,让你们心里有个底
先来解释下目录结构(这个很重要),这里目录结构太长了,一张图截图不下来QAQQQQQ
这里可以先不写代码啦,最后加进来测试就好了,最后我还会再说明一次的,这里主要是便于理解(这里长长的一段只是解释,还没开始)
- untils 工具包类,主要内容是放了一个获取项目根路径的类(要写这个的原因是,我刚刚配置的时候项目路径都写错,根本不会QAQ,有了这个写的就方便很多了,简化了项目路径的格式),其他的工具类你们自行添加
/*** @author: 航航* @Description:* 不匹配任何路径,跟随服务器启动而启动* 在上下文中存储了一个RootPath的值,值为根路径,使用方式 ${RootPath}* @Date: 11:33 2018/12/29 33*/ @WebServlet(urlPatterns = {},loadOnStartup = 2) public class WebPathInitServlet extends HttpServlet {@Overridepublic void init(ServletConfig config) throws ServletException {config.getServletContext().setAttribute("RootPath",config.getServletContext().getContextPath());super.init(config);} }
- controller 核心控制层,可以把他理解为一个写Servlet的包,但是这里不写Servlet,写SpringMvc提供的Servlet框架(先简单的这么理解)好理解为主(我也不知道对错QAQ,应该没问题)
/*** @author: 航航* @Description:* @Date: 20:36 2018/12/30 36*/ @Controller public class GirlController {@Autowiredprivate GirlService girlService;@RequestMapping("/queryGirl")public String queryGirl(Model model) throws Exception{Girl girl = girlService.selectGirl();model.addAttribute("girl",girl);return "success";} }
- mapper 这里主要放置 Sql语句的定义,比如
//GirlMapper @Repository public interface GirlMapper {Girl queryById(long id); }
- pojo 又称entity 放置一些Bean(简单的理解也就是java的类啦) 前面的Gril类就是写在这里面的
//Girl类 public class Girl {int id;String password;String account;//这里要写上get和set方法哦,别忘记了,Idea的快捷键是alt+insert就可以快速插入//如果填写了有参构造方法,一定要添加一个无参的构造方法!!!! }
- service 服务层 ,这个层下还有一个serviceImpl的包,图片里折叠了 这层主要调用mapper层里的方法,把数据返回给controller层(不懂没关系QAQ,我也只懂了一点点,反正看到代码就明白怎么用啦)
//这里是service包的内容 GirlService接口 @Repository public interface GirlService {Girl selectGirl() throws Exception; }//下面是serviceImpl包里的实现 GirlServiceImp @Service class GirlServiceImp implements GirlService {@Autowiredprivate GirlMapper girlMapper;@Overridepublic Girl selectGirl() throws Exception {return girlMapper.queryById(1);} }
- dao 有了mapper层应该不用这个东西了,但是我固执的把他留下来了,不舍得删了,内心有一种声音,他应该是有用的。
- resources 资源目录文件,默认的路径是classpath: 也就是说,后面出现classpath:即使访问这个路径啦
- resoureces/mapper 这里存放的是mapper的sql查询语句,以后将一次把这个包下的所有内容引用进来,这样看起来比较清晰啦,当然啦这个可以不用写的,直接使用idea 里的mybatis 的插件就可以生成的啦(插件最后来讲)
<!--GirlMapper.xml--><?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--这里写类名-->
<mapper namespace="com.hang.mapper.GirlMapper"><select id="queryById" resultType="com.hang.pojo.Girl">SELECT * from user WHERE id = #{id};</select>
</mapper>
- resources/spring 设置这个目录还是为了开发方便,主要目的是,把所有的spring的XML配置(虽然现在大家都用注解配置了)都写在这里面,在spring-mybatis.xml中把他们都引入进来,这样方便维护。(目录里你看到有文件,但是没有核心内容,主要还是为了让IDEA检测不报错加的)一下是引入的代码
<!--导入spring文件夹下的所有spring-*.xml的文件--> <import resource="classpath:spring/spring-*.xml"/>
- applicationContext.xml 这个文件是第一步配置Spring的时候使用的,后面整合SSM后,这个文件就可以删除了
- dispatcher-servlet.xml 这个是SpringMvc的配置文件(很重要!!!)
- jdbc.properties 这个是数据库的配置文件
- log4j.properties 这个是日志的配置文件
- mybatis-config.xml 这个是Mybatis的配置文件,后面整合SSM后将可以删除
- spring-mybatis.xml 这个超级重要(整合了mybatis-config.xml 和applicationContext.xml )不是单纯的拷贝,还添加了额外的内容,这里的内容包括了Spring和Mybatis的配置
继续解释目录结构
- webapp 这是一个web的根目录(不知道这样解释有没有问题),他的访问路径是'/'
- static 静态资源文件目录,路径为 “/static”
- js JavaScript静态资源文件目录,路径为/static/js
- images 放置图片资源文件的目录,路径为/static/images
- css 放置CSS样式的目录,路径为/static/css
- WEB-INF 路径/WEB-INF
- views 路径/WEB-INF/views ,这个目录下放置jsp文件,为Controller层提供跳转的页面
- web.xml 路径/WEB-INF/web.xml 这个是核心配置文件
- index.jsp 主页
- Test 这个目录主要是为了使用junit测试
- resources 测试资源文件(反正标准这样,我几乎不用QAQ)
好啦解释完啦,解下来先配置Spring(这里才是正文)
首先新建项目,这里我用的是JDK11,勾选骨架,选择maven项目webapp,选择下一步
下一步
点击Finish就完成啦
右下角会出现这2框框,第一个告诉你框架构建完成,第二个询问你是否要导入Maven包,import changes 是导入,Enable Auto-Import 表示自动导入(我一般选这个,建议选这个)。
目录结构如下,你会发现少了很多重要内容,所以我们补全他们
点击File,选择那个Project Structre...(也可以用快捷键)
其中main/java目录为Sources
main/resources目录为Resources
Test/java 目录Tests
Test/resources 目录为Test Resources
接下来打开pom.xml(以下内容都在pom.xml里面),修改junit版本为4.12,编译版本为1.8(你们可以不修改,我喜欢用最新的QAQ),并且添加Spring SpringMvc和Mybatis等等依赖包(一次性加完,省的麻烦哦)
根据这段代码修改一下你的pom.xml里面的内容
<properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target><!--Spring的版本号--><spring.version>5.1.3.RELEASE</spring.version><!--Mybatis的版本号--><mybatis.version>3.4.6</mybatis.version><jstl.version>1.2</jstl.version><slf4j.version>1.7.25</slf4j.version>
</properties>
把这一段代码放到
<dependencies> 内容在这里 </dependencies>
<dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- java ee --><dependency><groupId>javax</groupId><artifactId>javaee-api</artifactId><version>8.0</version></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.2</version></dependency><!-- JSON --><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.9.7</version></dependency><dependency><groupId>org.codehaus.jackson</groupId><artifactId>jackson-mapper-asl</artifactId><version>1.9.13</version></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-core</artifactId><version>2.9.7</version></dependency><!-- Mysql --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.13</version></dependency><!--日志包--><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</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>--><!--数据库连接池 https://mvnrepository.com/artifact/com.mchange/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>${mybatis.version}</version></dependency><!--Mybatis整合Spring https://mvnrepository.com/artifact/org.mybatis/mybatis-spring --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>1.3.2</version></dependency><!-- Spring --><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-beans</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring.version}</version></dependency><!-- JSP相关 --><dependency><groupId>jstl</groupId><artifactId>jstl</artifactId><version>${jstl.version}</version></dependency><!--文件上传和下载--><dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.3</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.6</version></dependency><dependency><groupId>commons-codec</groupId><artifactId>commons-codec</artifactId><version>1.10</version></dependency>
终极版本(建议根据上面的内容自行修改啦,很简单的,注意标签哦)
<?xml version="1.0" encoding="UTF-8"?><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/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.hang</groupId><artifactId>WebRoot_SSM</artifactId><version>1.0-SNAPSHOT</version><packaging>war</packaging><name>WebRoot_SSM Maven Webapp</name><!-- FIXME change it to the project's website --><url>http://www.example.com</url><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target><!--Spring的版本号--><spring.version>5.1.3.RELEASE</spring.version><!--Mybatis的版本号--><mybatis.version>3.4.6</mybatis.version><jstl.version>1.2</jstl.version><slf4j.version>1.7.25</slf4j.version></properties><dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- java ee --><dependency><groupId>javax</groupId><artifactId>javaee-api</artifactId><version>8.0</version></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.2</version></dependency><!-- JSON --><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.9.7</version></dependency><dependency><groupId>org.codehaus.jackson</groupId><artifactId>jackson-mapper-asl</artifactId><version>1.9.13</version></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-core</artifactId><version>2.9.7</version></dependency><!-- Mysql --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.13</version></dependency><!--日志包--><dependency><groupId>log4j</groupId><artifactId>log4j</artifactId><version>1.2.17</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>--><!--数据库连接池 https://mvnrepository.com/artifact/com.mchange/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>${mybatis.version}</version></dependency><!--Mybatis整合Spring https://mvnrepository.com/artifact/org.mybatis/mybatis-spring --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>1.3.2</version></dependency><!-- Spring --><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-beans</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring.version}</version></dependency><!-- JSP相关 --><dependency><groupId>jstl</groupId><artifactId>jstl</artifactId><version>${jstl.version}</version></dependency><!--文件上传和下载--><dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.3</version></dependency><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.6</version></dependency><dependency><groupId>commons-codec</groupId><artifactId>commons-codec</artifactId><version>1.10</version></dependency></dependencies><build><finalName>WebRoot_SSM</finalName><pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --><plugins><plugin><artifactId>maven-clean-plugin</artifactId><version>3.1.0</version></plugin><!-- see http://maven.apache.org/ref/current/maven-core/default-bindings.html#Plugin_bindings_for_war_packaging --><plugin><artifactId>maven-resources-plugin</artifactId><version>3.0.2</version></plugin><plugin><artifactId>maven-compiler-plugin</artifactId><version>3.8.0</version></plugin><plugin><artifactId>maven-surefire-plugin</artifactId><version>2.22.1</version></plugin><plugin><artifactId>maven-war-plugin</artifactId><version>3.2.2</version></plugin><plugin><artifactId>maven-install-plugin</artifactId><version>2.5.2</version></plugin><plugin><artifactId>maven-deploy-plugin</artifactId><version>2.8.2</version></plugin></plugins></pluginManagement></build>
</project>
这时候再次点击Crtl+Alt-Shift+S(我用啦快捷键啦)
把Spring模块去掉,点击OK
接下来右键WEBROOT_SSM,选择Add Framework Support...
勾选Spring,SpringMvc,和创建Spring-Config.xml,点击OK
然后观察目录结构,发现多了2个文件
其中applicationContext.xml 是spring的配置文件 (如果没有额外配置,Spring会在/WEB-INF下找applicationContext.xml文件,但是我们的配置是放在resources目录下的,所以后面我们移动 后要额外配置它)
dispatcher-servlet.xml 是springMvc的配置文件
所以下一步你也猜到了,就是移动他们到resources目录下啦,由此,目录结构大致(Test里面的还没填,java里面的还没填)搞定了,接下来就是在配置文件里写内容了
所以把还没新建的目录建立起来咯
在java目录下新建包
com.hang.pojp
com.hang.dao
com.hang.mapper
com.hang.service.serviceImpl
com.hang.controller
com.hang.utils
解下来是填写applicationContext.xml 的内容,写完会发现<import resource="classpath:spring/spring-*.xml"/>报错,是因为resources/spring里的没有spring-*.xml的文件(这里我要求我的小伙伴开发的时候新建的spring配置文件格式为spring-*.xml)
所以就这么填写了,如果想要不报错,就在resources/spring目录下新建一个spring-任意名字.xml的文件就好了。下面我会建一个文件。
<?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/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd"><!--这是一个Spring的配置文件--><!--开启注解扫描,扫描所有的com包下的所有包--><context:component-scan base-package="com"/><!--导入spring文件夹下的所有spring-*.xml的文件--><import resource="classpath:spring/spring-*.xml"/>
</beans>
spring-girl.xml内容如下(里面什么也没写)
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd"></beans>
接下来打开web.xml(重头戏)
上面一处修改的目的是让程序找到applicationContext.xml文件
下面一处可以不修改,像我这样我萌新就修改为“/”就可以了。这里表示所有请求要走Controller包下的DispatcherServlet。
还需要在<web-app>标签里添加一点点内容
<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/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0">
完整的内容
<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN""http://java.sun.com/dtd/web-app_2_3.dtd" ><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/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0"><display-name>Archetype Created Web Application</display-name><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><servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/</url-pattern></servlet-mapping>
</web-app>
解下来编写一个Girl的类(注意get,set,toString方法必须有,无参构造必须有)
@Component("girl")
public class Girl {Integer id;String account;String password;public void Hello(){System.out.println("Spring测试成功啦.....");}//这里你需要自己添加get,set,和toString方法,代码太长我就不黏贴进去了
}
解下来在Test/java目录下新建com.hang.Test的类
类中填入如下内容:
public class Test {@org.junit.Testpublic void testSpring(){ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationContext.xml");Girl girl = (Girl) applicationContext.getBean("girl");girl.Hello();}
}
执行控制台出现“Spring测试成功啦.....”表示spring成功
总结:注意事项
1.spring默认找/WEB-INF目录下的applicationContext.xml,我们更改了这个文件的位置,需要在web.xml里配置他的位置。
2. 没有啦(( ̄▽ ̄)"),spring配置是最简单的啦
Mybatis的配置
废话不多说,直接开干(写了4个小时了,写的有点烦躁QAQ,逐渐不安::>_<::)
下次心情好了继续慢慢的改的更加详细
在resources下新建jdbc.properties,内容如下
注意:数据库的url,driver,username,passowrd的内容是你需要修改成自己的
#数据库地址
url=jdbc:mysql://192.168.80.130:3306/example?useUnicode=true&characterEncoding=UTF-8
#数据库驱动
driver=com.mysql.jdbc.Driver
#账号
username=root
#密码
password=123456
#最大连接数
c3p0.maxPoolSize=30
#最小连接数
c3p0.minPoolSize=10
#关闭连接后不自动commit
c3p0.autoCommitOnClose=false
#获取连接超时时间
c3p0.checkoutTimeout=10000
#当获取连接失败重试次数
c3p0.acquireRetryAttempts=2
在resources下新建mybatis-config.xml文件,内容如下,导入后你会发现有个报错的地方
<mappers>
<!--这里是导入resources/mapper包下的文件-->
<mapper resource="mapper/GirlMapper.xml"></mapper>
</mappers>
主要原因是,mapper下没有GirlMapper.xml文件,所以我们建一个
<?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><properties resource="jdbc.properties"></properties><!--类型别名--><settings><!--开启驼峰命名--><setting name="mapUnderscoreToCamelCase" value="true"/><setting name="jdbcTypeForNull" value="NULL"></setting><setting name="lazyLoadingEnabled" value="true"></setting><setting name="aggressiveLazyLoading" value="false"></setting><!--开启二级缓存--><setting name="cacheEnabled" value="true"></setting></settings><typeAliases><!--直接注册整个包,包下的所有类都生效,默认规则写类名--><package name="com.hang.pojo"></package></typeAliases><environments default="mysqlConnect"><environment id="mysqlConnect"><transactionManager type="JDBC"></transactionManager><dataSource type="UNPOOLED"><property name="url" value="${url}"></property><property name="driver" value="${driver}"></property><property name="username" value="${username}"></property><property name="password" value="${password}"></property></dataSource></environment></environments><mappers><!--这里是导入resources/mapper包下的文件--><mapper resource="mapper/GirlMapper.xml"></mapper></mappers>
</configuration>
在com.hang.mapper下创建一个接口GirlMapper
内容如下,你会发现他会报错,他要求你写上sql语句,那么接下来就在GirlMapper.xml文件里写上sql语句
@Repository
public interface GirlMapper {Girl queryById(Integer id);
}
在resources/mapper创建一个GirlMapper.xml的文件
内容如下
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!--这里写类名-->
<mapper namespace="com.hang.mapper.GirlMapper"><select id="queryById" resultType="com.hang.pojo.Girl">SELECT * from user WHERE id = #{id};</select>
</mapper>
到现在为止,我们的目录结构为
完成一大半了,继续,我们在resources下新建mybatis-config.xml文件,填写内容如下
简单的介绍下,mapper标签里引入其他mybatis.xml文件主要是为了以后我们获取数据库连接对象只使用mybatis-config.xml这个文件,在测试的时候你就彻底明白了,其他的为数据库配置文件。
<?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><!--引入这个数据库配置文件--><properties resource="jdbc.properties"></properties><!--类型别名--><settings><!--开启驼峰命名--><setting name="mapUnderscoreToCamelCase" value="true"/><setting name="jdbcTypeForNull" value="NULL"></setting><setting name="lazyLoadingEnabled" value="true"></setting><setting name="aggressiveLazyLoading" value="false"></setting><!--开启二级缓存--><setting name="cacheEnabled" value="true"></setting></settings><typeAliases><!--直接注册整个包,包下的所有类都生效,默认规则写类名--><package name="com.hang.pojo"></package></typeAliases><environments default="mysqlConnect"><environment id="mysqlConnect"><transactionManager type="JDBC"></transactionManager><dataSource type="UNPOOLED"><property name="url" value="${url}"></property><property name="driver" value="${driver}"></property><property name="username" value="${username}"></property><property name="password" value="${password}"></property></dataSource></environment></environments><!--包含GirlMapper.xml这个文件,测试时候我们只引入mybatis-config.xml这个文件使用--><mappers><mapper resource="mapper/GirlMapper.xml"></mapper></mappers>
</configuration>
接下来我们准备测试环节
首先先新建表
注意,这里的字段名字要和girl类里的字段名字对应(前面和我一样的就不会报错的啦)
create table user
(account varchar(255) not null,password varchar(255) null,id int auto_incrementprimary key,constraint user_account_uindexunique (account)
);insert into user values ('admin1','123456',1);
解下来在Test/com.hang.Test类下新建一个函数
@org.junit.Testpublic void testSpringMvc(){String resource = "mybatis-config.xml";InputStream in = null;try {in = Resources.getResourceAsStream(resource);SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);SqlSession sqlSession = sqlSessionFactory.openSession();GirlMapper mapper = sqlSession.getMapper(GirlMapper.class);Girl girl = mapper.queryById(1);System.out.println(girl);sqlSession.close();} catch (IOException e) {e.printStackTrace();}
输出结果为Girl{id=1, account='admin1', password='123456'} 表示成功啦(注意:我的Girl类是有toString和get,set方法的,前往别拉下了,还有无参构造器一定要有)
总结:
一定要清楚思路,我们的思维是,在mybatis-config.xml里包含其他所有的resources/mapper/下的xml文件,这写文件是sql语句,通过加载mybatis-config.xml即可使用他们。所以我们使用了代码
String resource = "mybatis-config.xml";
in = Resources.getResourceAsStream(resource);
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(in);
来加载他们
最后,一定不要忘记,在mapper下每多写一个XXX.xml的文件,一定要在mybatis-config.xml的
<mappers><mapper resource="mapper/GirlMapper.xml"></mapper> </mappers>
这里面再配置一个(原因是我不知道如何写让他自动扫描mapper/下的所有配置文件。只会一个个写QAQQQQQQ)
SpringMVC
好啦终于到最后了,写的我脑阔疼::>_<::
在上面的基础上我们接着配置。先上目前的目录结构图
好啦,开始动手干活啦O(∩_∩)O
现在终于要开始编写dispatcher-servlet.xml这个文件啦,这个是一个springMvc的配置文件,动手!
直接上内容:开始解释
由于我们前面web.xml配置
<servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/</url-pattern> </servlet-mapping>
把所有的请求都拦截下来了,所以我们要选择放行一些,比如jsp页面里包含CSS文件的连接,这些静态资源要放行
所以。。。。 注意,他们要同时出现。
<!--屏蔽静态资源文件的扫描,防止静态资源被SpringMvc解析-->
<mvc:default-servlet-handler/>
<!-- 添加注解驱动 -->
<mvc:annotation-driven/>
表示去/WEB-INF/views/目录下找.jsp后缀的文件。主要是给后面controller层跳转页面使用。后面会再提这里的QAQ
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
<?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/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"><!--这是一个SpringMvc的文件--><!--屏蔽静态资源文件的扫描,防止静态资源被SpringMvc解析--><mvc:default-servlet-handler/><!-- 添加注解驱动 --><mvc:annotation-driven/><!--扫描/WEB-INF/views/下的jsp文件,配置视图解析器--><bean id="defaultViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/><property name="prefix" value="/WEB-INF/views/"/><!--设置JSP文件的目录位置--><property name="suffix" value=".jsp"/><!--选择.jsp后缀的文件--><property name="exposeContextBeansAsAttributes" value="true"/></bean><!-- 自动扫描装配,扫描controller下的包,扫描后即可提供注解 --><context:component-scan base-package="com.hang.controller"/><!--验证器-<mvc:annotation-driven validator="validtor"><mvc:message-converters><bean class="org.springframework.http.converter.StringHttpMessageConverter"/><bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/></mvc:message-converters></mvc:annotation-driven>--><!--避免IE执行AJAX时,返回JSON出现下载文件 --><bean id="mappingJacksonHttpMessageConverter"class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"><property name="supportedMediaTypes"><list><value>text/html;charset=UTF-8</value></list></property></bean><!-- 文件上传配置 --><bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"><!-- 默认编码 --><property name="defaultEncoding" value="UTF-8"/><!-- 上传文件大小限制为31M,31*1024*1024 --><property name="maxUploadSize" value="32505856"/><!-- 内存中的最大值 --><property name="maxInMemorySize" value="4096"/></bean></beans>
这里突然发现项目忘记建立静态资源文件夹了,没事补上
在webapp下新建文件夹static,下面再建3个文件夹js.css.images
目录结构图如下
接下来我们要让web项目找到这个dispatcher-servlet.xml配置文件
在web.xml的servlet里添加
<init-param><!--配置dispatcher-servlet.xml作为mvc的配置文件--><param-name>contextConfigLocation</param-name><param-value>classpath:dispatcher-servlet.xml</param-value></init-param>
所以现在的web.xml的配置文件如下
<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN""http://java.sun.com/dtd/web-app_2_3.dtd" ><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/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0"><display-name>Archetype Created Web Application</display-name><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><servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><!--配置dispatcher-servlet.xml作为mvc的配置文件--><param-name>contextConfigLocation</param-name><param-value>classpath:dispatcher-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/</url-pattern></servlet-mapping>
</web-app>
接下来准备测试啦
在com.hang.controller里新建一个java类A,内容如下
@Controller
public class A {@RequestMapping("/a")public String testMvc(){System.out.println("跳转success.jsp");return "success";}
}
看到return success语句了没??他的意思是要去找一个success的页面,去哪里找呢???
还记得我们前面配置的吗
<property name="prefix" value="/WEB-INF/views/"/>
<property name="suffix" value=".jsp"/>
就是去views的文件找一个后缀为.jsp的页面
所以我们去views下新建一个页面,名字为success.jsp(严格按照名字办事,不可以另外取一个和retrun “success”中的success名字不同的)
<%--Created by IntelliJ IDEA.User: 29632Date: 2018/12/31Time: 16:19To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>Title</title>
</head>
<body>
成功啦
</body>
</html>
准备工作就绪
好了现在要部署tomcat了。
OK后启动就好啦,自动就进入首页了
我们接下来就地址栏后面加上一个a,结果如下
好啦,到目前为止,三打框架都已经配置完成,就差整合了
最后的整合SSM
重头戏来了,欸写的我累死了QAQ,心塞塞
新建一个文件在resources下spring-mybatis.xml
内容如下(所以的配置的意思都已注释的形式放进去了)
<?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/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttp://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/txhttp://www.springframework.org/schema/tx/spring-tx.xsd"><!--这是spring和mybatis的整合文件--><!--开启注解扫描,扫描所有的com包下的所有包--><context:component-scan base-package="com"/><!--导入spring文件夹下的所有spring-*.xml的文件--><import resource="classpath:spring/spring-*.xml"/><!--导入mapper文件夹下的所有*.xml的文件--><!--<import resource="classpath:mapper/GirlMapper.xml"/>--><!--导入数据库配置文件,这里不可以使用这种方式--><!--<context:property-placeholder location="classpath:jdbc.properties"/>--><!--导入数据库配置文件--><bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="location" value="classpath:jdbc.properties"/></bean><!-- 数据库连接池c3p0 --><bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" destroy-method="close" ><property name="driverClass" value="${driver}"/><property name="jdbcUrl" value="${url}"/><property name="user" value="${username}"/><property name="password" value="${password}"/><property name="maxPoolSize" value="${c3p0.maxPoolSize}"/><property name="minPoolSize" value="${c3p0.minPoolSize}"/><property name="autoCommitOnClose" value="${c3p0.autoCommitOnClose}"/><property name="checkoutTimeout" value="${c3p0.checkoutTimeout}"/><property name="acquireRetryAttempts" value="${c3p0.acquireRetryAttempts}"/></bean><!-- 配置SqlSessionFactory对象 --><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><!-- 注入数据库连接池 --><property name="dataSource" ref="dataSource"/><!-- 扫描model包 使用别名 --><property name="typeAliasesPackage" value="com.hang.pojo"/><!-- 扫描sql配置文件:mapper需要的xml文件 --><property name="mapperLocations" value="classpath:mapper/*.xml"/></bean><!--<!– 配置扫描Dao接口包,动态实现Dao接口,注入到spring容器中 –>--><!--<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">--><!--<!– 注入sqlSessionFactory –>--><!--<property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/>--><!--<!– 给出需要扫描Dao接口包 –>--><!--<property name="basePackage" value="com.hang.dao"/>--><!--</bean>--><!-- 配置扫描mapper接口包,动态实现mapper接口,注入到spring容器中 --><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!-- 注入sqlSessionFactory --><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/><!-- 给出需要扫描mapper接口包 --><property name="basePackage" value="com.hang.mapper"/></bean><!-- 配置事务管理器 --><bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><!-- 注入数据库连接池 --><property name="dataSource" ref="dataSource"/></bean><!-- 配置基于注解的声明式事务 --><tx:annotation-driven transaction-manager="transactionManager"/></beans>
然后我们要加载这个配置文件.
在web.xml里修改内容,把applicationContext的配置换成我们现在Spring-Mybatis.xml的整合文件
<context-param><param-name>contextConfigLocation</param-name><!--这里本来填applicationContext.xml的--><param-value>classpath:spring-mybatis.xml</param-value></context-param>
最后最后附上结果
<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN""http://java.sun.com/dtd/web-app_2_3.dtd" ><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/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0"><display-name>Archetype Created Web Application</display-name><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring-mybatis.xml</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><!--配置dispatcher-servlet.xml作为mvc的配置文件--><param-name>contextConfigLocation</param-name><param-value>classpath:dispatcher-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/</url-pattern></servlet-mapping>
</web-app>
spring提供了一个编码的过滤器,我们把它添加上,也是添加在web.xml里
最后web.xml的内容如下
<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN""http://java.sun.com/dtd/web-app_2_3.dtd" ><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/javaeehttp://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"version="4.0"><display-name>Archetype Created Web Application</display-name><context-param><param-name>contextConfigLocation</param-name><param-value>classpath:spring-mybatis.xml</param-value></context-param><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><servlet><servlet-name>dispatcher</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><!--配置dispatcher-servlet.xml作为mvc的配置文件--><param-name>contextConfigLocation</param-name><param-value>classpath:dispatcher-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>dispatcher</servlet-name><url-pattern>/</url-pattern></servlet-mapping><filter><filter-name>encodingFilter</filter-name><filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class><init-param><param-name>forceRequestEncoding</param-name><param-value>true</param-value></init-param><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>
</web-app>
现在就全部整合完成啦,开心,准备测试
在service包下新建一个GirlService接口,内容如下
@Controller
public class GirlController {@Autowiredprivate GirlService girlService;@RequestMapping("/queryGirl")public String queryGirl(Model model) throws Exception{Girl girl = girlService.selectGirl();model.addAttribute("girl",girl);return "success";}
}
在serviceImpl包下新建一个GirlServiceImp类,内容如下
@Service
class GirlServiceImp implements GirlService {@Autowiredprivate GirlMapper girlMapper;@Overridepublic Girl selectGirl() throws Exception {return girlMapper.queryById(1);}
}
在controller包新建一个GirlController类,内容如下
@Controller
public class GirlController {@Autowiredprivate GirlService girlService;@RequestMapping("/queryGirl")public String queryGirl(Model model) throws Exception{Girl girl = girlService.selectGirl();model.addAttribute("girl",girl);return "success";}
}
在utils包下新建一个类,主要功能是为了方便写项目的路径(通过RootPath即可获取)
@WebServlet(urlPatterns = {},loadOnStartup = 2)
public class WebPathInitServlet extends HttpServlet {@Overridepublic void init(ServletConfig config) throws ServletException {config.getServletContext().setAttribute("RootPath",config.getServletContext().getContextPath());super.init(config);}
}
来看看现在的项目结构图
最后修改index.jsp里的内容
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>测试SpringMvc</title>
</head>
<body>
<a href="${RootPath}/queryGirl">测试SSM</a>
</body>
</html>
修改success.jsp的内容
<%@ page import="com.hang.pojo.Girl" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%Girl girl = (Girl) request.getAttribute("girl");
%>
<html>
<head><title>测试成功</title>
</head>
<body>
success
<%=girl%>
</body>
</html>
开启tomcat,点击测试SSM
至此,全部结束,草草的写完了,写了6个小时,实在不想写了,要是看的人多,需要的多的话,我就继续修改的更加完整点。
最后附上项目,一个是配置好的c3p0的SSM,一个是配置好的druid 的SSM
累了,午饭都没吃,饿死了QAQQQQQQQ,╯︿╰
Log4j的下次再加,写不动了,下次接着写
超级详细配置SSM (Intellij idea + Maven + Spring + SpringMVC + MyBatis + c3p0 )相关推荐
- Maven整合SSM框架(maven+spring+springmvc+mybatis)
啊哈,终于到了用Maven整合SSM这个扑街含家产了.弄了整整一天才跑通.Mybatis的配置有些繁琐,跟之前学习的那个有点出去,加上Eclipse的Spring工具没有弄,配置的时候没有提示被搞蒙圈 ...
- SSM框架整合(IntelliJ IDEA + maven + Spring + SpringMVC + MyBatis)
使用IDEA创建Spring + SpringMVC + MyBatis 框架的Maven的项目. 一. 创建maven项目 1. File -> New Module,进入创建项目窗口. 2. ...
- java实现微信支付宝等多个支付平台合一的二维码支付(maven+spring springmvc mybatis框架)
首先申明,本人实现微信支付宝等支付平台合多为一的二维码支付,并且实现有效时间内支付有效,本人采用的框架是spring springmvc mybatis 框架,maven管理.其实如果支付,不需要my ...
- java实现微信支付宝等多个支付平台合一的二维码支付(maven+spring springmvc mybatis框架)...
首先申明,本人实现微信支付宝等支付平台合多为一的二维码支付,并且实现有效时间内支付有效,本人采用的框架是spring springmvc mybatis 框架,maven管理.其实如果支付,不需要my ...
- SSM框架——干净详细的整合学习教程(Spring+SpringMVC+MyBatis)
一.SpringMVC概述 熟悉MVC的同学都知道,MVC即model(模型).view(视图).controller(控制),用一种业务逻辑,数据,界面显示分离的方式使得开发更加的便捷高效,具有低耦 ...
- SSM框架整合(Spring+SpringMVC+MyBatis+Oracle)
1.开发环境搭建以及创建Maven Web项目 参看之前的博文:http://www.cnblogs.com/cainiaomahua/p/6306476.html 2.SSM整合 这次整合有2个配置 ...
- SSM框架整合(Spring+SpringMVC+MyBatis)
输出结果 1.Maven Web项目创建 之前有写过Eclipse+Maven创建web项目的帖子,如果需要,请参考这里写链接内容 创建好项目之后因为入下图: 2.SSM整合 2.1 引入需要的JAR ...
- ssm面试题总结 spring springmvc mybatis面试题
1.你如何理解Spring? 具体来说Spring是一个轻量级的容器,用于管理业务相关对象的.核心功能主要为:IOC,AOP,MVC. IOD:控制反转,将对象的创建过程交给容器,让容器管理对象的生命 ...
- SSM学习——SSM整合案例(Spring+SpringMVC+Mybatis)(13)
这里写目录标题 要求 Spirng整合Mybatis Spirng整合SpringMVC 表与实体类的创建 创建层级 Dao层 Service层 controller层 接口测试 业务层`servic ...
最新文章
- Windows下实现反向代理的若干途径
- 动画-animation
- php源码安装配置,php源码安装时configure配置参数 | 学步园
- 5个学习Linux命令站点推荐
- CSS可见区域全局居中
- 整洁架构设计分析--架构设计的本质是什么?
- Spring Boot Test 进行JPA 测试保存数据到数据库
- 千万别急着入手 5G 手机!
- php 服务器监控源码,PHP自动Get监控源码
- “配置系统未能初始化” 异常解决
- 【微信小程序】(一)创建项目与前端编写
- 驱动精灵扩展版(集成万能网卡驱动)无法自动识别网卡的解决方案
- 基于Vue3在线商城(Vue3+VueCLI+VueRouter+vuex+axios+Bootstrap)
- arch模型 python_【一点资讯】Python玩转金融时间序列之ARCH与GARCH模型 www.yidianzixun.com...
- TCP Reassembly
- mysql数据丢失原因_分析mysql数据丢失的问题
- 数理统计基础 统计量
- 【模板】普通平衡树,洛谷P3369,splay
- MTK 使用iptable 命令来完成网络路由(android WIFI/4G分享网络)
- 美国大力发展量子产业,国会直接指定能源部制定量子系统访问路线图