qq邮箱格式怎么写才是正确的 qq邮箱的格式怎样写



文章插图
qq邮箱格式怎么写才是正确的 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 = [email protected]#发送短信后它给你的授权码 填写到这里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.Driverspring.datasource.url=jdbc:mysql://localhost:3306/email?useSSL=true&characterEncoding=utf-8&serverTimezone=UTCspring.datasource.username=rootspring.datasource.password=root#配置mappermybatis.mapper-locations=classpath:mapper/*.xml2.4、创建数据库
数据库结构如下图
创建一个数据库email
CREATEDATABASEemail;在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=InnoDBAUTO_INCREMENT=6DEFAULTCHARSET=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;@Controllerpublic class UserController {@Autowiredprivate MailService mailService;@PostMapping("/sendEmail")@ResponseBodypublic String sendEmail(String email, HttpSession httpSession){mailService.sendMimeMail(email, httpSession);return "sucess";}@PostMapping("/regist")@ResponseBodypublic String regist(UserVo userVo, HttpSession session){mailService.registered(userVo,session);return "sucess";}@PostMapping("/login")@ResponseBodypublic 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;@[email protected] interface UserMapper {/*** 注册,插入数据* @param user*/void insertUser(User user);/*** 根据邮箱查询* @param email* @return*/User queryByEmail(String email);}【qq邮箱格式怎么写才是正确的 qq邮箱的格式怎样写】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;@Servicepublic class MailService {@Autowiredprivate JavaMailSender mailSender;[email protected]@Autowiredprivate 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);//发送returntrue;}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 mapperPUBLIC "-//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 userwhere email = #{email}</select></mapper>4、使用postman测试
如果没有这个软件,安装一下,使用很简单 。打开后,点击左上角的file,再点击New Tab,就会出来一个页面 。(或者使用Ctrl+T快捷键)
4.1、测试发送邮件
请求url:
http://localhost:[email protected]
把请求url复制到如下如的url中, 邮箱换成自己的,请求方式换成POST 。点击send 。如下图
4.2、测试注册
请求url:
http://localhost:8080/regist
把请求url复制到如下如的url中, 邮箱换成自己的,code的值写邮箱收到的,请求方式换成POST 。点击send,如下图
4.3、测试登录
请求url:
http://localhost:[email protected]&password=12345
复制url,改成POST请求,点击Send 。
如下图: