SSM整合

一、创建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&amp;useUnicode=true&amp;characterEncoding=utf-8&amp;useSSL=false&amp;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&amp;useUnicode=true&amp;characterEncoding=utf-8&amp;useSSL=false&amp;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://www.bilibili.com/video/BV1sk4y1M7ru?spm_id_from=333.788.videopod.episodes&vd_source=96752c6768217ad3b8db6ec0a006429b&p=87

文档:https://cloud.fynote.com/share/d/V9JIaVwAC/149985

说明

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值