# 4、发送邮箱验证码
# 4.1、配置QQ邮箱教程
- 1、登录QQ邮箱
- 2、
邮箱首页
|设置
-换肤
的设置 - 3、点击
常规
帐户
换肤
中的帐户
- 4、POP3/SMTP服务 点击开启
- 5、复制授权码
- 6、粘贴到
uniCloud/cloudfunctions/common/uni-config-center/vk-unicloud/index.js
配置文件中
"vk":{
"service": {
"email": {
"qq": {
"host": "smtp.qq.com",
"port": 465,
"secure": true,
"auth": {
"user": "你的邮箱@qq.com",
"pass": "邮箱授权码"
}
}
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 4.2、配置163邮箱教程
- 1、登录163邮箱
- 2、
邮箱首页
|设置
-POP3/SMTP服务
- 开启POP3/SMTP服务
- 3、复制授权码
- 4、粘贴到
uniCloud/cloudfunctions/common/uni-config-center/vk-unicloud/index.js
配置文件中
"vk":{
"service": {
"email": {
"163": {
"host": "smtp.163.com",
"port": 465,
"secure": true,
"auth": {
"user": "你的邮箱@163.com",
"pass": "邮箱授权码"
}
}
}
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
2
3
4
5
6
7
8
9
10
11
12
13
14
15
# 4.3、添加 vk-mail 公共模块依赖
# 4.4、发送邮箱验证码示例代码(router内版本)
var vkmail;
try {
vkmail = require('vk-mail');
} catch (err) {
console.error("请先添加公共模块:vk-mail(右键对应的云函数,点击管理公共模块或扩展库依赖,勾选vk-mail依赖)");
}
module.exports = {
/**
* 发送邮箱验证码
* @url user/pub/sendEmailCode 前端调用的url参数地址
* @description 发送邮箱验证码
* data 请求参数 说明
* @params {String} email 邮箱
* @params {String} type 验证码类型
* res 返回参数说明
* @params {Number} code 错误码,0表示成功
* @params {String} msg 详细信息
* @params {String} email 手机号
* @params {String} verifyCode 验证码
*/
main: async (event) => {
let { data = {}, util } = event;
let { uniID, config } = util;
let { email, type } = data;
let res = {code : -1, msg : ''};
// 业务逻辑开始-----------------------------------------------------------
const randomStr = '00000' + Math.floor(Math.random() * 1000000);
let code = randomStr.substring(randomStr.length - 6);
let param = {
code,
type,
email
};
// 发送验证码开始
let emailConfig = config.vk.service.email;
// 创建邮箱服务实例
let emailService = vkmail.createTransport({
"host": emailConfig[data.serviceType].host,
"port": emailConfig[data.serviceType].port,
"secure": emailConfig[data.serviceType].secure, // use SSL
"auth": emailConfig[data.serviceType].auth
});
try{
// 发送邮件
await emailService.sendMail({
"from": emailConfig[data.serviceType].auth.user, // 邮件的发送者
"to": data.email, // 邮件的接收者
"cc": emailConfig[data.serviceType].auth.user, // 由于邮件可能会被当成垃圾邮件,但只要把右键抄送给自己一份,就不会被当成垃圾邮件。
"subject": data.subject, // 邮件的标题
"text": `您的验证码是${code},打死也不要告诉别人哦!`, // 邮件的内容
});
res.code = 0;
res.msg = "ok";
}
catch(err){
res.code = -1;
res.msg = "邮件发送失败";
res.err = err;
}
// 发送验证码结束
if(res.code === 0){
// 发送验证码成功后,设置验证码
await uniID.setVerifyCode(param);
}
// 业务逻辑结束-----------------------------------------------------------
return res;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# 4.5、发送邮箱验证码示例代码(非router版本)
'use strict';
// 通过 require 引入 vk 实例
const vk = require('vk-unicloud');
// 通过 vk.init 初始化 vk实例(只有初始化后才能使用)
vk.init({
baseDir: __dirname,
requireFn: require
});
var vkmail;
try {
vkmail = require('vk-mail');
} catch (err) {
console.error("请先添加公共模块:vk-mail(右键对应的云函数,点击管理公共模块或扩展库依赖,勾选vk-mail依赖)");
}
exports.main = async (event, context) => {
let res = { code: 0, msg: "" };
let { config = {} } = vk.getUnicloud();
let emailConfig = config.vk.service.email;
let serviceType = "qq";
let email = "发送给谁,他的邮箱";
let subject = "标题";
let text = `验证码 123456`;
// 创建邮箱服务实例
let emailService = vkmail.createTransport({
"host": emailConfig[serviceType].host,
"port": emailConfig[serviceType].port,
"secure": emailConfig[serviceType].secure, // use SSL
"auth": emailConfig[serviceType].auth
});
try {
// 发送邮件
res.sendMailRes = await emailService.sendMail({
"from": emailConfig[serviceType].auth.user, // 邮件的发送者
"to": email, // 邮件的接收者
"cc": emailConfig[serviceType].auth.user, // 由于邮件可能会被当成垃圾邮件,但只要把右键抄送给自己一份,就不会被当成垃圾邮件。
"subject": subject, // 邮件的标题
"text": text, // 邮件的内容
});
res.code = 0;
res.msg = "ok";
} catch (err) {
res.code = -1;
res.msg = "邮件发送失败";
res.err = err;
}
return res;
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
# 4.6、发送邮箱验证码示例代码(uniCloud通用版本,也是 node.js 通用版本)
'use strict';
var vkmail;
try {
vkmail = require('vk-mail');
} catch (err) {
console.error("请先添加公共模块:vk-mail(右键对应的云函数,点击管理公共模块或扩展库依赖,勾选vk-mail依赖)");
}
exports.main = async (event, context) => {
let res = { code: 0, msg: "" };
let {
email, // 前端接收邮箱
type = "bind", // 前端接收验证码类型(如: login register bind unbind)
} = event;
// 支持QQ 163 等主流邮箱
let emailConfig = {
"host": "smtp.163.com",
"port": 465,
"secure": true,
"auth": {
"user": "xxxx@163.com", // 发件人邮箱账号
"pass": "xxxxxxxxxxxx", // 账号授权码
}
};
if (!email) return { code: -1, msg: "email不能为空" };
if (!type) return { code: -1, msg: "type不能为空" };
let code = Math.floor(Math.random() * 100000) + 100000;
let subject = `验证码 ${code}`;
let text = `验证码 ${code},打死也不要告诉别人!`;
// 创建邮箱服务实例
let emailService = vkmail.createTransport({
"host": emailConfig.host,
"port": emailConfig.port,
"secure": emailConfig.secure, // use SSL
"auth": emailConfig.auth
});
try {
// 发送邮件
res.sendMailRes = await emailService.sendMail({
"from": emailConfig.auth.user, // 邮件的发送者
"to": email, // 邮件的接收者
"cc": emailConfig.auth.user, // 由于邮件可能会被当成垃圾邮件,但只要把右键抄送给自己一份,就不会被当成垃圾邮件。
"subject": subject, // 邮件的标题
"text": text, // 邮件的内容
});
// 标记发送成功
res.code = 0;
res.msg = "ok";
// 发送验证码成功后,通常需要设置验证码(写入数据库)
// await uniID.setVerifyCode({ code, email, type });
} catch (err) {
res.code = -1;
res.msg = "邮件发送失败";
res.err = err;
}
return res;
};
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
← 3、短信发送(聚合版) uni-id配置 →