Spring Boot如何实现基于qq邮箱的验证码注册及登录身份验证功能?
- 内容介绍
- 文章标签
- 相关推荐
本文共计1273个文字,预计阅读时间需要6分钟。
1. 登录/注册思路:这是一个基于Spring Boot开发的QQ邮箱注册和登录项目。项目不含前端页面,使用Postman进行测试。附有截图详细说明。 1.1 注册思路:通过输入邮箱发送验证码,前端传递验证码进行验证。
1、登录注册思路
这是一个使用spring boot做的一个qq邮箱注册和登录的项目。
没写前端页面,使用postman测试。有截图详细。
1.1、思路
注册:通过输入的邮箱发送验证码,检验前端传来的验证码是否和后台生成的一致,若一致,将数据写入数据库,完成注册;
登录:通过输入的邮箱查询密码,然后比较密码是否一致,一致就是登录成功。
1.2、整个项目结构图
2、准备
2.1、开启邮箱POP3/SMTP服务
登录qq邮箱后,点击左上方的设置,选择账户,如下图。
然后一直往下滑,看到如下图的POP3/SMTP服务,点击开启,应该会让帮定的手机号发个短信,然后会收到一个授权码,一定要好好保存,在appliction.properties配置中会用到。
2.2、创建一个spring boot项目的时候,一直确认,jdk选择8。
下边是pom.xml中<dependencies>标签的全部依赖
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!--web--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-mail</artifactId> </dependency> <!--mybatis--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.2</version> </dependency> <!--jdbc--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.19</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> </dependencies>
2.3、application.properties配置文件
application.properties配置文件
#邮箱配置 #平台地址,这里用的是qq邮箱,使用其他邮箱请更换 spring.mail.host = smtp.qq.com #改成自己的邮箱 spring.mail.username = xxxxx@qq.com #发送短信后它给你的授权码 填写到这里 spring.mail.password = xxxxxx #这东西不用改 spring.mail.properties.mail.smtp.ssl.enable=true ##编码格式 spring.mail.default-encoding=UTF-8 #数据库相关配置 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/email?useSSL=true&characterEncoding=utf-8&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=root #配置mapper mybatis.mapper-locations=classpath:mapper/*.xml
2.4、创建数据库
数据库结构如下图
创建一个数据库email
CREATE DATABASE email;
在email数据库创建user表
CREATE TABLE `user` ( `id` int(20) NOT NULL AUTO_INCREMENT, `username` varchar(255) NOT NULL, `password` varchar(255) NOT NULL, `email` varchar(255) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
3、全部代码类
如最上边的项目结构图。controller包是和前端对接的,mapper包中是接口,pojo是实体类,service层是逻辑代码,vo包是前端发送数据暂时保存。
执行流程: 使用postman发送请求,controller中会接受,然后调用service中的逻辑代码,service会调用的mapper中接口,mapper的对应的xml实现对数据库的各种操作。
3.1、UserController.java
package com.lu.youxiang.controller; import com.lu.youxiang.service.MailService; import com.lu.youxiang.vo.UserVo; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.ResponseBody; import javax.servlet.mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.lu.youxiang.mapper.UserMapper"> <insert id="insertUser" parameterType="com.lu.youxiang.pojo.User"> insert into user (username,password,email) values (#{username},#{password},#{email}) </insert> <select id="queryByEmail" resultType="com.lu.youxiang.pojo.User"> select * from user where email = #{email} </select> </mapper>
4、使用postman测试
如果没有这个软件,安装一下,使用很简单。
打开后,点击左上角的file,再点击New Tab,就会出来一个页面。
(或者使用Ctrl+T快捷键)
4.1、测试发送邮件
请求url:
localhost:8080/sendEmail?email=123456@qq.com
把请求url复制到如下如的url中, 邮箱换成自己的,请求方式换成POST。点击send。
如下图
4.2、测试注册
请求url:
localhost:8080/regist
把请求url复制到如下如的url中, 邮箱换成自己的,code的值写邮箱收到的,请求方式换成POST。点击send,如下图
4.3、测试登录
请求url:
localhost:8080/login?email=123456@qq.com&password=12345
复制url,改成POST请求,点击Send。
如下图
总结
到此这篇关于Spring Boot实现qq邮箱验证码注册和登录验证功能的文章就介绍到这了,更多相关SpringBoot qq邮箱验证码注册和登录内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!
本文共计1273个文字,预计阅读时间需要6分钟。
1. 登录/注册思路:这是一个基于Spring Boot开发的QQ邮箱注册和登录项目。项目不含前端页面,使用Postman进行测试。附有截图详细说明。 1.1 注册思路:通过输入邮箱发送验证码,前端传递验证码进行验证。
1、登录注册思路
这是一个使用spring boot做的一个qq邮箱注册和登录的项目。
没写前端页面,使用postman测试。有截图详细。
1.1、思路
注册:通过输入的邮箱发送验证码,检验前端传来的验证码是否和后台生成的一致,若一致,将数据写入数据库,完成注册;
登录:通过输入的邮箱查询密码,然后比较密码是否一致,一致就是登录成功。
1.2、整个项目结构图
2、准备
2.1、开启邮箱POP3/SMTP服务
登录qq邮箱后,点击左上方的设置,选择账户,如下图。
然后一直往下滑,看到如下图的POP3/SMTP服务,点击开启,应该会让帮定的手机号发个短信,然后会收到一个授权码,一定要好好保存,在appliction.properties配置中会用到。
2.2、创建一个spring boot项目的时候,一直确认,jdk选择8。
下边是pom.xml中<dependencies>标签的全部依赖
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <!--web--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-mail</artifactId> </dependency> <!--mybatis--> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>1.3.2</version> </dependency> <!--jdbc--> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.19</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> </dependencies>
2.3、application.properties配置文件
application.properties配置文件
#邮箱配置 #平台地址,这里用的是qq邮箱,使用其他邮箱请更换 spring.mail.host = smtp.qq.com #改成自己的邮箱 spring.mail.username = xxxxx@qq.com #发送短信后它给你的授权码 填写到这里 spring.mail.password = xxxxxx #这东西不用改 spring.mail.properties.mail.smtp.ssl.enable=true ##编码格式 spring.mail.default-encoding=UTF-8 #数据库相关配置 spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/email?useSSL=true&characterEncoding=utf-8&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=root #配置mapper mybatis.mapper-locations=classpath:mapper/*.xml
2.4、创建数据库
数据库结构如下图
创建一个数据库email
CREATE DATABASE email;
在email数据库创建user表
CREATE TABLE `user` ( `id` int(20) NOT NULL AUTO_INCREMENT, `username` varchar(255) NOT NULL, `password` varchar(255) NOT NULL, `email` varchar(255) NOT NULL, PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=6 DEFAULT CHARSET=utf8;
3、全部代码类
如最上边的项目结构图。controller包是和前端对接的,mapper包中是接口,pojo是实体类,service层是逻辑代码,vo包是前端发送数据暂时保存。
执行流程: 使用postman发送请求,controller中会接受,然后调用service中的逻辑代码,service会调用的mapper中接口,mapper的对应的xml实现对数据库的各种操作。
3.1、UserController.java
package com.lu.youxiang.controller; import com.lu.youxiang.service.MailService; import com.lu.youxiang.vo.UserVo; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PostMapping; import org.springframework.web.bind.annotation.ResponseBody; import javax.servlet.mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.lu.youxiang.mapper.UserMapper"> <insert id="insertUser" parameterType="com.lu.youxiang.pojo.User"> insert into user (username,password,email) values (#{username},#{password},#{email}) </insert> <select id="queryByEmail" resultType="com.lu.youxiang.pojo.User"> select * from user where email = #{email} </select> </mapper>
4、使用postman测试
如果没有这个软件,安装一下,使用很简单。
打开后,点击左上角的file,再点击New Tab,就会出来一个页面。
(或者使用Ctrl+T快捷键)
4.1、测试发送邮件
请求url:
localhost:8080/sendEmail?email=123456@qq.com
把请求url复制到如下如的url中, 邮箱换成自己的,请求方式换成POST。点击send。
如下图
4.2、测试注册
请求url:
localhost:8080/regist
把请求url复制到如下如的url中, 邮箱换成自己的,code的值写邮箱收到的,请求方式换成POST。点击send,如下图
4.3、测试登录
请求url:
localhost:8080/login?email=123456@qq.com&password=12345
复制url,改成POST请求,点击Send。
如下图
总结
到此这篇关于Spring Boot实现qq邮箱验证码注册和登录验证功能的文章就介绍到这了,更多相关SpringBoot qq邮箱验证码注册和登录内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

