时间/12/31,使用的包都是最新的和用的人最多的QAQ。
Maven仓库查找包的地址
/
在经历了70多个小时的奋斗后(花了60个小时学习了下SSM框架和Maven仓库),终于搭建成功了,这一篇将超级详细的讲诉如何Maven环境下搭建Spring,SpringMvc,MyBatis
最后对他们进行整合(整合这一块我整了10多个小时,终于整出来了( ̄﹏ ̄;))
附上项目地址:
里面包含一个c3p0配置的和druid配置的,其中c3p0配置的就是下面教程里配置的最终结果
想偷懒的可以直接去下载
/296326173/SSM/tree/master
本来是不打算写的,但是自己配置这个东西走的路程太过坎坷,还是想分享出来让别人少走点弯路,因为去网上看其他博客的SSM配置,没有一个成功的,可能和我无脑拷贝有关系吧QAQ。所以,我将详细的说每一个配置,告诉你哪里需要修改成你自己的路径
这里先将配置C3P0的数据库连接池,下一篇继续更改为Druid连接池(这东西挺好整出来的,就是很配置的多了点)。
第一次写这个东西,不知道如何做树形图,以后知道了再修改吧。懒得百度了。QAQQQQQQ
所以这一篇将会超级长,超级详细。(不要管前后又没逻辑关系QAQ,紧张(/▽\))
有基础的下面的可以不看(主要给像我一样什么都不懂看的,可以直接跳哒)
先上结果图,让你们心里有个底
先来解释下目录结构(这个很重要),这里目录结构太长了,一张图截图不下来QAQQQQQ
这里可以先不写代码啦,最后加进来测试就好了,最后我还会再说明一次的,这里主要是便于理解(这里长长的一段只是解释,还没开始)
untils工具包类,主要内容是放了一个获取项目根路径的类(要写这个的原因是,我刚刚配置的时候项目路径都写错,根本不会QAQ,有了这个写的就方便很多了,简化了项目路径的格式),其他的工具类你们自行添加/*** @author: 航航* @Description:* 不匹配任何路径,跟随服务器启动而启动* 在上下文中存储了一个RootPath的值,值为根路径,使用方式 ${RootPath}* @Date: 11:33 /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 /12/30 36*/@Controllerpublic 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@Repositorypublic 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接口@Repositorypublic interface GirlService {Girl selectGirl() throws Exception;}//下面是serviceImpl包里的实现 GirlServiceImp@Serviceclass 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 "-////DTD Mapper 3.0//EN""/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”jsJavaScript静态资源文件目录,路径为/static/jsimages放置图片资源文件的目录,路径为/static/imagescss放置CSS样式的目录,路径为/static/cssWEB-INF路径/WEB-INFviews路径/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><piler.source>1.8</piler.source><piler.target>1.8</piler.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>--><!--数据库连接池 /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 /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="/POM/4.0.0" xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/POM/4.0.0 /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></url><properties><project.build.sourceEncoding>UTF-8</project.build.sourceEncoding><piler.source>1.8</piler.source><piler.target>1.8</piler.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>--><!--数据库连接池 /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 /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 /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="/schema/beans"xmlns:xsi="/2001/XMLSchema-instance"xmlns:context="/schema/context"xsi:schemaLocation="/schema/beans/schema/beans/spring-beans.xsd/schema/context/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="/schema/beans"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/schema/beans /schema/beans/spring-beans.xsd"></beans>
接下来打开web.xml(重头戏)
上面一处修改的目的是让程序找到applicationContext.xml文件
下面一处可以不修改,像我这样我萌新就修改为“/”就可以了。这里表示所有请求要走Controller包下的DispatcherServlet。
还需要在<web-app>标签里添加一点点内容
<web-app xmlns="/xml/ns/javaee"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/xml/ns/javaee/xml/ns/javaee/web-app_4_0.xsd"version="4.0">
完整的内容
<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN""/dtd/web-app_2_3.dtd" ><web-app xmlns="/xml/ns/javaee"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/xml/ns/javaee/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#关闭连接后不自动commitc3p0.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 "-////DTD Config 3.0//EN" "/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语句
@Repositorypublic interface GirlMapper {Girl queryById(Integer id);}
在resources/mapper创建一个GirlMapper.xml的文件
内容如下
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapperPUBLIC "-////DTD Mapper 3.0//EN""/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 "-////DTD Config 3.0//EN" "/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="/schema/beans"xmlns:xsi="/2001/XMLSchema-instance"xmlns:context="/schema/context"xmlns:mvc="/schema/mvc"xsi:schemaLocation="/schema/beans/schema/beans/spring-beans.xsd/schema/context/schema/context/spring-context.xsd /schema/mvc /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.monsMultipartResolver"><!-- 默认编码 --><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""/dtd/web-app_2_3.dtd" ><web-app xmlns="/xml/ns/javaee"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/xml/ns/javaee/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,内容如下
@Controllerpublic 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: /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="/schema/beans"xmlns:xsi="/2001/XMLSchema-instance"xmlns:context="/schema/context"xmlns:tx="/schema/tx"xsi:schemaLocation="/schema/beans/schema/beans/spring-beans.xsd/schema/context/schema/context/spring-context.xsd/schema/tx/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.boPooledDataSource" 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""/dtd/web-app_2_3.dtd" ><web-app xmlns="/xml/ns/javaee"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/xml/ns/javaee/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""/dtd/web-app_2_3.dtd" ><web-app xmlns="/xml/ns/javaee"xmlns:xsi="/2001/XMLSchema-instance"xsi:schemaLocation="/xml/ns/javaee/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接口,内容如下
@Controllerpublic 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类,内容如下
@Serviceclass GirlServiceImp implements GirlService {@Autowiredprivate GirlMapper girlMapper;@Overridepublic Girl selectGirl() throws Exception {return girlMapper.queryById(1);}}
在controller包新建一个GirlController类,内容如下
@Controllerpublic 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的下次再加,写不动了,下次接着写