正确的邮箱qq格式怎么写(个人电子邮箱填写方法)
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.http.httpsession;
@controller
public class usercontroller {
@autowired
private mailservice mailservice;
@postmapping("/sendemail")
@responsebody
public string sendemail(string email, httpsession httpsession){
mailservice.sendmimemail(email, httpsession);
return "sucess";
}
@postmapping("/regist")
@responsebody
public string regist(uservo uservo, httpsession session){
mailservice.registered(uservo,session);
return "sucess";
}
@postmapping("/login")
@responsebody
public string login(string email, string password){
mailservice.loginin(email,password);
return "sucess";
}
}
3.2、usermapper.java
package com.lu.youxiang.mapper;
import com.lu.youxiang.pojo.user;
import org.apache.ibatis.annotations.mapper;
import org.springframework.stereotype.repository;
@mapper
@repository
public interface usermapper {
/**
* 注册,插入数据
* @param user
*/
void insertuser(user user);
/**
* 根据邮箱查询
* @param email
* @return
*/
user querybyemail(string email);
}
3.3、user.java
package com.lu.youxiang.pojo;
public class user {
private string username;
private string password;
private string email;
//get和set方法省略了,自己生成一下
}
3.4、mailservice.java ,重要。
package com.lu.youxiang.service;
import com.lu.youxiang.mapper.usermapper;
import com.lu.youxiang.pojo.user;
import com.lu.youxiang.vo.uservo;
import com.lu.youxiang.vo.uservotouser;
import org.springframework.beans.factory.annotation.autowired;
import org.springframework.beans.factory.annotation.value;
import org.springframework.mail.simplemailmessage;
import org.springframework.mail.javamail.javamailsender;
import org.springframework.stereotype.service;
import javax.servlet.http.httpsession;
import java.util.random;
@service
public class mailservice {
@autowired
private javamailsender mailsender;//一定要用@autowired
@autowired
private usermapper usermapper;//注入usermapper,交给bena
//application.properties中已配置的值
@value("${spring.mail.username}")
private string from;
/**
* 给前端输入的邮箱,发送验证码
* @param email
* @param session
* @return
*/
public boolean sendmimemail( string email, httpsession session) {
try {
simplemailmessage mailmessage = new simplemailmessage();
mailmessage.setsubject("验证码邮件");//主题
//生成随机数
string code = randomcode();
//将随机数放置到session中
session.setattribute("email",email);
session.setattribute("code",code);
mailmessage.settext("您收到的验证码是:"+code);//内容
mailmessage.setto(email);//发给谁
mailmessage.setfrom(from);//你自己的邮箱
mailsender.send(mailmessage);//发送
return true;
}catch (exception e){
e.printstacktrace();
return false;
}
}
/**
* 随机生成6位数的验证码
* @return string code
*/
public string randomcode(){
stringbuilder str = new stringbuilder();
random random = new random();
for (int i = 0; i < 6; i++) {
str.append(random.nextint(10));
}
return str.tostring();
}
/**
* 检验验证码是否一致
* @param uservo
* @param session
* @return
*/
public boolean registered(uservo uservo, httpsession session){
//获取session中的验证信息
string email = (string) session.getattribute("email");
string code = (string) session.getattribute("code");
//获取表单中的提交的验证信息
string vocode = uservo.getcode();
//如果email数据为空,或者不一致,注册失败
if (email == null || email.isempty()){
//return "error,请重新注册";
return false;
}else if (!code.equals(vocode)){
//return "error,请重新注册";
return false;
}
//保存数据
user user = uservotouser.touser(uservo);
//将数据写入数据库
usermapper.insertuser(user);
//跳转成功页面
return true;
}
/**
* 通过输入email查询password,然后比较两个password,如果一样,登录成功
* @param email
* @param password
* @return
*/
public boolean loginin(string email, string password){
user user = usermapper.querybyemail(email);
if(!user.getpassword().equals(password)){
return false;
}
system.out.println("登录成功:数据库密码是:"+user.getpassword());
return true;
}
}
3.5、uservo.java
package com.lu.youxiang.vo;
public class uservo {
private string username;
private string password;
private string email;
// 验证码
private string code;
//省略了get和set方法,自己生成一下
}
3.6、uservotouser.java
package com.lu.youxiang.vo;
import com.lu.youxiang.pojo.user;
public class uservotouser {
/**
* 将表单中的对象转化为数据库中存储的用户对象(剔除表单中的code)
* @param uservo
* @return
*/
public static user touser(uservo uservo) {
//创建一个数据库中存储的对象
user user = new user();
//传值
user.setusername(uservo.getusername());
user.setpassword(uservo.getpassword());
user.setemail(uservo.getemail());
// 返回包装后的对象
return user;
}
}
主配置类不复制了,创建springboot项目后,就有。
3.7、usermapper.xml
在resources包下创建mapper包,用来放xml,然后再这个包中创建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.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:
http://localhost:8080/sendemail?email=123456@qq.com
把请求url复制到如下如的url中, 邮箱换成自己的,请求方式换成post。点击send。
如下图
4.2、测试注册
请求url:
http://localhost:8080/regist
把请求url复制到如下如的url中, 邮箱换成自己的,code的值写邮箱收到的,请求方式换成post。点击send,如下图
4.3、测试登录
请求url:
http://localhost:8080/login?email=123456@qq.com&password=12345
复制url,改成post请求,点击send。
如下图:
下一篇: 防守炮塔攻略(最好玩的塔防手游排行榜)