当前位置: 首页 > news >正文

南宁网站建设接单网站代码优化有哪些

南宁网站建设接单,网站代码优化有哪些,长沙做旅游网站公司,手机优化大师哪个好其他方案>引入QQ邮箱发送验证码进行安全校验 相对短信验证码,操作更简单而且免费 最近想给自己的项目在注册时加点安全校验,准备使用免费的邮箱验证来着,在上一篇引入QQ邮箱进行安全校验时,看有朋友说阿里云会送一些短信服务免…

其他方案=>引入QQ邮箱发送验证码进行安全校验
相对短信验证码,操作更简单而且免费

最近想给自己的项目在注册时加点安全校验,准备使用免费的邮箱验证来着,在上一篇引入QQ邮箱进行安全校验时,看有朋友说阿里云会送一些短信服务免费额度,于是去官网一看,果然送了100条额度,因此在此写一篇使用流程与邮箱验证作为不同解决方案。

一.需求分析

  • 场景:用户输入自己的邮箱,点击获取验证码,后台会发送一封邮件到对应邮箱中。

  • 分析:防止刷爆邮箱,可以限制一分钟内只能获取一次。

    • 前端:期限内禁用button按钮。
    • 后端:存入redis设置过期时间,请求先判断redis中是否有数据。

二.服务介绍

  • 目前市面上有很多第三方提供的短信服务,这些第三方短信服务会和各个运营商(移动,联通,电信)对接,我们只需要购买服务后按照其提供的开发文档进行调用就可以发送短信了。常用的短信服务:
    • 阿里云
    • 腾讯云
    • 华为云

由于白嫖的是阿里云的免费额度,此文介绍如何引入阿里云短信服务~

三.服务配置

首先要到官方对服务进行相关的配置

  1. 进入阿里云官网并登录,顶部搜索短信服务
    在这里插入图片描述

  2. 进入短信服务控制台
    在这里插入图片描述

  3. 选择国内消息菜单,首先添加短信签名,用于标识短信发送者的身份
    在这里插入图片描述

  4. 其次申请短信模板,用于定义发送短信的内容格式。
    在这里插入图片描述

  5. 鼠标移动到右上角用户头像上,在弹出的窗口中点击[AccessKey管理],类似于用户名密码,提供于程序中访问阿里云鉴权
    在这里插入图片描述

  6. 进入后,可以选择使用子用户,权限更小,不小心泄露AccessKey导致的危害比较小,但操作相对繁琐
    在这里插入图片描述

  7. 首先需要创建一个用户,可以其中控制只允许OpenAPI调用访问
    在这里插入图片描述

  8. 创建好后会生成一对AccessKey,需要妥善保管,防止泄露
    在这里插入图片描述

  9. 点击创建好的用户,给其授予相应的短信服务权限。
    在这里插入图片描述

至此完成了短信服务的相关配置,接下来一起看看如何在项目中使用吧~

四.后端开发

官方提供非常详细的使用流程,可以选择自己查看帮助文档学习使用.

  • 具体开发步骤:
    • 导入maven坐标
    • 调用API

(1) 环境搭建

  1. 在maven中导入如下坐标
        <!--短信验证码所需jar包--><dependency><groupId>com.aliyun</groupId><artifactId>aliyun-java-sdk-core</artifactId><version>4.5.16</version></dependency><dependency><groupId>com.aliyun</groupId><artifactId>aliyun-java-sdk-dysmsapi</artifactId><version>2.1.0</version></dependency>
  1. 由于我们需要使用redis缓存验证码因此还要导入redis的jar包
   <!--     使用redis缓存验证码时效--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></dependency>
  1. 在yml文件中配置redis,设置了redis密码记得加上密码配置
spring:redis:# redis数据库索引(默认为0),我们使用索引为3的数据库,避免和其他数据库冲突database: 3# redis服务器地址(默认为localhost)host: localhost# redis端口(默认为6379)port: 6379

(2) 代码开发

复制官方提供的测试案例,填充入在服务配置中获取的相应的参数即可。
在这里插入图片描述

可在自己项目中根据自己的需求将官方案例封装为工具类调用

