目录

1. 创建Maven项目

1.1 创建一个新的项目  (请先连接好网络)

1.2 选择maven --> 选择你的jdk版本 --> 勾选Create from archetype

1.3 随便选中一条输入webapp进行模糊查询然后选中下列我选中的内容(重要!不可错)

1.4 填写你的项目名 --> 选择项目保存到你的电脑地址 --> 随便写(最好用两个单词中间用.隔开) --> 和项目名保持一致

1.5 选择你的maven安装包地址 --> 查看settings.xml文件是否在idea显示的地址 -->查看你的下载资源本地仓库是否在idea显示的地址(如果有误或自己整改过都要进行修改和idea保持一致)

1.6 正在创建中...请稍后(注意!!!创建maven项目请先连接网络)

1.7 控制台出现(BUILD SUCCESS)代表Maven项目已创建成功

2. 搭建项目相关目录

2.1 选中main文件夹右键

2.2 new一个新的文件夹选中(new --> Directory)

2.3 此操作要操作两遍因为要添加下方图中这两个文件夹(java,resources)

2.4 选中src文件夹右键

2.5 new一个新的文件夹(new --> Directory)

2.6 选中添加下方图中文件夹即可(test\java)

3. 添加pom相关依赖

4. 添加/修改相关配置文件

4.1 jdbc.properties(添加到main文件夹 --> resources文件夹下面)

4.2 log4j2.xml(添加到main文件夹 --> resources文件夹下面)

4.3 mybatis.cfg.xml(添加到main文件夹 --> resources文件夹下面)

4.4 spring.xml(添加到main文件夹 --> resources文件夹下面)

4.5 spring-mybatis.xml(添加到main文件夹 --> resources文件夹下面)

4.6 spring-mvc.xml(添加到main文件夹 --> webapp文件夹 --> WEB-INF文件夹下面)

4.7 修改web.xml相关配置

4.8 generatorConfig.xml(添加到main文件夹 --> resources文件夹下面)

4.8.1 添加Maven自动生成插件

5. 使用junit and Tomcat分别测试是否搭建成功

5.1 junit测试

5.2 Tomcat测试


1. 创建Maven项目

1.1 创建一个新的项目  (请先连接好网络)

1.2 选择maven --> 选择你的jdk版本 --> 勾选Create from archetype

1.3 随便选中一条输入webapp进行模糊查询然后选中下列我选中的内容(重要!不可错)

1.4 填写你的项目名 --> 选择项目保存到你的电脑地址 --> 随便写(最好用两个单词中间用.隔开) --> 和项目名保持一致

1.5 选择你的maven安装包地址 --> 查看settings.xml文件是否在idea显示的地址 -->查看你的下载资源本地仓库是否在idea显示的地址(如果有误或自己整改过都要进行修改和idea保持一致)

1.6 正在创建中...请稍后(注意!!!创建maven项目请先连接网络)

1.7 控制台出现(BUILD SUCCESS)代表Maven项目已创建成功

2. 搭建项目相关目录

2.1 选中main文件夹右键

2.2 new一个新的文件夹选中(new --> Directory)

2.3 此操作要操作两遍因为要添加下方图中这两个文件夹(java,resources)

2.4 选中src文件夹右键

2.5 new一个新的文件夹(new --> Directory)

2.6 选中添加下方图中文件夹即可(test\java)

3. 添加pom相关依赖

  • 直接复制下方依赖覆盖你自己创建好的项目pom文件中即可
