CSDN大V保姆级教程:图文详解IDEA整合SSM框架(附源码)

Posted 谷哥的小弟

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CSDN大V保姆级教程:图文详解IDEA整合SSM框架(附源码)相关的知识,希望对你有一定的参考价值。


版权声明

  • 本文原创作者:谷哥的小弟
  • 作者博客地址:http://blog.csdn.net/lfdfhl

教程概述

本教程以图文形式详细讲解IDEA整合SSM框架的流程以及具体步骤及其注意事项。

数据准备

在此,准备本教程所需的数据库、数据表及其数据;详情如下:

-- 假若panda存在则删除
DROP DATABASE IF EXISTS panda;
-- 创建pandaDB数据库
CREATE DATABASE panda;
-- 使用panda数据库
use panda;
-- 创建user表
CREATE TABLE user(
  -- 自动增长主键id
  id INT primary key auto_increment,
  -- 用户名
  username VARCHAR(50),
  -- 密码
  password VARCHAR(50)
);
-- 向user表中插入数据
INSERT INTO user (username,password) VALUES ('admin','admin');
-- 查询user表中的数据
SELECT * FROM user;

创建Maven项目

在此,详细介绍在IDEA中使用Maven创建JavaWeb项目的过程及其主要步骤。

创建项目,图示如下:

设定SDK版本并选择Maven模板,图示如下:

填写项目基本信息,图示如下:

配置Maven,图示如下:


点击Finish后IDEA开始创建项目,图示如下:

至此,项目已经创建;但是,还缺失Web项目所必须的文件夹。所以,接下来,我们来完善该项目。

完善Maven项目

Maven项目的标准目录结构如下:

  • src/main/java
  • src/main/resources
  • src/test/java
  • src/test/resources

在此,按照该Maven项目结构完善本项目的结构。

请在main下创建java文件夹,再将java文件夹设置为Sources Root;图示如下:

请在main下创建resources 文件夹,再将resources 文件夹设置为Resources Root;图示如下:

请在src下创建test文件夹,再在test中创建java文件夹;接下来,将java文件夹设置为Test Sources Root;图示如下:


请在test文件中创建resources文件夹,再将resources 文件夹设置为Test Resources Root;图示如下:

至此,关于项目结构的完善就基本完成,图示如下:

配置Tomcat

接下来,开始为项目添加本地Tomcat服务器,图示如下:

选择本地Tomcat服务器,再点击OK,图示如下:

本地Tomcat服务器已经添加完毕,接下来对其进行配置;图示如下:

配置端口号和默认浏览器,图示如下:


配置与项目发布相关的信息,图示如下:



运行项目,图示如下:

浏览器显示页面,图示如下:

至此,成功完成了Tomcat的配置。

整合SSM框架

在之前的操作中,我们完成了在IDEA中使用Maven创建JavaWeb项目。接下来,我们在此基础上整合SSM三大框架。

添加依赖

在项目初始化之后pom.xml文件中自带部分依赖,图示如下:

在此,我们需要将SSM项目中常用的依赖添加至< dependencies ></ dependencies >中。常见的有:servlet、spring-webmvc、mybatis、mysql、mybatis-spring、pagehelper、spring-jdbc、c3p0、log4j、jackson、jstl、fileupload等等;详情如下:

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-webmvc</artifactId>
            <version>5.3.14</version>
        </dependency>

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.5.9</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.27</version>
        </dependency>

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis-spring</artifactId>
            <version>2.0.6</version>
        </dependency>

        <dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper</artifactId>
            <version>5.0.0</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-jdbc</artifactId>
            <version>5.3.14</version>
        </dependency>

        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring-oxm</artifactId>
            <version>5.3.14</version>
        </dependency>

        <dependency>
            <groupId>com.mchange</groupId>
            <artifactId>c3p0</artifactId>
            <version>0.9.5.5</version>
        </dependency>

        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>1.7.30</version>
        </dependency>

        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <version>2.13.1</version>
        </dependency>

        <dependency>
            <groupId>org.aspectj</groupId>
            <artifactId>aspectjweaver</artifactId>
            <version>1.9.6</version>
        </dependency>

        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>javax.servlet-api</artifactId>
            <version>4.0.1</version>
        </dependency>

        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>

        <dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.4</version>
        </dependency>

