一、创建Maven项目


IDE中自带有Maven,如果想要用本地仓库或者改成国内镜像源,可以更改Maven路径和配置,如下图所示,详细可见博客https://blog.csdn.net/JiaXingNashishua/article/details/126114587?spm=1001.2101.3001.6661.1&utm_medium=distribute.pc_relevant_t0.none-task-blog-2defaultBlogCommendFromBaiduRate-1-126114587-blog-126256985.235%5Ev43%5Epc_blog_bottom_relevance_base3&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-2defaultBlogCommendFromBaiduRate-1-126114587-blog-126256985.235%5Ev43%5Epc_blog_bottom_relevance_base3&utm_relevant_index=1

二、补全目录

三、添加依赖和插件
【1】mybatis的依赖
【2】连接mysql的依赖
【3】log4j的依赖
【4】spring的核心依赖
【5】springjdbc依赖
【6】spring整合mybatis的依赖
【7】springwebmvc的依赖
由于添加依赖需要Maven从本题仓库下载相应的内容,这些库可以从Maven中心库https://central.sonatype.com/中找到,再导入。必要时可以挂梯子,下载速度会更快,有时也会因为下载速度问题,内容没有成功导入,ide出现报错情况。下面的依赖供参考:
<?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>
<!-- <pluginRepositories>-->
<!-- <pluginRepository>-->
<!-- <id>alfresco</id>-->
<!-- <url>https://artifacts.alfresco.com/nexus/content/repositories/public/</url>-->
<!-- </pluginRepository>-->
<!-- </pluginRepositories>-->
<groupId>com.msb</groupId>
<artifactId>TestSSM</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>war</packaging>
<dependencies>
<!-- 【1】mybatis的依赖 -->
<dependency> <groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.9</version>
</dependency>
<!-- 【2】连接mysql的依赖 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.33</version>
</dependency>
<!-- 【3】log4j的依赖 -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!-- 【4】spring的核心依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.3.16</version>
</dependency>
<!-- 【5】springjdbc依赖-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.3.16</version>
</dependency>
<!-- 【6】spring整合mybatis的依赖 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.7</version>
</dependency>
<!-- 【7】springwebmvc的依赖 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.16</version>
</dependency>
</dependencies>
<pluginRepositories>
<pluginRepository>
<id>alfresco-public</id>
<url>https://artifacts.alfresco.com/nexus/content/groups/public</url>
</pluginRepository>
<pluginRepository>
<id>alfresco-public-snapshots</id>
<url>https://artifacts.alfresco.com/nexus/content/groups/public-snapshots</url>
<snapshots>
<enabled>true</enabled>
<updatePolicy>daily</updatePolicy>
</snapshots>
</pluginRepository>
<pluginRepository>
<id>beardedgeeks-releases</id>
<url>http://beardedgeeks.googlecode.com/svn/repository/releases</url>
</pluginRepository>
</pluginRepositories>
<!-- 加入tomcat插件 -->
<build>
<plugins>
<!-- tomcat8插件 -->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat8-maven-plugin</artifactId>
<version>3.0-r1756463</version>
<configuration>
<port>8080</port>
<path>/ssm</path>
</configuration>
</plugin>
</plugins>
</build>
</project>
四、处理spring整合mybatis部分
以前用mybatis先搞配置文件mybatis.xml:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 加载属性文件,当前文件和 db.properties 在同一个目录中,使用相对路径 -->
<properties resource="db.properties"></properties>
<!-- 位置为 properties 下面,typeAlias 的上面,具体可以 Ctrl+mybatis-3-config.dtd 查看 -->
<settings>
<!-- 配置生效的日志 -->
<setting name="logImpl" value="LOG4J"/>
</settings>
<!-- 按照 DTD 顺序要求:typeAliases 放在 properties 下面,environments 上面 -->
<typeAliases>
<!-- type:类型全限定路径 alias:别名名称 -->
<typeAlias type="com.msb.pojo.Book" alias="b"></typeAlias>
<typeAlias type="com.msb.pojo.Book" alias="bb"></typeAlias>
<!-- 指定包 -->
<package name="com.msb.pojo"/>
</typeAliases>
<environments default="mysql">
<!-- 连接 mysql 数据库的数据源配置 -->
<environment id="mysql">
<!-- 配置 Mybatis 中的事务管理 -->
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOlED">
<property name="driver" value="${db.driver}"/>
<property name="url" value="${db.url}"/>
<property name="username" value="${db.username}"/>
<property name="password" value="${db.password}"/>
</dataSource>
</environment>
</environments>
<mappers>
<!-- <mapper resource="com/zss/mapper/BookMapper.xml"></mapper> -->
<package name="com.msb.mapper"/>
</mappers>
</configuration>
整合后:mybatis.xml要发生翻天覆地的变化了,都交由spring来管理,创建applicationContext.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/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd">
<!-- 【1】连接数据库,获取数据源,配置数据源,设置数据库连接的四个参数 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<!-- 利用setter方法完成属性注入,四个参数名固定的,注意源码中虽然没有driverClassName属性,但是有driverClassName的setter方法 -->
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/msb&useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=GMT%2B8&allowPublicKeyRetrieval=true"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</bean>
<!-- 【2】获取SqlSessionFactory对象 -->
<!-- 以前SqlSessionFactory都是在测试代码中我们自己创建的,但是现在不用了,整合包中提供的对于SqlSessionFactory的封装。里面提供了MyBatis全局配置文件所有配置的属性 -->
<bean id="factory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!-- 注入数据源 -->
<property name="dataSource" ref="dataSource"/>
<!-- 给包下类起别名 -->
<property name="typeAliasesPackage" value="com.msb.pojo"></property>
</bean>
<!-- 【3】扫描mapper文件 -->
<!-- 设置扫描哪个包,进行接口绑定-->
<!-- 所有Mapper接口代理对象都能创建出来,可以直接从容器中获取出来。 -->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<!-- 和SqlSessionFactory产生联系,以前接口绑定sqlSession.getMapper(BookMapper.class);
都是通过以前接口绑定sqlSession来调用mapper,所以这里一定要注入工厂啊
注意这里sqlSessionFactoryBeanName类型为String,所以用value把工厂名字写过来就行-->
<property name="sqlSessionFactoryBeanName" value="factory"></property>
<!-- 扫描的包 -->
<property name="basePackage" value="com.msb.mapper"></property>
</bean>
<!-- 【4】扫描包下注解 -->
<context:component-scan base-package="com.msb.service"></context:component-scan>
</beans>
此处注意,url的value值,需要改成自己数据库的名称,username和password的value值也是如此,需要改成自己的数据库用户名和密码。
<!-- 【1】连接数据库,获取数据源,配置数据源,设置数据库连接的四个参数 -->
<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<!-- 利用setter方法完成属性注入,四个参数名固定的,注意源码中虽然没有driverClassName属性,但是有driverClassName的setter方法 -->
<property name="driverClassName" value="com.mysql.cj.jdbc.Driver"/>
<property name="url" value="jdbc:mysql://localhost:3306/msb&useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=GMT%2B8&allowPublicKeyRetrieval=true"/>
<property name="username" value="root"/>
<property name="password" value="root"/>
</bean>
日志是mybatis特有的配置方式,spring没有提供那样的配置,所以日志部分没法替代。所以你可以把mybatis.xml保留,里面留下这个log4j的配置。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<settings>
<!-- 配置生效的日志 -->
<setting name="logImpl" value="LOG4J"/>
</settings>
</configuration>
加完之后这个mybatis.xml还要解析在applicationContext.xml中:加入:
<bean id="factory" class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource"/>
<property name="typeAliasesPackage" value="com.zss.pojo"></property>
<!-- 新加入 -->
<property name="configLocation" value="classpath:mybatis.xml"></property>
</bean>
log4j.properties还是需要的。
# log4j中定义的级别:fatal(致命错误) > error(错误) >warn(警告) >info(普通信息) >debug(调试信息)>trace(跟踪信息)
log4j.rootLogger = ERROR , console , D
# log4j.logger是固定的,a.b.c是命名空间的名字可以只写一部分。
log4j.logger.a.b=TRACE
### console ###
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern = [%p] [%-d{yyyy-MM-dd HH\:mm\:ss}] %C.%M(%L) | %m%n
### log file ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = D:/log4j.log
log4j.appender.D.Append = true
# 只能生级别,不能降
log4j.appender.D.Threshold = INFO
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = [%p] [%-d{yyyy-MM-dd HH\:mm\:ss}] %
五、整合springmvc
加入springmvc.xml的配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 扫描控制器类,千万不要把service等扫描进来,也千万不要在Spring配置文件扫描控制器类所在包 -->
<context:component-scan base-package="com.zss.controller"></context:component-scan>
<!-- 让Spring MVC的注解生效 :@RequestMapping-->
<mvc:annotation-driven></mvc:annotation-driven>
</beans>
在web.xml中我们只加入了springmvc.xml的解析,还要加入applicationContext.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_4_0.xsd"
version="4.0">
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<!-- 参数名称必须叫做:contextConfigLocation。单词和大小写错误都导致配置文件无法正确加载 -->
<param-name>contextConfigLocation</param-name>
<!-- springmvc.xml 名称自定义,只要和我们创建的配置文件的名称对应就可以了。 -->
<param-value>classpath:springmvc.xml</param-value>
</init-param>
<!-- Tomcat启动立即加载Servlet,而不是等到访问Servlet才去实例化DispatcherServlet -->
<!-- 配置上的效果:Tomcat启动立即加载Spring MVC框架的配置文件-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<!-- /表示除了.jsp结尾的uri,其他的uri都会触发DispatcherServlet。此处前往不要写成 /* -->
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--新加入-->
<!--解析applicationContext.xml:利用监听器监听-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!--给全局参数contextConfigLocation设置值,contextConfigLocation是ContextLoaderListener父类ContextLoader中的属性-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
</web-app>
六、创建项目目录结构
前五个步骤将整合的配置内容已经配置好了,接下来开始创建项目的目录结构,项目要分层,有controller层、service层、有dao层(mapper层)、实体类层。
构建实体类:
package com.msb.pojo;
public class Book {
private int id;
private String name;
private String author;
private double price;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getAuthor() {
return author;
}
public void setAuthor(String author) {
this.author = author;
}
public double getPrice() {
return price;
}
public void setPrice(double price) {
this.price = price;
}
}
创建mapper层内容:
构建mapper接口和mapper.xml映射文件:
com.zss.mapper.BookMapper接口:
package com.msb.mapper;
import java.util.List;
public interface BookMapper {
public abstract List selectAll();
}
映射文件:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.msb.mapper.BookMapper">
<select id="selectAll" resultType="book">
select * from t_book
</select>
</mapper>
创建service层内容:
package com.msb.service;
import java.util.List;
public interface BookService {
public abstract List findAll();
}
实现类:
package com.msb.service.impl;
import com.msb.mapper.BookMapper;
import com.msb.service.BookService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class BookServiceImpl implements BookService {
@Autowired
private BookMapper bookMapper;
public List findAll() {
return bookMapper.selectAll();
}
}
创建controller层内容:
package com.msb.controller;
import com.msb.pojo.Book;
import com.msb.service.BookService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.List;
@Controller
public class BookController {
@Autowired
private BookService bookService;
@RequestMapping(value="/findAllBooks",produces = "text/html;charset=utf-8")
@ResponseBody
public String findAll(){
List list=bookService.findAll();
System.out.println("一共有几本书籍:"+list.size());
String str="";
for (Object o : list) {
Book book=(Book) o;
str=str+book.getAuthor()+" ";
str=str+book.getName()+" ";
}
return str;
}
}
七、启动项目
双击tomcat8:run-war


出现以下内容:

在后面加入findAllBooks,网站变成:http://localhost:8080/ssm/findAllBooks

八、其他
最后的项目目录

参考文件
文档:https://cloud.fynote.com/share/d/V9JIaVwAC/149985
说明
本人第一次学习SSM框架及其整合,是通过b站视频进行简单的学习,不足之处,还望指点和包含,在此也仅作学习的记录。配置过程中一些细节无法完全展示,可以参考视频文件。在此,也感谢马士兵教育机构提供的视频和资料。
11万+

被折叠的 条评论
为什么被折叠?