<?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.jmh</groupId><artifactId>mybatis03</artifactId><version>1.0-SNAPSHOT</version><packaging>war</packaging><name>mybatis03 Maven Webapp</name><!-- FIXME change it to the project's website --><url>http://www.example.com</url><!--版本--><properties><spring.version>5.0.2.RELEASE</spring.version><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target><jackson.version>2.9.3</jackson.version><shiro.version>1.2.5</shiro.version><slf4j.version>1.7.7</slf4j.version><log4j2.version>2.9.1</log4j2.version></properties><dependencies><!-- **********************spring依赖 ********************** --><!--1)spring核心依赖--><!-- ********************** spring-ore核心依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>${spring.version}</version></dependency><!--spring ioc依赖 --><!-- ********************** spring-ioc依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-beans</artifactId><version>${spring.version}</version></dependency><!--spring 扩展依赖 --><!-- ********************** spring-context依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>${spring.version}</version></dependency><!--2)spring dao层依赖--><!-- ********************** spring-orm依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-orm</artifactId><version>${spring.version}</version></dependency><!-- ********************** spring-tx依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>${spring.version}</version></dependency><!--3)aop相关依赖 --><!-- ********************** spring-aspects依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-aspects</artifactId><version>${spring.version}</version></dependency><!--4)spring web相关依赖 --><!-- ********************** spring-web依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>${spring.version}</version></dependency><!--5) spring test相关依赖 --><!-- ********************** spring-test依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring.version}</version></dependency><!-- ********************** spring-webmvc依赖 ********************** --><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>${spring.version}</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><!-- ********************** Json相关依赖 ********************** --><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>${jackson.version}</version><exclusions><exclusion><artifactId>jackson-annotations</artifactId><groupId>com.fasterxml.jackson.core</groupId></exclusion></exclusions></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-core</artifactId><version>${jackson.version}</version></dependency><dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-annotations</artifactId><version>${jackson.version}</version></dependency><!-- ********************** 文件上传依赖 ********************** --><dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.3</version></dependency><!-- ********************** JSR303依赖 ********************** --><dependency><groupId>org.hibernate</groupId><artifactId>hibernate-validator</artifactId><version>6.0.7.Final</version></dependency><!-- ********************** junit单元测试依赖 ********************** --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!-- ********************** JavaServlet API  ********************** --><dependency><groupId>javax.servlet</groupId><artifactId>javax.servlet-api</artifactId><version>4.0.0</version><scope>provided</scope></dependency><!-- ********************** Mybatis依赖 ********************** --><!--1) mybatis核心 --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.4.5</version></dependency><!--2) Mybatis分页插件--><!-- ********************** Mybatis分页插件 ********************** --><dependency><groupId>com.github.pagehelper</groupId><artifactId>pagehelper</artifactId><version>5.1.2</version></dependency><!--3) spring整合mybatis --><!-- ********************** spring整合mybatis ********************** --><dependency><groupId>org.mybatis</groupId><artifactId>mybatis-spring</artifactId><version>1.3.1</version></dependency><!-- ********************** MysqlJDBC驱动 ********************** --><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.44</version></dependency><!--dbcp2连接池依赖--><!-- ********************** dbcp2连接池依赖 ********************** --><dependency><groupId>org.apache.commons</groupId><artifactId>commons-dbcp2</artifactId><version>2.1.1</version></dependency><!-- ********************** commons-pool2 ********************** --><dependency><groupId>org.apache.commons</groupId><artifactId>commons-pool2</artifactId><version>2.4.3</version></dependency><!-- **********************  日志配置  ********************** --><!--记得修改mybatis.cfg.xml添加如下内容--><!--<setting name="logImpl"value="LOG4J2"/>--><dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>${slf4j.version}</version></dependency><dependency><groupId>org.slf4j</groupId><artifactId>jcl-over-slf4j</artifactId><version>${slf4j.version}</version><scope>runtime</scope><exclusions><exclusion><artifactId>slf4j-api</artifactId><groupId>org.slf4j</groupId></exclusion></exclusions></dependency><!-- 用于与slf4j保持桥接--><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-slf4j-impl</artifactId><version>${log4j2.version}</version><exclusions><exclusion><artifactId>slf4j-api</artifactId><groupId>org.slf4j</groupId></exclusion></exclusions></dependency><!--核心log4j2jar包--><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-core</artifactId><version>${log4j2.version}</version></dependency><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-api</artifactId><version>${log4j2.version}</version></dependency><!--web工程需要包含log4j-web,非web工程不需要--><dependency><groupId>org.apache.logging.log4j</groupId><artifactId>log4j-web</artifactId><version>${log4j2.version}</version></dependency><!--需要使用log4j2的AsyncLogger需要包含disruptor --><dependency><groupId>com.lmax</groupId><artifactId>disruptor</artifactId><version>3.2.0</version></dependency><!-- **********************  lombok依赖  ********************** --><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.20</version><scope>provided</scope></dependency><!-- ********************** shiro相关依赖  ********************** --><!-- shiro核心包 --><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-core</artifactId><version>${shiro.version}</version></dependency><!-- 添加shiro web支持 --><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-web</artifactId><version>${shiro.version}</version></dependency><!--shiro和spring的集成--><dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-spring</artifactId><version>${shiro.version}</version></dependency></dependencies><!--插件部分--><build><finalName>ssm</finalName><resources><!--解决mybatis-generator-maven-plugin运行时没有将XxxMapper.xml文件放入target文件夹的问题--><resource><directory>src/main/java</directory><includes><include>**/*.xml</include></includes></resource><!--解决mybatis-generator-maven-plugin运行时没有将jdbc.properites文件放入target文件夹的问题--><resource><directory>src/main/resources</directory><includes><include>jdbc.properties</include><include>*.xml</include></includes></resource></resources><pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) --><plugins><plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.2</version><dependencies><!--使用Mybatis-generator插件不能使用太高版本的mysql驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.44</version></dependency></dependencies><configuration><overwrite>true</overwrite></configuration></plugin></plugins></pluginManagement></build>
</project>

4. 添加/修改相关配置文件

4.1 jdbc.properties(添加到main文件夹 --> resources文件夹下面)

下方配置文件需要修改:

1. 你的数据库名称

2. 你的数据库登录账号

3. 你的数据库登录密码

jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/你的数据库名称?useUnicode=true&characterEncoding=UTF-8
jdbc.username=你的数据库登录账号
jdbc.password=你的数据库登录密码