图示如下:

创建包

在此,提前准备好项目中可能用到的包。

创建与Java代码相关的包

首先,请在java包下创建com.cn.panda包;再在com.cn.panda中创建与Java代码相关的包;常见的有:controller、entity、service、mapper、config、interceptor等,图示如下:

创建与resources代码相关的包

请在resources下以com/cn/panda/mapper的方式创建com.cn.panda.mapper包用于存放mapper的映射文件。

注意事项:

  • 1、请勿以com.cn.panda.mappe的方式创建mapper包
  • 2、mapper映射文件的包名需与mapper的接口文件所在包的包名保持一致

图示如下:

创建与webapp相关的文件夹

请在webapp下创建与项目页面资源相关的文件夹,常见的有:css、fonts、imgs、js等;图示如下:

创建与WEB-INF相关的文件夹

请在WEB-INF下创建与项目页面相关的文件夹。在此,先创建jsp文件夹再在jsp下创建back文件夹用于存放后台页面,再在jsp下创建front文件夹用于存放前端页面;图示如下:

编写各层代码

接下来,我们按照分层思想以用户查询为例完成代码的编写工作。

User类

请在entity包下创建User类。

User类作为JavaBean,其属性名应尽量与数据库中user表的字段保持一致。

package com.cn.panda.entity;

/**
 * 本文作者:谷哥的小弟
 * 博客地址:http://blog.csdn.net/lfdfhl
 */
public class User 
    private String username;
    private String password;

    public User() 
    

    public User(String username, String password) 
        this.username = username;
        this.password = password;
    

    public String getUsername() 
        return username;
    

    public void setUsername(String username) 
        this.username = username;
    

    public String getPassword() 
        return password;
    

    public void setPassword(String password) 
        this.password = password;
    

    @Override
    public String toString() 
        return "User" +
                "username='" + username + '\\'' +
                ", password='" + password + '\\'' +
                '';
    

UserMapper接口文件

请在java中的mapper包下创建UserMapper接口文件UserMapper.java。

要点概述:

  • 1、在该接口中定义方法findUserById( )
  • 2、在UserMapper接口上使用@Repository注解
package com.cn.panda.mapper;

import com.cn.panda.entity.User;
import org.springframework.stereotype.Repository;
/**
 * 本文作者:谷哥的小弟
 * 博客地址:http://blog.csdn.net/lfdfhl
 */

@Repository
public interface UserMapper 
    User findUserById(int id);


UserMapper映射文件

请在resources中的mapper包下创建UserMapper映射文件UserMapper.xml。

要点概述:

  • 1、映射文件名与映射接口名保持一致,均为UserMapper;但是,后缀不同
  • 2、映射文件中的namespace属性值为接口文件UserMapper.java所在的包
  • 3、select标签的id属性值为接口文件UserMapper.java中的方法名findUserById
  • 4、select标签的parameterType属性值为findUserById方法的输入参数类型
  • 5、select标签的resultType属性值为findUserById方法的返回值类型;但是,其首字母小写。此时,xml文件提醒user报错;别急,稍后通过配置统一解决。
  • 6、select标签中使用占位符编写SQL语句
<?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">
<mapper namespace="com.cn.panda.mapper.UserMapper">
    <select id="findUserById" parameterType="int" resultType="user">
        select * from user where id = #id
    </select>

</mapper>

UserService

请在service包下创建UserService接口。

请在service包下创建impl子包并在impl包下创建UserService接口的实现类UserServiceImpl。

要点概述:

  • 1、在UserServiceImpl类上使用@Service注解
  • 2、在UserServiceImpl类中使用@Autowired注入UserMapper
  • 3、在UserServiceImpl类中定义queryUser()方法
  • 4、在queryUser()方法中调用UserMapper的findUserById()方法

