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框架(附源码)