4.2 log4j2.xml(添加到main文件夹 --> resources文件夹下面)

<?xml version="1.0" encoding="UTF-8"?><!-- status : 指定log4j本身的打印日志的级别.ALL< Trace < DEBUG < INFO < WARN < ERROR < FATAL < OFF。 monitorInterval : 用于指定log4j自动重新配置的监测间隔时间,单位是s,最小是5s. -->
<Configuration status="WARN" monitorInterval="30"><Properties><!-- 配置日志文件输出目录 ${sys:user.home} --><Property name="LOG_HOME">/root/workspace/lucenedemo/logs</Property><property name="ERROR_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/error</property><property name="WARN_LOG_FILE_NAME">/root/workspace/lucenedemo/logs/warn</property><property name="PATTERN">%d{yyyy-MM-dd HH:mm:ss.SSS} [%t-%L] %-5level %logger{36} - %msg%n</property></Properties><Appenders><!--这个输出控制台的配置 --><Console name="Console" target="SYSTEM_OUT"><!-- 控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) --><ThresholdFilter level="trace" onMatch="ACCEPT"onMismatch="DENY" /><!-- 输出日志的格式 --><!-- %d{yyyy-MM-dd HH:mm:ss, SSS} : 日志生产时间 %p : 日志输出格式 %c : logger的名称 %m : 日志内容,即 logger.info("message") %n : 换行符 %C : Java类名 %L : 日志输出所在行数 %M : 日志输出所在方法名 hostName : 本地机器名 hostAddress : 本地ip地址 --><PatternLayout pattern="${PATTERN}" /></Console><!--文件会打印出所有信息,这个log每次运行程序会自动清空,由append属性决定,这个也挺有用的,适合临时测试用 --><!--append为TRUE表示消息增加到指定文件中,false表示消息覆盖指定的文件内容,默认值是true --><File name="log" fileName="logs/test.log" append="false"><PatternLayoutpattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" /></File><!-- 这个会打印出所有的info及以下级别的信息,每次大小超过size, 则这size大小的日志会自动存入按年份-月份建立的文件夹下面并进行压缩,作为存档 --><RollingFile name="RollingFileInfo" fileName="${LOG_HOME}/info.log"filePattern="${LOG_HOME}/$${date:yyyy-MM}/info-%d{yyyy-MM-dd}-%i.log"><!--控制台只输出level及以上级别的信息(onMatch),其他的直接拒绝(onMismatch) --><ThresholdFilter level="info" onMatch="ACCEPT"onMismatch="DENY" /><PatternLayoutpattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" /><Policies><!-- 基于时间的滚动策略,interval属性用来指定多久滚动一次,默认是1 hour。 modulate=true用来调整时间:比如现在是早上3am,interval是4,那么第一次滚动是在4am,接着是8am,12am...而不是7am. --><!-- 关键点在于 filePattern后的日期格式,以及TimeBasedTriggeringPolicy的interval, 日期格式精确到哪一位,interval也精确到哪一个单位 --><!-- log4j2的按天分日志文件 : info-%d{yyyy-MM-dd}-%i.log --><TimeBasedTriggeringPolicy interval="1"modulate="true" /><!-- SizeBasedTriggeringPolicy:Policies子节点, 基于指定文件大小的滚动策略,size属性用来定义每个日志文件的大小. --><!-- <SizeBasedTriggeringPolicy size="2 kB" /> --></Policies></RollingFile><RollingFile name="RollingFileWarn" fileName="${WARN_LOG_FILE_NAME}/warn.log"filePattern="${WARN_LOG_FILE_NAME}/$${date:yyyy-MM}/warn-%d{yyyy-MM-dd}-%i.log"><ThresholdFilter level="warn" onMatch="ACCEPT"onMismatch="DENY" /><PatternLayoutpattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" /><Policies><TimeBasedTriggeringPolicy /><SizeBasedTriggeringPolicy size="2 kB" /></Policies><!-- DefaultRolloverStrategy属性如不设置,则默认为最多同一文件夹下7个文件,这里设置了20 --><DefaultRolloverStrategy max="20" /></RollingFile><RollingFile name="RollingFileError" fileName="${ERROR_LOG_FILE_NAME}/error.log"filePattern="${ERROR_LOG_FILE_NAME}/$${date:yyyy-MM}/error-%d{yyyy-MM-dd-HH-mm}-%i.log"><ThresholdFilter level="error" onMatch="ACCEPT"onMismatch="DENY" /><PatternLayoutpattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n" /><Policies><!-- log4j2的按分钟 分日志文件 : warn-%d{yyyy-MM-dd-HH-mm}-%i.log --><TimeBasedTriggeringPolicy interval="1"modulate="true" /><!-- <SizeBasedTriggeringPolicy size="10 MB" /> --></Policies></RollingFile></Appenders><!--然后定义logger,只有定义了logger并引入的appender,appender才会生效 --><Loggers><!--过滤掉spring和mybatis的一些无用的DEBUG信息 --><logger name="org.springframework" level="INFO"></logger><logger name="org.mybatis" level="INFO"></logger><!-- 第三方日志系统 --><logger name="org.springframework" level="ERROR" /><logger name="org.hibernate" level="ERROR" /><logger name="org.apache.struts2" level="ERROR" /><logger name="com.opensymphony.xwork2" level="ERROR" /><logger name="org.jboss" level="ERROR" /><!-- 配置日志的根节点 --><root level="all"><appender-ref ref="Console" /><appender-ref ref="RollingFileInfo" /><appender-ref ref="RollingFileWarn" /><appender-ref ref="RollingFileError" /></root></Loggers></Configuration>

