(1)SpringMVC框架
SpringMVC框架位于Controller层,主要为接收用户发起的请求,在接收请求后可进行一定处理(如:通过拦截器的信息验证处理)。在通过处理后SpringMVC会根据请求的路径将请求分发到对应的Controller类中的处理方法。处理方法再调用Service层的业务处理逻辑。
(2)Spring框架
Spring框架在SSM中充当类似与粘合剂的作用,利用其对象托管的特性将SpringMVC、MyBatis两个独立的框架有机的结合起来。 Spring可将SpringMVC中的Controller类和MyBatis中的SqlSession类进行托管,简化了人工管理过程。 Spring除了能对SpringMVC和MyBatis的核心类进行管理外,还可对主要的业务处理的类进行管理。
(3)MyBatis框架
MyBatis框架应用于对数据库的操作,其中主要功能类SqlSession可对数据库进行具体操作。
SpringMVC容器:**主要对Controller控制器对象,视图等用户请求和请求结果进行管理。
Spring容器:**主要对Service、Dao、工具类等对象进行管理。
两个容器的关系:**SpringMVC容器为Spring容器的子容器,进而两容器中的对象进行间接管理。
1、各个框架担任的角色
SpringMVC:表述层框架,处理浏览器发送给服务器的请求,将一些数据响应到浏览器。
MyBatis:持久层框架,连接数据库,访问数据库,操作数据库
Spring:整合型框架,通过 IOC管理对象,比如MyBatis中操作数据库的SqlSession对象,MyBatis操作数据库时需要事务功能,也可以使用Spring中Aop的重要应用,声明式事务实现。
Spring 和 SpringMVC 本身就是同源的,作为 Spring 家族的一个框架,整合不整合都行,我们所说的不整合是指 Spring 和 SpringMVC 创建同一个 IOC 容器,整合是指 Spring 和 SpringMVC 各自创建自己的 IOC 容器,管理各自的组件。(建议整合)
CREATE TABLE `book` (`id` int(0) NOT NULL AUTO_INCREMENT,`type` varchar(255) ,`price` double(10, 1),`author` varchar(255),PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb3 COLLATE = utf8mb3_general_ci ROW_FORMAT = Dynamic;#在给表中插入数据
INSERT INTO `book` VALUES (1, '三国演义', 30.0, '张飞');SET FOREIGN_KEY_CHECKS = 1;
<dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.12</version><scope>provided</scope></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>5.3.18</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>5.3.18</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-jdbc</artifactId><version>5.3.18</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-tx</artifactId><version>5.3.18</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-aspects</artifactId><version>6.0.1</version></dependency><!--mysql驱动--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.33</version></dependency><!--spring mybtis--><dependency><groupId>com.alibaba</groupId><artifactId>druid</artifactId><version>1.1.10</version></dependency><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus</artifactId><version>3.1.1</version></dependency><!--spring mvc--><dependency><groupId>org.springframework</groupId><artifactId>spring-web</artifactId><version>5.3.18</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.3.18</version></dependency><dependency><groupId>javax.servlet</groupId><artifactId>servlet-api</artifactId><version>2.5</version></dependency><dependency><groupId>javax.servlet.jsp</groupId><artifactId>jsp-api</artifactId><version>2.0</version></dependency><dependency><groupId>jstl</groupId><artifactId>jstl</artifactId><version>1.2</version></dependency></dependencies>
mapper层
package com.it.mapper;import com.it.pojo.Book;import java.util.List;public interface BookMapper {//查询List<Book> findList();//新增加int inster(Book book);}
service层
service接口
public interface BookService {//查询List<Book> findList();//新增加int inster(Book book);}
service实现类
public class BookServiceImpl implements BookService {BookMapper bookMapper;@Overridepublic List<Book> findList() {return bookMapper.findList();}@Overridepublic int inster(Book book) {return bookMapper.inster(book);}
}
controller层(这里写大体框架,下面在写逻辑代码)
public class BookController {//插入public void inster(){return null;}//查询public ModelAndView findList(){return null;}
}
创建对应表单
<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<html>
<head><title>图书系统</title><style type="text/css">*{font-family: 楷体;}table{width: 50%;text-align: center;}td{border: 1px solid royalblue;}</style>
</head>
<body>
<table cellspacing="0" cellpadding="0"><tr><td>书号</td><td>书名</td><td>价格</td><td>作者</td></tr><c:forEach items="" var=""><tr><td>书号</td><td>书名</td><td>价格</td><td>作者</td></tr></c:forEach>
</table>
</br>
<input type="button" value="新增" onclick=""/></body></html>
新增表单
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head><title>添加信息</title>
</head>
<body><h1>添加新书籍</h1>
<form action="/inster" method="post">书籍名称<input type="text" name="type">书籍价钱<input type="text" name="price">书籍作者<input type="text" name="author"><input type="submit" value="新增">
</form></body>
</html>
jdbc.driversql.cj.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/tb_mybatis_spring?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&useSSL=false
jdbc.username=root
jdbc.password=123456
注意:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapperPUBLIC "-//mybatis//DTD Mapper 3.0//EN"".dtd">
<mapper namespace="com.it.mapper.BookMapper"><insert id="inster">INSERT INTO book VALUES(null,#{type},#{price},#{author});</insert><select id="findList" resultType="Book">select*from book</select>
</mapper>
其余的配置都会整合在Spring配置文件中,这里面的所有内容都可以在Spring配置文件中配置,我配置了一部分。
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configurationPUBLIC "-//mybatis//DTD Config 3.0//EN"".dtd"><configuration><!--日志--><settings><setting name="logImpl" value="org.apache.ibatis.logging.stdout.StdOutImpl"/></settings><!--设置别名实体类--><typeAliases>
<!-- <typeAlias type="com.it.pojo.Users" alias="Users"></typeAlias>--><package name="com.it.pojo"/></typeAliases><mappers>
<!-- <mapper resource="com/it/l"></mapper>--><package name="com.it.mapper"/></mappers>
</configuration>
SpringMVC扫描的是controller包,Spring就要把其他的包扫描了,排除controller
配置数据源,在把Mybatis的SqlSessionFactoryBean注入到Spring容器中,别忘了映射文件
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns=""xmlns:xsi=""xmlns:context=""xsi:schemaLocation=" .xsd .xsd"><!--加载properties配置文件--><context:property-placeholder location="classpath:jdbc.properties" /><!--注解扫描 排除contorller层--><context:component-scan base-package="com.it"><context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"/></context:component-scan><!--数据源--><bean id="dataSoure" class="com.alibaba.druid.pool.DruidDataSource" ><property name="driverClassName" value="${jdbc.driver}"></property><property name="url" value="${jdbc.url}"></property><property name="username" value="${jdbc.username}"></property><property name="password" value="${jdbc.password}"></property></bean><!--把mybtis的SqlSessionFactoryBean工厂注入容器--><bean id="factory" class=batis.spring.SqlSessionFactoryBean"><property name="dataSource" ref="dataSoure"></property><property name="configLocation" value=l"></property></bean>
<!--扫描mapper映射文件--><bean class=batis.spring.mapper.MapperScannerConfigurer">
<!-- <property name="sqlSessionFactoryBeanName" value="factory"/>--><property name="basePackage" value="com.it.mapper"/></bean>
</beans>
Service层实现类上使用@Service注解把他注入到Spring容器中 @Autowired导入依赖
@Service
public class BookServiceImpl implements BookService {@AutowiredBookMapper bookMapper;@Overridepublic List<Book> findList() {return bookMapper.findList();}@Overridepublic int inster(Book book) {return bookMapper.inster(book);}
}
服务器启动时三大组件执行顺序:监听器,过滤器,Servlet
SpringMVC 的 IOC 容器是在 Servlet 的初始化方法中执行的,那我们把获取 Spring 的 IOC 容器的代码放在过滤器或者监听器的初始化方法中执行,就可以保证在获取 SpringMVC 的 IOC 容器时, Spring 的 IOC 容器是提前创建好的,完成 Controller 中对 Service 自动装配。
但是,过滤器并不适合,过滤器是用来过滤当前的请求和响应,如果我们在过滤器的初始化方法中写了创建 Spring 的 IOC 容器的代码,那在执行过滤的方法中什么都不写,直接放行的话,那创建过滤器的意义就没有了。
创建过滤器的初始化方法,销毁方法我们完全可以不写,最主要的就是dofilter方法,但是现在我们的过滤器就执行了一个初始化方法,之后执行过滤的时候 dofilter 没有写任何代码,我们不能为了实现一个目的而忽视了组件的最初目的。
所以创建Spring的IOC容器只能交给监听器了。
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns=""xmlns:xsi=""xmlns:context=""xmlns:mvc=""xsi:schemaLocation=" .xsd .xsd .xsd"><!--注解扫描--><context:component-scan base-package="ller"></context:component-scan><!--配置MVC注解驱动--><mvc:annotation-driven></mvc:annotation-driven><!--内部资源视图解析器--><bean id="resourceViewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="prefix" value="/WEB-NF/jso"></property><property name="suffix" value=".jsp"></property></bean><!--开发静态资源--><mvc:default-servlet-handler></mvc:default-servlet-handler></beans>
<!DOCTYPE web-app PUBLIC"-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"".dtd" ><web-app><!--Spring核心配置文件--><context-param><param-name>contextConfigLocation</param-name><param-value>l</param-value></context-param><!--乱码过滤器--><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></filter><filter-mapping><filter-name>encodingFilter</filter-name><url-pattern>/*</url-pattern></filter-mapping><!--Spring监听器--><listener><listener-class>org.t.ContextLoaderListener</listener-class></listener><!--前端核心控制器 --><servlet><servlet-name>DispatcherServlet</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><init-param><param-name>contextConfigLocation</param-name><param-value>l</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>DispatcherServlet</servlet-name><url-pattern>/</url-pattern></servlet-mapping></web-app>
@Controller
public class BookController {@AutowiredBookService bookService;//插入@RequestMapping("/inster")public void inster(Book c, HttpServletResponse response) throws IOException {int inster = bookService.inster(c);//新增字段System.out.println(inster);Writer().write("<script>alert('新增成功!');location.href='/select';</script>");}//查询@RequestMapping("/select")public ModelAndView findList(){ModelAndView modelAndView=new ModelAndView();List<Book> list = bookService.findList();modelAndView.addObject("list",list);modelAndView.setViewName("/booklist.jsp");return modelAndView;}
}
总结:
SSM整合核心有以下几点:
Spring的IOC容器创建先于SpringMVC的IOC容器
SpringMVC扫描的是controller包,Spring要把其他的包扫描了,两个框架管理各自的组件
了解 ContextLoaderListener 监听器的作用,在服务器启动的时候加载Spring的配置文件
Spring配置文件代替原来的 l
其余的配置与单独使用时基本一致
本文发布于:2024-02-01 12:33:38,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170676202036624.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |