以下操作基于
2020.3企业版
1.创建Java Enterprise
项目
直接默认即可
输入项目相关信息
点击完成后,得到以下目录结构
2.搭建项目目录结构
java目录下
-
controller:实现控制转发,基本参数校验,不复杂的简单业务处理
-
config:配置类存放的地方
-
service:业务逻辑层
- impl(实现层)
-
dao:数据持久层
-
entitry:实体类
-
resources
- mappers(存放sql语句)
-
webapp
-
WEB-INF
- views(视图的JSP文件)
-
3.导入依赖
在pom.xml
文件中导入SSM框架相关依赖
<!-- spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.3.23</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>5.3.23</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.3.23</version>
<scope>test</scope>
</dependency>
<!-- spring mvc -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.3.23</version>
</dependency>
<!-- jstl -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp.jstl</groupId>
<artifactId>jstl-api</artifactId>
<version>1.2</version>
</dependency>
<!-- JDBC -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.30</version>
</dependency>
<!-- mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.11</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.7</version>
</dependency>
导入完成后,点击右上角的更新
如果没有出现
Spring Config
,则检查一下是否正确安装了依赖了
4.通过类配置项目
创建类App
在config目录下创建类App
- 添加注解
@Configuration
——表示为配置类
- 添加注解
ComponentScan
——扫描service
@ComponentScan(basePackages = "com.leo.SSM.service")
注意:
- basePackages 配置:查看下图位置
这里扫描的包对应位置也需要添加注解
例如这里,我扫描了service,那与之对应的就需要在service的各个类中添加注解
@Service
为防止后面忘记,先在service目录下创建一个service接口
在service
->impl
下创建对应的实现类
在实现类中添加@Service
注解
实现接口
- 添加注解
@MapperScan
——扫描dao
@MapperScan(basePackages = "com.leo.SSM.dao")
创建UserDao接口
添加注解@Mapper
package com.leo.SSM.dao;
import org.apache.ibatis.annotations.Mapper;
@Mapper
public class UserDao {
}
- 添加注解——添加配置源(配置jdbc)
直接直接复制下列代码进入项目即可
@PropertySource("classpath:jdbc.properties")
创建jdbc配置文件
在resources
下创建jdbc.properties
选择Resource Bundle
仅输入名称即可
创建完成
进行配置
jdbc.driver=com.mysql.cj.jdbc.Driver
jdbc.url=jdbc:mysql:///studb?useSSL=false
jdbc.username=你SQL的用户名
jdbc.password=SQL的密码
- 开启事务管理
在App类中继续添加@EnableTransactionManagement
注解,表示开启事务
配置类App
创建于jdbc对应的属性
private String driver;
private String url;
private String userName;
private String password;
- 添加注解,设置值
@Value("${jdbc.driver}")
属性的最终配置
@Value("${jdbc.driver}")
private String driver;
@Value("${jdbc.url}")
private String url;
@Value("${jdbc.username}")
private String userName;
@Value("${jdbc.password}")
private String password;
配置数据源
- 创建方法,并添加
@Bean
注解——往IOC容器中放东西
@Bean
public DataSource dataSource(){
}
- 创建一个dataSource并返回
DriverManagerDataSource dataSource = new DriverManagerDataSource();
dataSource.setDriverClassName(driver);
dataSource.setUrl(url);
dataSource.setUsername(userName);
dataSource.setPassword(password);
return dataSource;
配置mybatis中的SqlSessionFacotry
- 创建方法,添加注解
@Bean
public SqlSessionFactory sqlSessionFactory(){
}
-
配置mybatis相关属性
- 数据源
- 映射包名
- 对应sql存放位置
- 映射关系(下划线改为小驼峰)
SqlSessionFactoryBean sqlSessionFactoryBean = new SqlSessionFactoryBean();
sqlSessionFactoryBean.setDataSource(dataSource());
// 映射包名
sqlSessionFactoryBean.setTypeAliasesPackage("com.leo.SSM.entity");
PathMatchingResourcePatternResolver resolver = new PathMatchingResourcePatternResolver();
sqlSessionFactoryBean.setMapperLocations(
resolver.getResources("classpath*:mappers/*.xml")
);
org.apache.ibatis.session.Configuration configuration = Objects.requireNonNull(sqlSessionFactoryBean.getObject()).getConfiguration();
configuration.setMapUnderscoreToCamelCase(true);
return sqlSessionFactoryBean.getObject();
配置事务
@Bean
public PlatformTransactionManager transactionManager(){
DataSourceTransactionManager transactionManager = new DataSourceTransactionManager();
transactionManager.setDataSource(dataSource());
return transactionManager;
}
配置Web-MVC
在config文件夹下创建类WebMvcConfig
- 添加注解
@Configuration
,声明配置类
import org.springframework.context.annotation.Configuration;
@Configuration
- 添加注解
@EnableWebMvc
——启动webMvc
import org.springframework.web.servlet.config.annotation.EnableWebMvc;
@EnableWebMvc
- 扫包与controller对应
import org.springframework.context.annotation.ComponentScan;
@ComponentScan(basePack
ages = "com.leo.SSM.controller")
实现WebMvcConfigurer
public class WebMvcConfig implements WebMvcConfigurer {
}
选择重写方法
按ctrl
+o
选择以下方法进行重写
- addViewControllers
- configureViewResolvers
添加视图解析器
- 设置视图对应文件位置
- 设置视图文件后缀
- 设置视图解析器,支持JSTL
private ViewResolver viewResolver(){
InternalResourceViewResolver viewResolver = new InternalResourceViewResolver();
viewResolver.setPrefix("/WEB-INF/views/");
viewResolver.setSuffix(".jsp");
viewResolver.setViewClass(JstlView.class);
return viewResolver;
}
注册视图解析器
在configureViewResolvers
方法中,进行视图解析器的注册
@Override
public void configureViewResolvers(ViewResolverRegistry registry) {
// 注册视图解析器
registry.viewResolver(viewResolver());
}
添加view的控制
在spring中,很可能出现很多仅需要页面跳转而没有具体业务逻辑的代码比如
@GetMapping('/login') public String login(){ return "login"; }
这样长久以往就会生成很多这样的空方法,因此我们需要通过SprIngMVC中的
addViewControllers
简化实现上述逻辑
- 设置
/
对应的页面为login
@Override
public void addViewControllers(ViewControllerRegistry registry) {
registry.addViewController("/").setViewName("login");
}
创建Controller
在controller
目录下创建UserController
类,添加注解@Controller
package com.leo.SSM.controller;
import org.springframework.stereotype.Controller;
@Controller
public class UserController {
}
配置整体servlet
创建类AppInit
在config目录下创建AppInit
类,并继承AbstractAnnotationConfigDispatcherServletInitializer
继承的类用于DispatcherServlet 初始化
DispatcherServlet
:Spring MVC的核心组件,它是request首先到达的地方,负责在各个组件间传递加工
- 完成servlet容器功能
- 完成配置MVC基础功能
- 完成配置
DispatcherServlet
和ContextLoaderListener
ContextLoaderListener——Spring实现了Tomcat提供的ServletContextListener接口,写了一个监听器来监听项目启动。一旦项目启动,会触发ContextLoaderListener中的特定方法
实现其方法
修改各方法逻辑
**getRootConfigClasses——**配置root上下文(数据源等)
这里直接从我们的APP中获取即可
@Override
protected Class<?>[] getRootConfigClasses() {
return new Class[]{App.class};
}
**getServletConfigClasses——**配置dispatcher servlet(视图解析器)
这里从
WebMvcConfig
中获取
@Override
protected Class<?>[] getServletConfigClasses() {
return new Class[]{WebMvcConfig.class};
}
getServletMappings——指定开始被servlet处理的url(默认设置为 /
)
@Override
protected String[] getServletMappings() {
return new String[]{"/"};
}
5.实现login页面
在WebMvcConfig.java
文件配置下的prefix目录下创建文件,名称为login
<%--
Created by IntelliJ IDEA.
User: Leo
Date: 2022/11/6
Time: 15:37
To change this template use File | Settings | File Templates.
--%>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
</head>
<body>
<form action="login" method="post">
<label>
用户名:
<input name="userName" />
<span style="color: red">
${msg}
</span>
</label>
<br />
<label>
密   码:
<input name="passwd" type="password" />
</label>
<br/>
<input type="submit" value="登录">
</form>
</body>
</html>
6.创建userController
在UserController
添加方法
@PostMapping("/login")
public String login(){
return "index";
}
因为在form表单中
- action = login ----> (“/login”)
- method=“post” —>@PostMapping
我们运行测试一下
当我们点击登录时,返回的页面就是index.jsp
当然,现在没有进行逻辑判断,但是实际上对于webmvc的配置已经成功
7.创建实体类
在entity
文件目录下创建与数据库对应的类
8.实现UserDao
定义接口
首先我们需要实现登录接口,因此在UserDao中定义获取用户信息的接口
UserInfo getUserInfo(@Param("userNumber") String userNumber , @Param("passwd") String passwd);
实现SQL
在resources
->mappers
创建UserMapper.xml文件
<?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.leo.SSM.dao.UserDao">
<select
id="getUserInfo"
resultType="com.leo.SSM.entity.UserInfo"
>
select
pk_user_id,
u_number,
u_name,
u_passwd
from user_info
where u_number = #{userNumber} and u_passwd = #{passwd}
</select>
</mapper>
9.实现UserService
在UserService
接口出定义方法
- 返回类型——boolean
- 传递参数
- 方法名——login
package com.leo.SSM.service;
import javax.servlet.http.HttpSession;
import java.util.List;
public interface UserService {
Boolean login(String userNumber , String passwd, HttpSession session, Model model);
}
定义属性
使用注解
@Resource
将userDAO交给Spring进行管理
@Resource
private UserDAO userDAO;
实现方法
@Override
public Boolean login(String userNumber, String passwd, HttpSession session) {
UserInfo userInfo = null;
userInfo = userDAO.getUserInfo(userNumber , passwd);
if(null != userInfo){
session.setAttribute("user",userInfo);
return true;
}else{
model.addAttribute("msg","用户名或密码错误");
return false;
}
}
10.实现UserController逻辑
添加属性——UserService
@Resource
private UserService userService;
修改函数参数
与login.jsp中的name对应
login(String userName , String password , HttpSession session)
修改逻辑
直接调用UserService,判断返回值
- true——进入index.jsp页面
- false——停留在login.jsp页面
boolean isSuccess = userService.login(userName , password,session);
if(isSuccess){
return "index";
}else{
return "login";
}
实现logout
- 使session失效
- 设置提示信息
- 跳转login页面
@PostMapping("/logout")
public String logout(HttpSession session, Model model){
session.invalidate();
model.addAttribute("msg","退出成功");
return "login";
}