4.3 mybatis.cfg.xml(添加到main文件夹 --> resources文件夹下面)

<?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><!--日志配置--><settings><setting name="logImpl" value="LOG4J2"/></settings><!--分页配置--><plugins><plugin interceptor="com.github.pagehelper.PageInterceptor"></plugin></plugins></configuration>

4.4 spring.xml(添加到main文件夹 --> resources文件夹下面)

<?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"><!--1. 引入外部properties文件 --><bean id="propertyConfigurer"class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"><property name="systemPropertiesModeName" value="SYSTEM_PROPERTIES_MODE_OVERRIDE" /><property name="ignoreResourceNotFound" value="true" /><property name="locations"><list><value>classpath:jdbc.properties</value><!--<value>classpath:config.properties</value>--><!--<value>classpath:shiro-config.properties</value>--></list></property></bean><import resource="spring-mybatis.xml"/><!--导入的是下方4.5配置文件-->
</beans>

4.5 spring-mybatis.xml(添加到main文件夹 --> resources文件夹下面)

下方配置文件需要修改(注!!!需要修改的地方已用注释标注):

   

<?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"xmlns:aop="http://www.springframework.org/schema/aop"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"><!--1. 注解式开发 --><!--1) 注解驱动 -->
<!--    <context:annotation-config/>&lt;!&ndash;2) 用注解方式注入bean,并指定查找范围:com.zking.oa及子子孙孙包&ndash;&gt;<context:component-scan base-package="com.jmh.mybatis"/>--><!--****************************** 需要修改01 ***************************************--><context:component-scan base-package="com.jmh.shiro" use-default-filters="true"><context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/><!--<context:exclude-filter type="regex" expression=".+\.controller2\..*"/>--></context:component-scan><!-- 已在spring.xml中配置,只能引入一次 --><!--2. 引入外置jdbc配置文件 --><!--<bean id="propertyConfigurer" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">--><!--<property name="location" value="classpath:jdbc.properties"/>--><!--</bean>--><!--3. dbcp2数据库连接池配置--><bean id="dataSource" class="org.apache.commons.dbcp2.BasicDataSource"destroy-method="close"><property name="driverClassName" value="${jdbc.driver}"/><property name="url" value="${jdbc.url}"/><property name="username" value="${jdbc.username}"/><property name="password" value="${jdbc.password}"/><!--初始连接数--><property name="initialSize" value="10"/><!--最大活动连接数--><property name="maxTotal" value="100"/><!--最大空闲连接数--><property name="maxIdle" value="50"/><!--最小空闲连接数--><property name="minIdle" value="10"/><!--设置为-1时,如果没有可用连接,连接池会一直无限期等待,直到获取到连接为止。--><!--如果设置为N(毫秒),则连接池会等待N毫秒,等待不到,则抛出异常--><property name="maxWaitMillis" value="-1"/></bean><!--4. spring和MyBatis整合 --><!--1) 创建sqlSessionFactory--><bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"><!-- 指定数据源 --><property name="dataSource" ref="dataSource"/><!-- 指定mybatis核心配置文件 --><property name="configLocation" value="classpath:mybatis.cfg.xml"/><!-- 自动扫描XxxMapping.xml文件,**任意路径 --><!--****************************** 需要修改02 ***************************************--><property name="mapperLocations" value="classpath:com/jmh/shiro/**/mapper/*.xml"/><!-- 指定别名 --><!--****************************** 需要修改03 ***************************************--><property name="typeAliasesPackage" value="com.jmh.shiro.model"/></bean><!--2) 自动扫描com/zking/oa/**/mapper下的所有XxxMapper接口(其实就是DAO接口),并实现这些接口,--><!--   即可直接在程序中使用dao接口,不用再获取sqlsession对象--><bean class="org.mybatis.spring.mapper.MapperScannerConfigurer"><!--basePackage 属性是映射器接口文件的包路径。--><!--你可以使用分号或逗号 作为分隔符设置多于一个的包路径--><!--****************************** 需要修改04 ***************************************--><property name="basePackage" value="com/jmh/shiro/**/mapper"/><!--需修改--><property name="sqlSessionFactoryBeanName" value="sqlSessionFactory"/></bean><!--1) 事务管理器 --><bean id="transactionManager"class="org.springframework.jdbc.datasource.DataSourceTransactionManager"><property name="dataSource" ref="dataSource"/></bean><!--2. 注解式事务配置开始 --><tx:annotation-driven transaction-manager="transactionManager"/><!--3) 开启自动代理 --><aop:aspectj-autoproxy/>
</beans>

