整合SSM
卤蛋的SSM整合完整流程讲解
SpringMVC 是 Spring 家族中的一个框架,可以选择整合,也可以选择不整合,不整合就是指 Spring 和 SpringMVC 创建了同一个 IOC 容器,整合是指 Spring 和 SpringMVC 各自创建自己的 IOC 容器,管理各自的组件。(建议整合)
SpringMVC 是管理表示层(Web)的组件,其他组件是交给 Spring 去管理,表示层依赖于Service组件,这里需要进行自动装配对该组件进行注入,即需要从IOC容器中获取,上面解释了SpringMVC这个子容器可以访问Spring这个父容器的Bean。
而对Service组件进行装配是在表示层的,应该从 SpringMVC 容器中获取,那么Spring 创建 IOC 容器要先于SpringMVC 的创建时间,才能完成自动装配。
而小编在学Spring的时候,不管是使用注解式注入,还是使用配置式注入,都得通过一行代码去将对象交给 IOC 容器管理(针对singleton范围的)。也就是说Spring创建 IOC 是有代码的。
ApplicationContext applicationContext = new ClassPathXmlApplicationContext(??);
或
ApplicationContext applicationContext = new AnnotationConfigApplicationContext(??);
Tomcat服务器提供了三大组件:监听器,过滤器,Servlet。这三大组件的执行顺序为:监听器,过滤器,Servlet。
SpringMVC 中 IOC 容器的创建是在其核心组件DispatcherServlet初始化的时候创建的,根据自下往上的排除法,可以猜测 Spring 要先创建IOC容器的话,很可能就发生在过滤器或者监听器这俩大组件中(因为是Spring提供的整合,所以也排除在DispatcherServlet生命周期中创建)。
过滤器中有俩次过滤,一次是对请求的过滤,执行doFilter方法之前,一次是响应的过滤,执行doFilter方法之后。如果把对Spring IOC容器创建的代码放在过滤器中,缺点很多:
所以可以考虑使用监听器进行实现。
监听器的种类挺多,但根据 Tomcat 运行Servlet的执行顺序,符合要求的只有 ServletContextListener 一个。
为什么这么说?ServletContextListener,顾名思义是去监听ServletContext对象的,它作为WebApp中的上下文对象,其中的初始化参数可以被这整个应用去使用。之所以说它符合要求,首先是一个webapp就一个ServletContext对象,还有就是和它的以下运行流程有关:
contextInitialized方法,下面是ServletContextListener接口中的方法(监听器可以通过其事件参数,通过event.getServletContext()获取ServletContext对象,然后获取其初始化参数,然后进行操作)public interface ServletContextListener extends EventListener {
void contextInitialized(ServletContextEvent var1);
void contextDestroyed(ServletContextEvent var1);
}
下面再看看 ContextLoaderListener 监听器的实现,一切都变得清晰起来了。
public class ContextLoaderListener extends ContextLoader implements ServletContextListener {
public ContextLoaderListener() {
}
public ContextLoaderListener(WebApplicationContext context) {
super(context);
}
public void contextInitialized(ServletContextEvent event) {
this.initWebApplicationContext(event.getServletContext());
}
public void contextDestroyed(ServletContextEvent event) {
this.closeWebApplicationContext(event.getServletContext());
ContextCleanupListener.cleanupAttributes(event.getServletContext());
}
}
当 Tomcat 去解析 web.xml ,启动项目然后创建 ServletContext 对象进行初始化后,就会去执行这个 initWebApplicationContext 方法,见方法名知其意,这就是先去创建 Spring IOC 容器的实现。
随后为什么要在web.xml 中配置以下内容也很清晰了:
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<!--设置spring配置文件自定义的位置和名称-->
<context-param>
<param-name>contextConfigLocation</param-name>
<!--这里是小编将spring配置分成了俩,一个配置mybatis的,是spring-mapper.xml,然后下面的spring-service.xml导入了上面的那个,所以...-->
<!--名字没关系,只要对应的上就行-->
<param-value>classpath:spring-service.xml</param-value>
</context-param>
1)建库建表(这个由于是整合练习,可以按照自己的需求进行建库建表)
2)新建maven项目,选择webapp模块
3)修改目录,新建目录,如下所示:

