13.SSM集成

路昭
• 阅读 1462

缘由分析

对于我们现在的中大型项目于来说,用得最多的,应该就数我们的SSM,记Spring、SpringMvc、Mybatis,那么我们今天,就会来完成他们的集成。需要说明一下,本次集成我没有使用maven项目,如果需要maven项目的,可以直接讲jar包删除,在pom.xml中引入依赖即可,其他的内容都没有任何变化。

前期准备

1.jar包

这里的jar包有点多,我就直接截图出来,也会放一个某云的链接,有需要可以直接提取
13.SSM集成
如有需要,请点击,提取码4fy8

2.数据库

数据库的话,可以在里面创建一个user表,里面添加几条数据,目的是为了在部署到tomcat上面的时候测试链接数据库提取数据成功与否

3.开发工具

我所用的是idea1903版本的,像eclipse也同理

具体步骤

1.新建一个java web项目

13.SSM集成
13.SSM集成

2.开始导入jar包

2.1在你的web/WEB-INF文件夹下面建一个名叫lib的文件夹,然后将所有的jar包复制进这个文件夹里面
2.2右键该文件夹,然后点击Add as Library,即完成导包操作

13.SSM集成

3.在src下面创建所需的包及类

下图是我创建好之后的样子
13.SSM集成

4.xml配置

4.1 Spring配置文件

这里的每一项都写了注释,就不多做解释,只是有一点需要注意的是,寡欲配置的事务即tx命名空间,如果我们直接在下面写而不先写上面的命名空间的话,会将tx前面的schema自动写为cache,从而我们后续在运行的时候,就会报一个No bean named 'cacheManager' is defined的错误,需要注意一下,所以特别提一下

<?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"
   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">

<!--引入数据库连接配置文件-->
<context:property-placeholder location="classpath:jdbc.properties"/>

<!--数据库连接池-->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
    <property name="driverClassName" value="${driverClassName}"/>
    <property name="url" value="${url}"/>
    <property name="username" value="${username}"/>
    <property name="password" value="${password}"/>
</bean>

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
    <!--配置加载数据库路径-->
    <property name="dataSource" ref="dataSource"/>
    <!--配置加载mapper资源文件路径-->
    <property name="mapperLocations" value="classpath:com/arvin/ssm/mapper/*Mapper.xml"/>
<!--给对应包下面的domain或者类配置别名,配置完了默认为类名,一般建议类名首字母小写-->
    <property name="typeAliasesPackage">
        <value>
            com.arvin.ssm.domain
            com.arvin.ssm.query
        </value>
    </property>
</bean>

<!--配置扫描mapper的路径-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
    <property name="basePackage" value="com.arvin.ssm.mapper"></property>
</bean>

<!--事务配置-->
<bean id="transactionManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
    <property name="dataSource" ref="dataSource"/>
</bean>

<!--配置事务对注解的支持-->
<tx:annotation-driven/>

<!--扫描service包-->
<context:component-scan base-package="com.arvin.ssm.service"/>

</beans>

4.2 SpringMvc配置文件

这个配置文件相对简单,只是需要注意的是mvc命名空间前面的schema也存在上述的问题,需要大家注意一下,这个是idea自动代码提示生成的,目前我还没有更好的解决办法,只有看到了之后自己手动改为schema

<?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:mvc="http://www.springframework.org/schema/mvc"
   xmlns:context="http://www.springframework.org/schema/context"
   xsi:schemaLocation="http://www.springframework.org/schema/beans
   http://www.springframework.org/schema/beans/spring-beans.xsd
   http://www.springframework.org/schema/mvc
   http://www.springframework.org/schema/mvc/spring-mvc.xsd
   http://www.springframework.org/schema/context
   http://www.springframework.org/schema/context/spring-context.xsd">


<!--Controller包扫描-->
<context:component-scan base-package="com.arvin.ssm.controller"/>
<!--静态资源放行-->
<mvc:default-servlet-handler/>
<!--开启注解支持-->
<mvc:annotation-driven/>
<!--视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
    <property name="prefix" value="/WEB-INF/views"/>
    <property name="suffix" value=".jsp"/>