4.6 spring-mvc.xml(添加到main文件夹 --> webapp文件夹 --> WEB-INF文件夹下面)

下方配置文件需要修改(注!!!需要修改的地方已用注释标注):

<?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/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-4.3.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"><!-- 通过context:component-scan元素扫描指定包下的控制器--><!--1) 扫描com.zking.zf及子子孙孙包下的控制器(扫描范围过大,耗时)--><!--<context:component-scan base-package="com.zking.zf"/>--><!--1) use-dafault-filters="false"的情况下,根据表达式包含(include-filter)或排除(exclude-filter)指定包--><!--****************************** 需要修改01 ***************************************--><context:component-scan base-package="com.jmh.shiro" use-default-filters="false"><context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/><!--<context:exclude-filter type="regex" expression=".+\.controller2\..*"/>--></context:component-scan><!--2) 此标签默认注册DefaultAnnotationHandlerMapping和AnnotationMethodHandlerAdapter --><!--两个bean,这两个bean是spring MVC为@Controllers分发请求所必须的。并提供了数据绑定支持,--><!--@NumberFormatannotation支持,@DateTimeFormat支持,@Valid支持,读写XML的支持(JAXB),读写JSON的支持(Jackson)--><mvc:annotation-driven></mvc:annotation-driven><!--3) ViewResolver --><bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"><!-- viewClass需要在pom中引入两个包:standard.jar and jstl.jar --><property name="viewClass"value="org.springframework.web.servlet.view.JstlView"></property><property name="prefix" value="/WEB-INF/jsp/"/><property name="suffix" value=".jsp"/></bean><!--4) 单独处理图片、样式、js等资源 --><mvc:resources location="/static/css/" mapping="/static/css/**"/><mvc:resources location="/static/images/" mapping="/static/images/**"/><mvc:resources location="/static/js/" mapping="/static/js/**"/></beans>

4.7 修改web.xml相关配置

  • 可直接复制覆盖你的web.xml文件

下方配置文件需要修改(注!!!需要修改的地方已用注释标注):

1. 需要修改01(你要映射的.xml文件名)

2. 需要修改02  (中文乱码过滤器配置(已在下方提供代码资源))

3. 需要修改03  (那里面的.xml文件修改成上方4.6添加的spring-mvc.xml文件名即可)

<?xml version="1.0" encoding="UTF-8"?>
<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/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"version="3.1"><display-name>Archetype Created Web Application</display-name><!-- Spring和web项目集成start --><!-- spring上下文配置文件 --><context-param><param-name>contextConfigLocation</param-name><!--****************************** 需要修改01 ***************************************--><param-value>classpath:spring.xml</param-value></context-param><!-- 读取Spring上下文的监听器 --><listener><listener-class>org.springframework.web.context.ContextLoaderListener</listener-class></listener><!-- Spring和web项目集成end --><!-- 防止Spring内存溢出监听器 --><listener><listener-class>org.springframework.web.util.IntrospectorCleanupListener</listener-class></listener><!-- 中文乱码处理 --><filter><filter-name>encodingFilter</filter-name><!--****************************** 需要修改02 ***************************************--><filter-class>com.jmh.shiro.utils.EncodingFiter</filter-class><!--web.xml 3.0的新特性,是否支持异步--><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><!--此参数可以不配置,默认值为:/WEB-INF/springmvc-servlet.xml--><init-param><param-name>contextConfigLocation</param-name><!--****************************** 需要修改03 ***************************************--><param-value>/WEB-INF/spring-mvc.xml</param-value></init-param><load-on-startup>1</load-on-startup><!--web.xml 3.0的新特性,是否支持异步--><async-supported>true</async-supported></servlet><servlet-mapping><servlet-name>SpringMVC</servlet-name><url-pattern>/</url-pattern></servlet-mapping>
</web-app>
  • EncodingFiter
package com.jmh.ssm.utils;import javax.servlet.*;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.util.Map;/*** 中文乱码处理**/
public class EncodingFiter implements Filter {private String encoding = "UTF-8";// 默认字符集public EncodingFiter() {super();}public void destroy() {}public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain chain)throws IOException, ServletException {HttpServletRequest request = (HttpServletRequest) servletRequest;HttpServletResponse response = (HttpServletResponse) servletResponse;String method = request.getMethod();if (method.equalsIgnoreCase("get")) {Map<String, String[]> map = (Map<String, String[]>) request.getParameterMap();// 保存所有参数名=参数值(数组)的Map集合for (String[] values : map.values()) {for (int i = 0; i < values.length; i++) {values[i] = new String(values[i].getBytes("ISO-8859-1"), this.encoding);}}} else if (method.equalsIgnoreCase("post")) {request.setCharacterEncoding(this.encoding);}response.setContentType("text/html;charset=" + this.encoding);chain.doFilter(servletRequest, servletResponse);}public void init(FilterConfig filterConfig) throws ServletException {String s = filterConfig.getInitParameter("encoding");// 读取web.xml文件中配置的字符集if (null != s && !s.trim().equals("")) {this.encoding = s.trim();}}}

4.8 generatorConfig.xml(添加到main文件夹 --> resources文件夹下面)

下方配置文件需要修改(注!!!需要修改的地方已用注释标注):

  1. 需要修改01 (你的mysql jar包的放置地址路径位置)

2. 需要修改02 (生成实体类的模块位置比如xxx.xxx.xxx.model)

3. 需要修改03 (生成sql映射文件位置)

4. 需要修改04 (生成mapper接口位置)

5. 最后就是table标签需要修改的属性值!一个table标签就是一张表可以这么理解

需要修改的table标签也就两个属性:

5.1 tableName="这里填写的就是你要生成的表名称"

5.2 domainObjectName="这里就是你要生成的表对应的实体类名称"

<?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="jdbc.properties"/><!--指定数据库jdbc驱动jar包的位置--><!--****************************** 需要修改01 ***************************************--><classPathEntry location="E:\\mysql"/><!-- 一个数据库一个context --><context id="infoGuardian"><!-- 注释 --><commentGenerator><property name="suppressAllComments" value="true"/><!-- 是否取消注释 --><property name="suppressDate" value="true"/> <!-- 是否生成注释代时间戳 --></commentGenerator><!-- jdbc连接 --><jdbcConnection driverClass="${jdbc.driver}"connectionURL="${jdbc.url}" userId="${jdbc.username}" password="${jdbc.password}"/><!-- 类型转换 --><javaTypeResolver><!-- 是否使用bigDecimal, false可自动转化以下类型(Long, Integer, Short, etc.) --><property name="forceBigDecimals" value="false"/></javaTypeResolver><!-- 01 指定javaBean生成的位置 --><!-- targetPackage:指定生成的model生成所在的包名 --><!-- targetProject:指定在该项目下所在的路径  --><!--****************************** 需要修改02 ***************************************--><javaModelGenerator targetPackage="com.jmh.shiro.model"targetProject="src/main/java"><!-- 是否允许子包,即targetPackage.schemaName.tableName --><property name="enableSubPackages" value="false"/><!-- 是否对model添加构造函数 --><property name="constructorBased" value="true"/><!-- 是否针对string类型的字段在set的时候进行trim调用 --><property name="trimStrings" value="false"/><!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 --><property name="immutable" value="false"/></javaModelGenerator><!-- 02 XxxMapper.xml指定sql映射文件生成的位置 --><!--****************************** 需要修改03 ***************************************--><sqlMapGenerator targetPackage="com.jmh.shiro.mapper"targetProject="src/main/java"><!-- 是否允许子包,即targetPackage.schemaName.tableName --><property name="enableSubPackages" value="false"/></sqlMapGenerator><!-- 03 生成XxxMapper接口 --><!-- type="ANNOTATEDMAPPER",生成Java Model 和基于注解的Mapper对象 --><!-- type="MIXEDMAPPER",生成基于注解的Java Model 和相应的Mapper对象 --><!-- type="XMLMAPPER",生成SQLMap XML文件和独立的Mapper接口 --><!--****************************** 需要修改04 ***************************************--><javaClientGenerator targetPackage="com.jmh.shiro.mapper"targetProject="src/main/java" type="XMLMAPPER"><!-- 是否在当前路径下新加一层schema,false路径com.oop.eksp.user.model, true:com.oop.eksp.user.model.[schemaName] --><property name="enableSubPackages" value="false"/></javaClientGenerator><!-- 配置表信息 --><!-- schema即为数据库名 --><!-- tableName为对应的数据库表 --><!-- domainObjectName是要生成的实体类 --><!-- enable*ByExample是否生成 example类 --><table schema="" tableName="t_sys_user" domainObjectName="User"enableCountByExample="false" enableDeleteByExample="false"enableSelectByExample="false" enableUpdateByExample="false"><!-- 忽略列,不生成bean 字段 --><!-- <ignoreColumn column="FRED" /> --><!-- 指定列的java数据类型 --><!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> --></table><table schema="" tableName="t_sys_permission" domainObjectName="Permission"enableCountByExample="false" enableDeleteByExample="false"enableSelectByExample="false" enableUpdateByExample="false"><!-- 忽略列,不生成bean 字段 --><!-- <ignoreColumn column="FRED" /> --><!-- 指定列的java数据类型 --><!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> --></table><table schema="" tableName="t_sys_role" domainObjectName="Role"enableCountByExample="false" enableDeleteByExample="false"enableSelectByExample="false" enableUpdateByExample="false"><!-- 忽略列,不生成bean 字段 --><!-- <ignoreColumn column="FRED" /> --><!-- 指定列的java数据类型 --><!-- <columnOverride column="LONG_VARCHAR_FIELD" jdbcType="VARCHAR" /> --></table></context>
</generatorConfiguration>

4.8.1 添加Maven自动生成插件

命令如下:

mybatis-generator:generate -e

好吧!我还是当个老保姆一步步带你们怎么添加好吧 [表情委屈委屈]

4.8.1.1

4.8.1.2 点击+号

4.8.1.3 选择Maven

4.8.1.4 注意!复制命令的时候不要多复制空

4.8.1.5

4.8.1.6 ok!下方就是生成成功啦 如果你没有像图中这个小企鹅的话你也可以忽略这个作用就是方便我们查看sql映射文件的代码...如果你想要这个功能的话下载Mybatis插件“ free mybatis plugins”如果没有这个插件的话就是版本问题就下载Mybatis插件‘’ MybatisX ”

ok!ssm项目基本就搭建好了然后下方我们就测试一下吧

5. 使用junit and Tomcat分别测试是否搭建成功

5.1 junit测试

5.1.1 需要在Mapper层接口添加@Repository注解

@Repository    将DAO类声明为Bean3

5.1.2 Service层代码 需在service层接口添加@Transactional注解