4)修改 pom.xml文件(添加以下依赖,下面只是提供了整合依赖,如果需要其他具体实现,比如aspects,jdbc事务,jsp依赖,分页操作…都得另外配置依赖)
<dependencies>
<!--添加spring的测试依赖-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.2.5.RELEASE</version>
</dependency>
<!--spring-context和spring-beans依赖-->
<!--spring-context依赖本身就依赖spring-beans-->
<!--所以只需要配置spring-context依赖即可-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${spring.version}</version>
</dependency>
<!--springmvc依赖-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<!--mybatis核心-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.11</version>
</dependency>
<!--数据库连接池-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.16</version>
</dependency>
<!--mysql驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.31</version>
</dependency>
、<!--Tomcat10的Servlet依赖-->
<dependency>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-servlet-api</artifactId>
<version>10.1.0</version>
</dependency>
<dependency>
<!--mybatis和spring的整合包-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.6</version>
</dependency>
<!--jackson依赖,springmvc框架默认进行JSON转换的依赖工具-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.14.2</version>
</dependency>
</dependencies>
5)添加jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://localhost:3306/ssmuser?useUnicode=true&characterEncoding=utf8
jdbc.username=root
jdbc.password=123456
6)添加mybatis-config.xml文件,其他一些mybatis主要配置可以在spring配置SqlSessionFactoryBean时进行配置。
<?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>
<!--驼峰命名自动映射,默认false-->
<setting name="mapUnderscoreToCamelCase" value="false"/>
<setting name="lazyLoadingEnabled" value="true"/>
<setting name="logImpl" value="STDOUT_LOGGING"/>
</settings>
</configuration>
7)添加spring-mapper.xml文件
<!--读取属性文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>
<!--配置数据源-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driver}"/>
<property name="url" value="${jdbc.url}"/>
<property name="name" value="${jdbc.username}"/>
<property name="password" value="${jdbc.password}"/>
</bean>
<!--配置SqlSessionFactoryBean-->
<bean class="org.mybatis.spring.SqlSessionFactoryBean">
<!--配置数据源-->
<property name="dataSource" ref="dataSource"/>
<!--配置mybatis-config.xml核心配置-->
<property name="configLocation" value="classpath:mybatis-config.xml"/>
<!--注册实体类-->
<property name="typeAliasesPackage" value="com.ncpowernode.bean"/>
</bean>
<!--注册mapper.xml文件-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="com.ncpowernode.controller"/>
</bean>
8)添加spring-service.xml文件,因为没有使用事务,这个不添加也没关系,但是这个包扫描就得添加到上面去。
<import resource="spring-mapper.xml"/>
<!--添加包扫描-->
<context:component-scan base-package="com.ncpowernode.service"/>
<!--添加事务管理器-->
<bean id="tx" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource"/>
</bean>
<!--启动事务注解-->
<tx:annotation-driven transaction-manager="tx"/>
9)添加springmvc.xml文件
<!--添加包扫描-->
<context:component-scan base-package="com.ncpowernode.controller"/>
<!--添加注解驱动-->
<!--使用@ResponseBody注解需要-->
<!--添加就对了-->
<mvc:annotation-driven/>
10)在web.xml文件中注册springmvc框架(添加DispatcherServlet),注册spring框架(全局配置,监听器)
<servlet>
<servlet-name>dispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc.xml</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>dispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--注册spring框架,目的就是先启动Spring容器-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-service.xml</param-value>
</context-param>
</web-app>
11)整合配置结束,开始写Java程序,由于所建的数据库,所建的表不一致,下面我就直接给出小编所写类,类中所用注解,测试。


以上测试可以证明sm整合成功。

以上测试说明ss整合成功,即ssm整合成功。
项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU
我是Cucumber测试的新手。我创建了两个特征文件:events.featurepartner.feature并将我的步骤定义放在step_definitions文件夹中:./step_definitions/events.rbpartner.rbCucumber似乎在所有.rb文件中查找步骤信息。有没有办法限制该功能查看特定的步骤定义文件?我之所以要这样做,是因为即使我使用了--guess标志,我也会遇到不明确的匹配错误。我之所以要这样做,有以下几个原因。我正在测试CMS,并希望在不同的功能中测试每种不同的内容类型(事件和合作伙伴)。事件.特征Feature:AddpartnerA
我在下面有一个步骤定义,它执行我想要它执行的操作,即它根据“PAGES”哈希的“page”元素检查页面的url。Then(/^Ishould(still)?beatthe"(.*)"page$/)do|still,page|BROWSER.url.should==PAGES[page]end步骤定义用于两者我应该在...页面我应该还在...页面但是,我不需要将“still”传递到block中。我只需要它是可选的以匹配步骤但不传递到block中。我该怎么做?谢谢。 最佳答案 您想将“静止”组标记为非捕获。这是通过使用?:启动组来完成的
我们想测试cucumber的步骤定义。我们希望能够检查的一件事是我们期望失败的测试实际上失败了。为此,我们想编写我们知道会失败的场景并将它们添加到我们的测试套件中,但标记或以其他方式表示它们以便当且仅当它们失败时它们“通过”。如何解决这个问题? 最佳答案 您应该测试负面状态。失败的步骤只是通过步骤的倒数。所以做这样的事情:Then/ishouldnotbetrue/dosome_value.should_notbe_trueend这就是我进行失败测试的方式。您还可以捕获异常等,并验证block是否确实抛出该异常lambdadosom
我已经阅读了有关此主题的stackoverflow帖子以及包括APrimeronRubyMethodLookup在内的几篇文章,WhatisthemethodlookuppathinRuby.此外,我查看了RubyMetaprogramming2中的对象模型章节,在几个聊天室中询问,并做了thisredditthread。.除了学习C,我已经尽我所能来解决这个问题。如上述资源所述,这6个位置在接收对象(如fido_instance)的方法查找期间(按顺序)被检查。:fido_instance的单例类IClass(来自扩展模块)IClass(来自前置模块)类IClass(来自包含的模块)
一、系统定级信息系统运营使用单位按照等级保护管理办法和定级指南,自主确定信息系统的安全保护等级。有上级主管部门的,应当经上级主管部门审批。跨省或全国统一联网运行的信息系统可以由其主管部门统一确定安全保护等级。定级需要根据信息系统的实际情况合理定级。二、系统备案第二级以上信息系统定级单位到所在地设区的市级以上公安机关办理备案手续。省级单位到省公安厅网安总队备案,各地市单位一般直接到市级网安支队备案,也有部分地市区县单位的定级备案资料是先交到区县公安网监大队的,具体根据各地市要求来。信息系统运营、使用单位或者其主管部门应当在信息系统安全保护等级确定后30日内,到公安机关办理备案手续。三、初次测评信
对于体育新闻中文文本的关键字提取,常用的算法包括TF-IDF、TextRank和LDA等。它们的基本步骤如下:1.TF-IDF算法: -将文本进行分词和词性标注处理。-统计每个词在文本中的词频(TF)。-计算每个词在整个语料库中出现的文档频率(DF)和逆文档频率(IDF)。-计算每个词的TF-IDF值,并按照值的大小进行排序,选择排名前几的词作为关键字。2.TextRank算法:-将文本进行分词和词性标注处理。-将分词结果转化成图模型,每个词语为节点,根据词语之间的共现关系建立边。-对图模型进行迭代计算,计算每个节点的PageRank值,表示该节点的重要性。-选择排名前几的节点作为关键字。3.
我的Cucumber找不到步骤定义。文件结构(只有Rails根目录中的specs文件夹)如下所示:->specs->features->main_structure.feature->step_definitions->main_structure_steps.rb这是main_structure.feature:Feature:MainstructureScenario:ViewingtheStructurepageWhenIamonthestructurepage这是main_structure_steps.rb:When(/^Iamonthestructurepage$/)dov
我正在尝试找到一种更好的方法将IRB与我的常规ruby开发集成。目前我很少在我的代码中使用IRB。我只用它来验证语法或尝试一些小的东西。我知道我可以将我自己的代码加载到ruby中作为一个require'mycode'但这通常不符合我的编程风格。有时我要检查的变量超出范围或在循环内。有没有一种简单的方法可以启动我的脚本并在IRB内的某个点卡住?我想我正在寻找一种更简单的方法来调试我的ruby代码而不破坏我的F5(编译)键。也许有经验的ruby开发者可以和我分享一个更精简的开发方法。 最佳答案 安装ruby-debugg
我有一个cucumber步骤:鉴于我已登录我不明白我应该如何将它作为一个步骤定义来实现。谁能指出我正确的方向、教程、博客等。 最佳答案 这是我的做法。Given/^Ihaveone\s+user"([^\"]*)"withemail"([^\"]*)"andpassword"([^\"]*)"$/do|username,email,password|@user=User.new(:email=>email,:username=>username,:password=>password,:password_confirmation=>