UserService接口如下:

package com.cn.panda.service;

import com.cn.panda.entity.User;
/**
 * 本文作者:谷哥的小弟
 * 博客地址:http://blog.csdn.net/lfdfhl
 */

public interface UserService 
    User queryUser(int id);


UserServiceImpl类如下:

package com.cn.panda.service.impl;

import com.cn.panda.entity.User;
import com.cn.panda.mapper.UserMapper;
import com.cn.panda.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
 * 本文作者:谷哥的小弟
 * 博客地址:http://blog.csdn.net/lfdfhl
 */

@Service
public class UserServiceImpl implements UserService 

    @Autowired
    private UserMapper userMapper;

    public User queryUser(int id) 
        return userMapper.findUserById(id);
    




UserController

请在controller包下创建UserController。

要点概述:

  • 1、在UserController类上使用@Controller注解和@RequestMapping注解
  • 2、在UserController类中使用@Autowired注入UserService
  • 3、在UserController类中定义getUser()方法
  • 4、在getUser()方法上使用@GetMapping注解
  • 5、在getUser()方法中调用UserService的queryUser()方法
  • 6、getUser()方法的返回值为跳转页面的路径
package com.cn.panda.controller;

import com.cn.panda.entity.User;
import com.cn.panda.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
/**
 * 本文作者:谷哥的小弟
 * 博客地址:http://blog.csdn.net/lfdfhl
 */

@Controller
@RequestMapping("user")
public class UserController 

    @Autowired
    private UserService userService;

    @GetMapping("getUser")
    public String getUser(int id) 
        User user = userService.queryUser(id);
        System.out.println(user);
        return "front/user";
    



user.jsp

请在front包下创建user.jsp页面。

<html>
<body>
<h2>This is user page</h2>
</body>
</html>

LoginInterceptor

请在interceptor下创建登陆拦截器LoginInterceptor。

要点概述:

  • 1、LoginInterceptor类实现HandlerInterceptor接口
  • 2、HandlerInterceptor接口中的preHandle()方法返回true表示不拦截
  • 3、请在项目中依据实际情况完善preHandle()方法
package com.cn.panda.interceptor;

import org.springframework.web.servlet.HandlerInterceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
/**
 * 本文作者:谷哥的小弟
 * 博客地址:http://blog.csdn.net/lfdfhl
 */

public class LoginInterceptor implements HandlerInterceptor 

    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception 

        return true;
    


编写配置文件

在此,完善项目各个配置文件的编写。

请在resources包下创建以下配置文件:

  • Spring配置文件applicationContext.xml
  • 数据库配置文件db.properties
  • 日志配置文件log4j.properties
  • MyBatis配置文件mybatis-config.xml
  • Spring MVC配置文件springmvc-config.xml

另外,还需配置WEB-INF中的web.xml

要点概述:

  • 1、请务必注意各配置文件中的包名,请依据项目实际情况设置
  • 2、请务必注意各配置文件中的路径,请依据项目实际情况设置
  • 3、请务必注意各配置文件中的配置信息,请依据项目实际情况设置
  • 4、请务必注意各配置文件截图的红色标记,请依据项目实际情况设置

log4j.properties

# Global logging configuration
log4j.rootLogger=ERROR, stdout
# MyBatis logging configuration...
log4j.logger.com.cn.panda=DEBUG
# Console output...
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

db.properties

jdbc.url=jdbc:mysql://localhost:3306/panda
jdbc.driver=com.mysql.jdbc.Driver
jdbcSSM 框架 搭建整合(IDEA)保姆级

2022新版图文详解SpringBoot整合SSM框架(附源码)

利用LAMP搭建论坛(图文详解,保姆级教程)

MQ4万字保姆教程|RabbitMQ知识点整理与Springboot整合附Demo(图文并茂)

Anaconda下载及安装保姆级教程(详细图文)

IDEA下载与安装,保姆级教程