  • 可直接复制Mapper接口粘贴即可需修改@注解

@Transactional 注解配置事务,个人感觉写XML配置声明式事务更加简单

@Transactional(readOnly = true) 在方法前面加上就代表是只读事务

package com.jmh.ssm.service;import com.jmh.ssm.model.User;
import org.springframework.stereotype.Repository;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;@Transactional
public interface IUserService {int deleteByPrimaryKey(Integer userid);int insert(User record);int insertSelective(User record);@Transactional(readOnly = true)User selectByPrimaryKey(Integer userid);int updateByPrimaryKeySelective(User record);int updateByPrimaryKey(User record);
}

5.1.3 Service.impl层代码 需在Service.impl层接口实现类添加@Service() 注解

  • 此时Service实现类需要依赖Mapper层接口 我们需要注入Mapper层接口添加@Resource注解

@Service() 通常作用在业务层

@Resource的装配顺序:
1、@Resource后面没有任何内容,默认通过name属性去匹配bean,找不到再按type去匹配
2、指定了name或者type则根据指定的类型去匹配bean
3、指定了name和type则根据指定的name和type去匹配bean,任何一个不匹配都将报错

package com.jmh.ssm.service.impl;import com.jmh.ssm.mapper.UserMapper;
import com.jmh.ssm.model.User;
import com.jmh.ssm.service.IUserService;
import org.springframework.stereotype.Service;import javax.annotation.Resource;@Service
public class UserServiceImpl implements IUserService {//注入@Resourceprivate UserMapper userMapper;@Overridepublic int deleteByPrimaryKey(Integer userid) {return 0;}@Overridepublic int insert(User record) {return 0;}@Overridepublic int insertSelective(User record) {return 0;}@Overridepublic User selectByPrimaryKey(Integer userid) {return userMapper.selectByPrimaryKey(userid);}@Overridepublic int updateByPrimaryKeySelective(User record) {return 0;}@Overridepublic int updateByPrimaryKey(User record) {return 0;}
}

5.1.4 使用junit单元测试

  • 创建BaseTestCat类

创建BaseTestCat类需添加以下两个注解:

@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:spring.xml"})spring.xml文件对应你要映射的.xml文件名

package com.jmh.mybatis.service.impl;import org.junit.Before;
import org.junit.runner.RunWith;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration(locations={"classpath:spring.xml"})
public class BaseTestCat {@Beforepublic void setUp(){}
}
  • 创建junit测试类需继承上方BaseTestCat类 重写BaseTestCat类里面的方法
package com.jmh.ssm.service.impl;import com.jmh.ssm.model.User;
import com.jmh.ssm.service.IUserService;
import org.junit.Test;import javax.annotation.Resource;import static org.junit.Assert.*;public class UserServiceImplTest extends BaseTestCat{//注入@Resourceprivate IUserService iUserService;@Overridepublic void setUp() {super.setUp();}@Testpublic void deleteByPrimaryKey() {}@Testpublic void insert() {}@Testpublic void insertSelective() {}@Testpublic void selectByPrimaryKey() {User user = iUserService.selectByPrimaryKey(1);System.out.println(user);}@Testpublic void updateByPrimaryKeySelective() {}@Testpublic void updateByPrimaryKey() {}
}
  • 随便测试一个方法成功就是成功!失败就是失败!

 

5.2 Tomcat测试

5.2.1 前端代码(在WEB-INF下面创建一个jsp文件夹 在jsp文件夹里面创建一个index.jsp页面)

<%--Created by IntelliJ IDEA.User: 蒋明辉Date: 2022/8/21Time: 2:59To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>搭建SSM项目</title>
</head>
<body>
<h1>搭建SSM项目成功!</h1>
</body>
</html>

5.2.2 Controller层代码

package com.jmh.ssm.controller;import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;/*** Tomcat测试*/
@Controller
public class SsmController {@RequestMapping("/")//请求路径:当前/是打开服务器自动请求的第一个页面public String toIndex(){return "index";//跳转视图名称}
}

5.2.3 搭建Tomcat服务器

嘿嘿!现在最关键的时候到啦看看能不能第一时间访问index.jsp页面啦

ok!访问成功 测试完毕


idea搭建SSM项目这一篇就够了相关推荐

  1. 搭建SSM项目 IDEA版本

    搭建SSM项目 IDEA版本 实验环境 项目源文件地址 创建Maven WebApp 打开IDEA 选择项目类型 指定项目坐标 配置Maven相关参数 设置项目本地存放位置 IDEA自动生成的项目骨架 ...

  2. 【建议收藏】手把手带你搭建SSM项目

    1.简介SSM SSM(Spring+SpringMVC+MyBatis) 框架集由Spring.MyBatis两个开源框架整合而成(SpringMVC是Spring中的部分内容).常作为数据源较简单 ...

  3. 5min搭建SSM项目

    5min搭建SSM项目 1. 环境准备 Java 1.8_281 Mysql 5.7.27 IDEA 2020.1.3 maven 3.6.3 Tomcat 8.5.56 2. 创建项目 1. 使用I ...

  4. 快速搭建SSM项目【最全教程】~令狐小哥版

    快速搭建SSM项目[最全教程]~令狐小哥版 文章目录 快速搭建SSM项目[最全教程]~令狐小哥版 一.创建项目 二.集成spring依赖 三.创建applicationContext.xml文件 四. ...

  5. 【wordpress】搭建wordpress看这一篇就够了。

    搭建wordpress看这一篇就够了 一.介绍 WordPress是使用PHP语言开发的博客平台,用户可以在支持PHP和MySQL数据库的服务器上架设属于自己的网站.也可以把 WordPress当作一 ...

  6. 用idea搭建SSM项目,原来这么简单

    目录 前言 软件环境 创建项目 数据库文件 配置文件 pom.xml log4j.properties jdbc.properties applicationContext.xml spring-mv ...

  7. java 获取项目下的webapp_Spring Boot2 系列教程(一)纯 Java 搭建 SSM 项目

    在 Spring Boot 项目中,正常来说是不存在 XML 配置,这是因为 Spring Boot 不推荐使用 XML ,注意,并非不支持,Spring Boot 推荐开发者使用 Java 配置来搭 ...

  8. Linux 环境搭建一步到位,看这篇就够了!

    VMware Workstation 是一款功能强大的桌面虚拟软件,可模仿物理机器承载多个虚拟操作系统. 虚拟机下载安装 VMWare下载地址:https://pan.baidu.com/s/1OFV ...

  9. eclipse 右键项目为什么没有properties菜单_只需几步,从零开始搭建SSM项目

    SSM(Spring+SpringMVC+MyBatis) SSM(Spring+SpringMVC+MyBatis)框架集由Spring.SpringMVC.MyBatis三个开源框架整合而成,常作 ...

最新文章

  1. (转载)如何学好iphone游戏开发
  2. Cocos2d-xna : 横版战略游戏开发实验5 TiledMap实现关卡地图
  3. SpringBoot 2.x 监控中心:Actuator
  4. python爬取知乎live_Python爬虫 - 简单抓取百度指数
  5. 21、java中的反射机制
  6. Storm的ack机制在项目应用中的坑
  7. java settitle 源码_在其他初始化方法中折叠工具栏的setTitle - java代码 - 源码查
  8. Scala笔记2——IDE配置、函数式编程核心概念
  9. tabbar图标大小更改
  10. 电子元器件之电容如何测量
  11. python批量处理图片统一尺寸
  12. python 读写文件 把爬取的图片信息写入文件
  13. Qt 制作带农历的日历
  14. asuswrt 单臂路由_OPENWRT-KOOLSHARE软路由,一级/单臂/二级/旁软路由设置单臂路由联网教程...
  15. GraphicsLab Project之简易贴画系统(Decal System)
  16. Gradle打包报错:Failed to calculate the value of task ‘:unityLibrary:compileReleaseJavaWithJavac‘
  17. 【它山之石,可以攻玉】关于求职(实习)面试经验(2)
  18. AIX对硬件在线做diag诊断
  19. Mysql经典面试题(建议收藏)
  20. object.getClass()和Object.class的区别

热门文章

  1. C#连接SQLite数据库
  2. 基于python的音乐数据分析_[译] 你的歌单无聊吗?关于音乐和机器学习的数据分析...
  3. Django REST项目实战:在线中文字符识别
  4. 固态硬盘nvme协议什么意思 SSD四大协议传输标准
  5. listview上拉加载上一页 下拉加载下一页共通处理
  6. Python学习之路-字典外传
  7. 牛顿问题(牛吃草问题)-python题解
  8. 关于SQL语句的执行顺序
  9. 【超简单方法】ubantu18.04.2安装最新显卡驱动
  10. qt + opencv320 + EasyPR的车牌识别环境搭建