【微信小程序 - 工作实战分享】1.微信小程序发送手机短信验证码(阿里云)

简介: 【微信小程序 - 工作实战分享】1.微信小程序发送手机短信验证码(阿里云)

前言

  1. 在网站和移动应用中利用短信验证码进行信息确认是最常用的验证手段。随着短信验证码的技术更新,短信验证码的应用程序也非常多样,如交易确认、授权绑定、登录保护等。 本文用在微信小程序手机号登录
  2. 短信验证码对注册用户的管理更加方便,用户通过手机注册网站平台,手机号码+短信验证码的登录方式,操作非常简单,比起输入密码,用户可能更喜欢短信验证登录。短信验证码保证了用户注册时的质量与数量,它可以更好的校验用户真实身份,可以避免恶意注册,令企业更好的进行用户管理,减少运营维护的工作量。

一. 准备工作

  1. 没有阿里云账号先注册阿里云账户
  2. 短信功能是要收费的,所以乖乖充值吧!
  3. 完成短信签名和短信模板的申请(需要一点时间)
  4. 创建access key(后面需要使用)

二. 配置

  1. 依赖
<dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>aliyun-java-sdk-core</artifactId>
            <version>4.4.6</version>
        </dependency>
        <dependency>
            <groupId>com.aliyun</groupId>
            <artifactId>aliyun-java-sdk-ecs</artifactId>
            <version>4.17.6</version>
        </dependency>
  1. 配置阿里云短信(这里***是自己要配的,来源于阿里云短信服务)
aliyun:
    accessKey: ***
    accessSecret: ***
    sms:
      domain: ***
      SignName: ***
      TemplateCode: ***
  1. java中引入
@Value("${aliyun.accessKey}")
    private String accessKey;
    @Value("${aliyun.accessSecret}")
    private String accessSecret;
    @Value("${aliyun.sms.domain}")
    private String domain;
    @Value("${aliyun.sms.SignName}")
    private String signName;
    @Value("${aliyun.sms.TemplateCode}")
    private String templateCode;
    @Value("${water.charge.maintenanceCode}")
    private String maintenanceCode;

三. 实战代码(仅仅是后台代码,前端传入手机号)

  1. Controller
@Autowired
    private CustomerAppLoginService customerAppLoginService;
    @ApiOperation("发送手机短信")
    @GetMapping("phone/send_code")
    public JsonData phoneSendCode(@RequestParam("phone") String phone) {
        return customerAppLoginService.phoneSendCode(phone);
    }
  1. service
@Override
    public JsonData phoneSendCode(String phone) {
        // 手机号三重校验
        JsonData jsonData = tripleCheck(phone);
        if (jsonData.getCode() != 0) {
            return jsonData;
        }
        // 自定义验证码
        String vCode = RevenueUtil.getVCode();
        DefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKey, accessSecret);
        IAcsClient client = new DefaultAcsClient(profile);
        // 组装请求
        CommonRequest request = buildRequest(phone, vCode);
        try {
            CommonResponse response = client.getCommonResponse(request);
            JSONObject smsRes = JSONObject.parseObject(response.getData());
            String ok = "OK";
            String code = "Code";
            if (smsRes.get(code).equals(CODE_ERROR)) {
                return JsonData.buildResult(BizCodeEnum.REVENUE_MSG_SEND_NUM_OUT);
            }
            if (ok.equals(smsRes.get(code))) {
                log.info("send sms success: " + vCode);
                // 放入缓存,登录时校验,过期时间2分钟
                redisTemplate.opsForValue().set(phone, vCode, 120, TimeUnit.SECONDS);
            } else {
                log.error("send sms failed: " + smsRes.get("Message"));
                return JsonData.buildResult(BizCodeEnum.REVENUE_MSG_SEND_FAIL);
            }
        } catch (Exception e) {
            return JsonData.buildResult(BizCodeEnum.REVENUE_MSG_SEND_FAIL);
        }
        return JsonData.buildSuccess();
    }
  1. 用到的方法
    a. 校验手机号
/**
     * 手机号正则
     */
    private static final Pattern PHONE_PATTERN = Pattern.compile("^(13[0-9]|14[579]|15[0-3,5-9]|16[6]|17[0135678]|18[0-9]|19[89])\\d{8}$");
  /**
     * 手机号格式校验
     *
     * @return
     */
    public static Boolean validatePhone(String phone) {
        if (null == phone || "".equals(phone)) {
            return false;
        }
        Matcher m = PHONE_PATTERN.matcher(phone);
        return m.matches();
    }
b. 组装请求
/**
     * 构建 CommonRequest
     *
     * @param phone
     * @param vCode
     * @return
     */
    private CommonRequest buildRequest(String phone, String vCode) {
        CommonRequest request = new CommonRequest();
        request.setSysMethod(MethodType.POST);
        request.setSysDomain(domain);
        request.setSysVersion("2017-05-25");
        request.setSysAction("SendSms");
        request.putQueryParameter("RegionId", "cn-hangzhou");
        request.putQueryParameter("PhoneNumbers", phone);
        request.putQueryParameter("SignName", signName);
        request.putQueryParameter("TemplateCode", templateCode);
        request.putQueryParameter("TemplateParam", "{\"code\":" + vCode + "}");
        return request;
    }
  1. 附加
    代码中使用到Redis存储,用于控制验证码两分钟失效
// 放入缓存,登录时校验,过期时间2分钟
redisTemplate.opsForValue().set(phone, vCode, 120, TimeUnit.SECONDS);

总结

接口逻辑并不复杂,主要能看得懂接口文档和相关配置就行

有哪里有问题欢迎指正

下一篇:【微信小程序 - 工作实战分享】2.微信小程序相关信息获取并且登录

相关文章
|
5月前
|
JavaScript NoSQL Redis
Vue中实现修改邮箱、手机号等流程的大致过程、验证码由后端的redis生成验证(版本1.0)
这篇文章记录了在Vue中实现修改手机号和邮箱的大致流程,包括使用过滤器部分隐藏展示的手机号和邮箱,以及通过点击触发路由跳转的便捷方式。文章还描述了旧号码和新号码验证的界面实现,其中验证码由后端生成并通过弹窗展示给用户,未来可以接入真正的手机验证码接口。此外,还提供了修改邮箱的页面效果截图,并强调了学习是一个永无止境的过程。
Vue中实现修改邮箱、手机号等流程的大致过程、验证码由后端的redis生成验证(版本1.0)
|
3月前
Discuz! X3.5插件云诺-阿里云短信手机登录 会员登录后也无法查看附件图片的问题解决方法
Discuz! X3.5插件云诺-阿里云短信手机登录 会员登录后也无法查看附件图片的问题解决方法
43 2
|
3月前
|
SQL 存储 数据可视化
手机短信SQL分析技巧与方法
在手机短信应用中,SQL分析扮演着至关重要的角色
|
3月前
|
小程序 JavaScript API
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
这篇文章介绍了如何在uni-app和微信小程序中实现将图片保存到用户手机相册的功能。
1279 0
微信小程序开发之:保存图片到手机,使用uni-app 开发小程序;还有微信原生保存图片到手机
|
4月前
|
人工智能 小程序 Java
【评测】玩转阿里云《10 分钟构建 AI 客服并应用到网站、钉钉或微信中》
本文介绍了使用阿里云百炼大模型在10分钟内构建AI客服,并应用于网站、钉钉或微信中的体验。作者“JavaDog程序狗”详细描述了从搭建到完成的全过程,包括快速上手、遇到的问题及解决方法、定制化需求以及云产品的整体体验。文档清晰易懂,集成过程顺畅,客服支持响应迅速,定制功能满足特定业务需求,总体体验极佳,适合开发者尝试。
179 5
【评测】玩转阿里云《10 分钟构建 AI 客服并应用到网站、钉钉或微信中》
|
3月前
|
数据采集 消息中间件 API
Python爬虫验证码识别——手机验证码的自动化处理
Python爬虫验证码识别——手机验证码的自动化处理
122 0
|
4月前
|
小程序 前端开发 API
微信小程序 - 调用微信 API 回调函数内拿不到 this 问题(解决方案)
本文讨论了在微信小程序中调用API回调函数时无法获取到`this`上下文的问题,并提供了解决方案。在回调函数中,使用一个变量(如`that`)来保存当前的`this`引用,然后在回调内部使用这个变量来访问当前页面的数据和方法。
|
5月前
|
移动开发 小程序 前端开发
|
5月前
|
JSON 小程序 JavaScript
超详细微信小程序开发学习笔记,看完你也可以动手做微信小程序项目
这篇文章是一份全面的微信小程序开发学习笔记,涵盖了从小程序介绍、环境搭建、项目创建、开发者工具使用、文件结构、配置文件、模板语法、事件绑定、样式规范、组件使用、自定义组件开发到小程序生命周期管理等多个方面的详细教程和指南。
|
5月前
|
小程序 前端开发
微信小程序商城,微信小程序微店 【毕业设计参考项目】
文章推荐了一个微信小程序商城项目作为毕业设计参考,该项目在Github上获得18.2k星,提供了详细的使用教程和前端页面实现,适合学习微信小程序开发和作为毕业设计项目。
微信小程序商城,微信小程序微店 【毕业设计参考项目】

热门文章

最新文章