package com.example.utils;import com.aliyuncs.DefaultAcsClient;
import com.aliyuncs.IAcsClient;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
import com.aliyuncs.exceptions.ClientException;
import com.aliyuncs.exceptions.ServerException;
import com.aliyuncs.profile.DefaultProfile;/*** 短信发送工具类*/
public class SMSUtils {// 签名private final static String SIGN_NAME = "XXXX";// 模板private final static String TEMPLATE_CODE = "XXXX";/*** 发送短信** @param phoneNumbers 收信人手机号* @param param        发送的验证码*/public static void sendMessage(String phoneNumbers, String param) {// 配置的accessKeyId和secretDefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", "xxxx", "xxxxxx");IAcsClient client = new DefaultAcsClient(profile);SendSmsRequest request = new SendSmsRequest();request.setSysRegionId("cn-hangzhou");// 收信人手机号request.setPhoneNumbers(phoneNumbers);// 申请的签名request.setSignName(SIGN_NAME);// 申请的模板request.setTemplateCode(TEMPLATE_CODE);// 替换模板中的参数,必须为Json格式request.setTemplateParam("{\"code\":\"" + param + "\"}");try {// 获取发送结果SendSmsResponse response = client.getAcsResponse(request);System.out.println(response);} catch (ServerException e) {e.printStackTrace();} catch (ClientException e) {// 打印处理结果System.out.println("ErrCode:" + e.getErrCode());System.out.println("ErrMsg:" + e.getErrMsg());System.out.println("RequestId:" + e.getRequestId());}}}

编写短信服务接口:

package com.example.controller;@RestController
@CrossOrigin("http://localhost:63342")
public class SendCode {/*** @param targetPhone 用户手机号* @return*/@GetMapping("/getCode")@ResponseBodypublic String phone(@RequestParam("targetPhone") String targetPhone) {//生成六位数验证码int authNum = new Random().nextInt(899999) + 100000;String authCode = String.valueOf(authNum);SMSUtils.sendMessage(targetPhone,authCode);return "发送成功";}
}

启动服务测试接口

GET http://localhost:8080/getCode?targetPhone=158xx889

查看手机我们可以看到成功接收到了验证码
在这里插入图片描述

至此我们已经成功实现了调用阿里云短信服务发送验证码的功能

(3) 缓存改进

如果仅仅是上述那样,当碰到恶意用户时,我们的财产将面临非常危险的处境,因此可以引入缓存来简单改进代码

package com.example.controller;import com.example.utils.SMSUtils;
import com.example.utils.SendMailUtil;
import org.springframework.data.redis.core.RedisTemplate;
import org.springframework.web.bind.annotation.*;import javax.annotation.Resource;
import java.util.Random;
import java.util.concurrent.TimeUnit;@RestController
@CrossOrigin("http://localhost:63342")
public class SendCode {@Resourceprivate RedisTemplate<String, String> redisTemplate = new RedisTemplate<>();/*** @param targetPhone 用户手机号* @return*/@GetMapping("/getCode")@ResponseBodypublic String phone(@RequestParam("targetPhone") String targetPhone) {// 发送前先看下我们是否已经缓存了验证码String yzm = redisTemplate.opsForValue().get("yzm");// 判断是否存在if (yzm == null){// 生成六位数验证码int authNum = new Random().nextInt(899999) + 100000;String authCode = String.valueOf(authNum);// 不存在,我们发送验证码给用户SMSUtils.sendMessage(targetPhone,authCode);// 存入redis中,设置有效期为1分钟redisTemplate.opsForValue().set("yzm", authCode, 1, TimeUnit.MINUTES);return "发送成功";}// 存在,直接返回,不再发送验证码~return "请勿重复发送验证码";}
}

重新多次测试接口查看效果,可发现短时间内只能获取一次:
在这里插入图片描述

如此我们便简单的完善了获取验证码功能。

五.前端(补充)

用原生js简单写了一个界面,感兴趣的可以看一看
在这里插入图片描述

代码如下:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<div><input id="phoneNum" type="text"><button id="getCode">获取验证码</button>
</div>
<script>/*按钮禁用60秒,并显示倒计时*/function disabledButton() {const getCode = document.querySelector("#getCode")getCode.disabled = truelet second = 60;const intervalObj = setInterval(function () {getCode.innerText = "请" + second + "秒后再重试"if (second === 0) {getCode.innerText = "获取验证码"getCode.disabled = falseclearInterval(intervalObj);}second--;}, 1000);}document.querySelector("#getCode").addEventListener('click', function () {const phoneNum = document.querySelector("#phoneNum")let xhr = new XMLHttpRequest();xhr.open("GET", "http://localhost:8080/getCode?targetPhone=" + phoneNum.value, true);xhr.send();xhr.onreadystatechange = function () {if (xhr.readyState === 4) {alert(xhr.response);disabledButton()}}})</script>
</body>
</html>
http://www.yayakq.cn/news/746839/

相关文章:

  • 站长工具app齐河县城乡建设局官方网站
  • 网站网页主页的区别app开发编程
  • 网站关键词选择wordpress seo蜘蛛访问统计插件
  • 百度一下建设银行网站首页昆明公司网站开发
  • 企业网站开发有哪些网络公司名字大全
  • 做外贸到什么网站上发布比较好高校网站建设及管理制度
  • 建设银行业务管理中心网站有哪些网站建设公司上线
  • 北京建设商业网站中小网站 广告费
  • 天津+交友+网站建设虚拟机安装wordpress
  • 网站建设与网页制作案例用phpmysql做图书网站
  • 大浪做网站公司安徽工程建设信息网站
  • 自助网站建设软件wordpress 插件 重命名
  • 宜黄建设局网站台州网络推广
  • 新浪虚拟主机做网站天津seo渠道代理
  • 设计网站模板论坛推广软件
  • 专业定制网站设计织梦网站备份几种方法
  • 无锡网站建设系统wordpress弹出搜索结果
  • 把自己做的网站上传到服务器电商网站目录优化
  • 利为汇网站建设哈尔滨网站建设网站
  • 网站学习流程地方网站盈利模式
  • 做网站的工作是什么河北建设厅网站修改密码在哪
  • 建设银行网站用户注册不了暴雪倒闭
  • 河源市住房和城乡建设局网站制作app的公司是什么公司
  • 整站优化seo公司哪家好动画设计师工作内容
  • 科技网站建设方案广州专业找人见人付款
  • 做微信首图的网站软件工程师培训学校
  • 石家庄大型网站建站泰安如何开发商城app开发
  • 泉州手机网站建设费用辽阳企业网站建设价格
  • 怎么做系统软件网站咸阳个人兼职网站建设
  • 智能网站建设步骤兰州网络seo