[node.js]调用阿里云api,实现手机验证码

 登陆阿里云-计算,为了无法计算的价值 (aliyun.com)

完成配置

资质,签名,模板进行申请

签名名称

注意:

关联签名必须与

对应

node实现

安装  npm i  @alicloud/pop-core

在app中配置

app.use(express.json()); // 解析请求中的 JSON 数据

const Core = require("@alicloud/pop-core"); // 引入阿里云 SDKA

const client = new Core({
  // 创建 Client 对象
  accessKeyId: "", // 替换成自己的 AccessKey ID
  accessKeySecret: "", // 替换成自己的 AccessKey Secret
  endpoint: "https://dysmsapi.aliyuncs.com", // API 访问入口,根据实际情况修改
  apiVersion: "2017-05-25", // API 版本号,根据实际情况修改
});
// 生成随机验证码
function generateCode() {
  const characters =
    "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
  let code = "";

  for (let i = 0; i < 6; i++) {
    const randomIndex = Math.floor(Math.random() * characters.length);
    code += characters.charAt(randomIndex);
  }

  return code;
}

const randomCode = generateCode();
// 发送短信验证码
router.post("/sendCode", (req, res) => {
  const phoneNumber = req.body.phoneNumber; // 获取手机号码

  const code = generateCode(); // 生成验证码
  const params = {
    RegionId: "cn-hangzhou", // 短信服务所在区域,可以参考阿里云文档
    PhoneNumbers: phoneNumber, // 目标手机号码
    SignName: "", // 短信签名名称,需先在阿里云控制台中申请审核通过
    TemplateCode: "", // 短信模板 CODE,需先在阿里云控制台中申请审核通过
    TemplateParam: JSON.stringify({
      // 短信模板参数,为 JSON 字符串格式
      code: code, // 模板中的变量名和对应的值
    }),
  };

  const requestOption = {
    // 设置请求超时时间等选项
    method: "POST",
    timeout: 5000,
  };
  // 调用 SendSms 方法发送短信
  client.request("SendSms", params, requestOption).then(
    (result) => {
      console.log(result); // 打印发送结果

      res.status(200).json({
        // 返回状态码和生成的验证码
        message: "验证码已发送,请注意查收!",
        code: code,
      });
    },
    (ex) => {
      console.log(ex); // 打印异常信息

      res.status(500).json({
        // 返回错误状态码和错误信息
        message: "短信发送失败,请稍后重试!",
      });
    }
  );
});


// 验证验证码的有效期
function isCodeValid(creationTime) {
  const currentTime = Date.now();
  const expirationTime = 5 * 60 * 1000; // 5分钟的毫秒数

  return currentTime - creationTime <= expirationTime;
}
router.post("/login", (req, res) => {
  const phoneNumber = req.body.phoneNumber; // 获取手机号码
  const inputCode = req.body.code; // 获取用户输入的验证码
  const generatedCode = req.body.generatedCode; // 获取之前生成的验证码
  const creationTime = req.body.creationTime; // 获取验证码生成时间

  // 验证验证码是否一致和是否在有效期内(5分钟)
  if (inputCode === generatedCode && isCodeValid(creationTime)) {
    // 验证码一致且在有效期内,登录成功
    res.status(200).json({
      message: "登录成功!",
    });
  } else {
    // 验证码不一致或已过期,登录失败
    res.status(401).json({
      message: "验证码错误或已过期,请重新获取!",
    });
  }
});

  • 14
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值