</bean>

</beans>

4.3 数据库连接池配置文件

这个很简单就不多做说明了

    driverClassName=com.mysql.jdbc.Driver
    username=root
    password=123456
    url=jdbc:mysql:///mybatis
4.4 web.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>dispatcherServlet</servlet-name>
        <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
        <init-param>
            <param-name>contextConfigLocation</param-name>
            <!--加载mvc的配置文件-->
            <param-value>classpath:applicationContext-mvc.xml</param-value>
        </init-param>
        <!--在web应用程序启动的时候就加载这个servlet-->
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>dispatcherServlet</servlet-name>
        <url-pattern>/</url-pattern>
    </servlet-mapping>

    <!--配置加载spring的配置文件-->
    <context-param>
        <param-name>contextConfigLocation</param-name>
        <param-value>classpath:applicationContext.xml</param-value>
    </context-param>

    <!--监听器-->
    <listener>
        <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
    </listener>

    <!--字符编码集过滤-->
    <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>

</web-app>
4.5 关于mapper的配置

这里有需要注意的点了

4.5.1 建的位置必须要和对应mapper所在类的文件夹名相同

举例说明:我这里的UserMapper.xml所在位置为\com\arvin\ssm\mapper,那么我们写的配置文件也必须要和这个对应起来
13.SSM集成
13.SSM集成
即做成如下图
13.SSM集成
13.SSM集成

4.5.2 别名的配置,都有写注释,可以参考
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<!--这里的namesprace对应的为我们UserMapper接口的全限定名-->
<mapper namespace="com.arvin.ssm.mapper.UserMapper">
    <!--这里是我预先抽取的公共sql语句-->
    <sql id="showAll">
        select * from user
    </sql>
    <!--这里的id,对应的是UserMapper中的方法名-->
    <!--resultTpye可以写对应domain的全限定名,我这里写了类名首字母小写是因为我在前面配置了别名,
    具体可以看application.xml中的配置-->
    <select id="getAll" resultType="user">
        <!--这里是在引用上面抽取的公共sql语句,refid对应上面sql标签中的id-->
        <include refid="showAll"/>
    </select>
</mapper>

到这里,我们的配置就算完成了,可以在Controller里面先写一个请求测试!!

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
美凌格栋栋酱 美凌格栋栋酱
6个月前
Oracle 分组与拼接字符串同时使用
SELECTT.,ROWNUMIDFROM(SELECTT.EMPLID,T.NAME,T.BU,T.REALDEPART,T.FORMATDATE,SUM(T.S0)S0,MAX(UPDATETIME)CREATETIME,LISTAGG(TOCHAR(
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Jacquelyn38 Jacquelyn38
4年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Wesley13 Wesley13
3年前
FLV文件格式
1.        FLV文件对齐方式FLV文件以大端对齐方式存放多字节整型。如存放数字无符号16位的数字300(0x012C),那么在FLV文件中存放的顺序是:|0x01|0x2C|。如果是无符号32位数字300(0x0000012C),那么在FLV文件中的存放顺序是:|0x00|0x00|0x00|0x01|0x2C。2.  
Easter79 Easter79
3年前
Twitter的分布式自增ID算法snowflake (Java版)
概述分布式系统中,有一些需要使用全局唯一ID的场景,这种时候为了防止ID冲突可以使用36位的UUID,但是UUID有一些缺点,首先他相对比较长,另外UUID一般是无序的。有些时候我们希望能使用一种简单一些的ID,并且希望ID能够按照时间有序生成。而twitter的snowflake解决了这种需求,最初Twitter把存储系统从MySQL迁移
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
为什么mysql不推荐使用雪花ID作为主键
作者:毛辰飞背景在mysql中设计表的时候,mysql官方推荐不要使用uuid或者不连续不重复的雪花id(long形且唯一),而是推荐连续自增的主键id,官方的推荐是auto_increment,那么为什么不建议采用uuid,使用uuid究
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这