配置web.xml
<?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>helloworld</display-name> <!-- 配置编码方式--> <filter> <filter-name>encodingFilter</filter-name> <filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>encoding</param-name> <param-value>UTF-8</param-value> </init-param> <init-param> <param-name>forceEncoding</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>encodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!-- 配置springmvc的前端控制器 指向spring-mvc.xml 程序在启动的时候就加载springmvc 可以接受所有请求 load-on-startup:表示启动容器时初始化该Servlet; --> <servlet> <servlet-name>springServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 可以自定义servlet.xml配置文件的位置和名称, 默认为WEB-INF目录下,名称为[<servlet-name>]-servlet.xml,如spring-servlet.xml --> <init-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:spring/applicationContext.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!-- 将前端URL请求和后台处理方法controller建立对应关系--> <servlet-mapping> <servlet-name>springServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <!-- Spring配置 --> <listener> <listener-class> org.springframework.web.context.ContextLoaderListener </listener-class> </listener> <!-- 取消对某一类文件的拦截--> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.md</url-pattern> </servlet-mapping> <context-param> <param-name>contextConfigLocation</param-name> <param-value> classpath:spring/applicationContext.xml</param-value> </context-param> <!-- 欢迎页面--> <welcome-file-list> <welcome-file>/index.jsp</welcome-file> </welcome-file-list> <!--404错误展示页面,可自行配置--> <!--<error-page>--> <!--<error-code>404</error-code>--> <!--<location>/WEB-INF/views/404.jsp</location>--> <!--</error-page>--> <!--设置session失效时间为30分钟 --> <session-config> <session-timeout>600</session-timeout> </session-config> </web-app>
四、配置tomcat
到这一步springmvc框架就基本搭好了,我们先运行检验一下,这就需要先配置tomcat
- 如图直接点击或者找到 Edit Configurations… 点击
选择本地的tomcat
这里我们选择war exploded模式,网上关于这两个模式的解释是
war模式—-将WEB工程以包的形式上传到服务器
war exploded模式—-将WEB工程以当前文件夹的位置关系上传到服务器
on frame换成update classes and resources,这样修改了jsp页面不用重启服务器,实现热部署,然后点击OK,效果如下图
启动项目。启动成功了,但是发现路径是这样的,因为我们之前选择war exploded模式影响的
正常启动,这个时候springmvc已经完全配置好了.
五、配置mybatis反向生成
mybatis generato
先在spring文件里面增加SqlSessionFactory配置,将这个配置添加到applicationContext.xml文件里面
<!-- 配置会话工厂SqlSessionFactory --> <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> <!-- 数据源 --> <property name="dataSource" ref="dataSource"/> <property name="mapperLocations" value="classpath:sqlmap/*Mapper.xml"/> <property name="typeAliasesPackage" value="com.springmvc.entity" /> </bean> <!-- 在spring容器中配置mapper的扫描器产生的动态代理对象在spring的容器中自动注册,bean的id就是mapper类名(首字母小写)--> <bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"> <!-- 指定扫描包的路径,就是mapper接口的路径,多个包中间以 半角逗号隔开 --> <property name="basePackage" value="com.springmvc.dao"/> <!-- 配置sqlSessionFactoryBeanName --> <property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/> </bean>
配置mybatis-generator添加到generatorConfig.xml文件
<?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE generatorConfiguration PUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN" "http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd"> <generatorConfiguration> <!--导入属性配置 --> <properties resource="generator.properties"/> <!--本地的mysql-connector-java.jar的位置,因为连接数据库是需要驱动的,maven已经帮我们下好了jar包.--> <classPathEntry location="F:\apache-maven\mavanJar\mysql\mysql-connector-java\5.1.29\mysql-connector-java-5.1.29.jar" /> <context id="context1"> <!-- 注释 --> <commentGenerator> <property name="suppressAllComments" value="true" /><!-- 是否取消注释 --> <property name="suppressDate" value="true" /> <!-- 是否生成注释代时间戳 --> </commentGenerator> <jdbcConnection driverClass="${driver}" connectionURL="${url}" userId="${username}" password="${password}" /> <!-- 类型转换 --> <javaTypeResolver> <!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) --> <property name="forceBigDecimals" value="false" /> </javaTypeResolver> <javaModelGenerator targetPackage="${modelPackage}" targetProject="${modelProject}" /> <sqlMapGenerator targetPackage="${sqlPackage}" targetProject="${sqlProject}" /> <javaClientGenerator targetPackage="${mapperPackage}" targetProject="${mapperProject}" type="XMLMAPPER" /> <!-- 如果需要通配所有表 直接用sql的通配符 %即可 --> <table schema="" tableName="${table}" enableCountByExample="false" enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false" selectByExampleQueryId="false"/> </context> </generatorConfiguration>
请注意的是上面的classPathEntry节点的location属性值是本地的mysql-connector-java.jar的位置,因为连接数据库是需要驱动的,我们用maven已经自动帮我们下好了jar包,在左边的External Libraries里面寻找JAR包的路径(下图帮你找寻路径)。
我们按照上图点击Copy Path,然后找到classPathEntry节点的location属性值Ctrl + v 更换为本地mysql jar包路径即可
配置generator.properties
这里面保存的是连接数据库的相关信息,是在使用mybatis-generator这个功能的时候用到的;其实在jdbc.properties是系统运行时用到的。这两个信息差不多,图方便的话,也可以将两个合并成一个文件,分开写的话,好实现可插拔。
driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/mytest?useUnicode=true&characterEncoding=utf-8 username=root password=********* #entity 包名和 java目录 modelPackage=com.springmvc.entity modelProject=src/main/java #sqlmap包名 和resources目录 sqlPackage=sqlmap sqlProject=src/main/resources #mapper包名和 java目录 mapperPackage=com.springmvc.dao mapperProject=src/main/java table=message
modelPackage是等会连接数据库自动生成的实体类保存的位置,sqlPackage是生成xml映射文件保存的位置,mapperPackage是生成数据库接口保存的位置,table是数据库里面的表的名字
创建数据表
这样,我们需要再mytest数据库里创建一个测试用的表。
mybatis基本配置的差不多了,执行maven的mybatis-generator操作,尽管双击便是。
我当时出现一个问题就是找不到mybatis-generator,如果你也出现了这个问题,那就可以参考该博客解决:idea创建Maven项目时插件内看不到mybatis-generator问题解决
当日志中提示"BUILD SUCCESS"意为生成成功,成功以后会对应生成mapper.xml、dao层和entity层的文件,具体效果见下图:
六、配置junit
如果写完一段代码,想去验证他的正确性,并不一定需要去启动tomcat跑跑看或者debug,这时我们就会想到可以使用测试工具来验证,这儿配置junit测试。 那就来测试一下刚生成的message接口有没有用,因为spring的标签,我们先去messagemapper文件加一个@Repository标签,表明它是数据访问组件,即DAO组件
如下图:
接下来就可以新建测试文件开始测试,将鼠标移到MessageMapper后(箭头所指方向),然后键盘上按下快捷键alt+enter键,接着create test
如下图:
选中需要测试的函数方法,点击OK,但是可以发现我这里没有显示测试函数方法,也不用着急,继续看下面
如下图:
如果上面你有测试函数方法并且点击了,之后会在test目录下生成MessageMapperTest测试文件;如果是没有测试方法的我们就按照下面目录自己建一个
如下图:
测试就开始编写MessageMapperTest,编写测试代码。
package com.springmvc.dao; import com.springmvc.entity.Message; import org.junit.After; import org.junit.Before; import org.junit.Test; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; /** * @author yzh * @date 2019-08-19 14:50 */ public class MessageMapperTest { private ApplicationContext applicationContext; @Autowired private MessageMapper mapper; @Before public void setUp() throws Exception { // 加载spring配置文件 applicationContext = new ClassPathXmlApplicationContext("classpath:spring/applicationContext.xml"); // 导入需要测试的 mapper = applicationContext.getBean(MessageMapper.class); } @After public void tearDown() throws Exception { } @Test public void insert() throws Exception { Message message = new Message(); message.setCommand("前端"); message.setContent("后端"); message.setDescription("都会点"); int result = mapper.insert(message); System.out.println(result); assert (result == 1); } }
OK,这样就完成了测试类的编码,接下来运行test,右击这个绿色的小三角,然后运行。
如下图:
运行之后效果图:
OK,运行之后,返回1,表示运行成功。
我们刷新一下数据库看有没有被插入。
到了这里,就算是成功了!如果中间哪里出现了问题可以联系我。