springboot短信验证码登录功能的实现

 更新时间:2021年2月4日 15:00  点击:2055

1 、构造手机验证码:使用 random 对象生成要求的随机数作为验证码,例如 4 位验证码: 1000~9999 之间随机数;

2 、使用接口向短信平台发送手机号和验证码数据,然后短信平台再把验证码发送到制定手机号上,接口参数一般包括:目标手机号,随机验证码 (或包含失效时间),平台接口地址,平台口令;

3 、保存接口返回的信息(一般为 json 文本数据,然后需转换为 json 对象格式);

4 、将手机号 — 验证码、操作时间存入 Session 中,作为后面验证使用;

5 、接收用户填写的验证码及其他数据;

6 、对比提交的验证码与 Session 中的验证码是否一致,同时判断提交动作是否在有效期内;

7 、验证码正确且在有效期内,请求通过,处理相应的业务。

一,首先添加一个 jar 包,工具类会用到。

<!--秒滴云的jar包-->
<dependency>
 <groupId>commons-codec</groupId>
 <artifactId>commons-codec</artifactId>
 <version>1.11</version>
</dependency>

二、我这里只是编写一个简单的短信验证功能,要是用其他的语音验证。

等等需要去秒滴云官方下载文档,下面是编写的一个 config 文档,专门存放一些参数

三、编写 http 请求工具类

public class HttpUtil
{
 /**
 * 构造通用参数timestamp、sig和respDataType
 *
 * @return
 */
 public static String createCommonParam()
 {
  // 时间戳
  SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
  String timestamp = sdf.format(new Date());


  // 签名
  String sig = DigestUtils.md5Hex(Config.ACCOUNT_SID + Config.AUTH_TOKEN + timestamp);


  return "×tamp=" + timestamp + "&sig=" + sig + "&respDataType=" + Config.RESP_DATA_TYPE;
 }


 /**
 * post请求
 *
 * @param url
 * 功能和操作
 * @param body
 * 要post的数据
 * @return
 * @throws IOException
 */
 public static String post(String url, String body)
 {
  System.out.println("url:" + System.lineSeparator() + url);
  System.out.println("body:" + System.lineSeparator() + body);


  String result = "";
  try
  {
   OutputStreamWriter out = null;
   BufferedReader in = null;
   URL realUrl = new URL(url);
   URLConnection conn = realUrl.openConnection();


   // 设置连接参数
   conn.setDoOutput(true);
   conn.setDoInput(true);
   conn.setConnectTimeout(5000);
   conn.setReadTimeout(20000);
   conn.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
   // 提交数据
   out = new OutputStreamWriter(conn.getOutputStream(), "UTF-8");
   out.write(body);
   out.flush();


   // 读取返回数据
   in = new BufferedReader(new InputStreamReader(conn.getInputStream(), "UTF-8"));
   String line = "";
   boolean firstLine = true; // 读第一行不加换行符
   while ((line = in.readLine()) != null)
   {
   if (firstLine)
   {
    firstLine = false;
   } else
   {
    result += System.lineSeparator();
   }
   result += line;
   }
  } catch (Exception e)
  {
   e.printStackTrace();
  }
  return result;
 }


 /**
 * 回调测试工具方法
 *
 * @param url
 * @param reqStr
 * @return
 */
 public static String postHuiDiao(String url, String body)
 {
  String result = "";
  try
  {
   OutputStreamWriter out = null;
   BufferedReader in = null;
   URL realUrl = new URL(url);
   URLConnection conn = realUrl.openConnection();


   // 设置连接参数
   conn.setDoOutput(true);
   conn.setDoInput(true);
   conn.setConnectTimeout(5000);
   conn.setReadTimeout(20000);


   // 提交数据
   out = new OutputStreamWriter(conn.getOutputStream(), "UTF-8");
   out.write(body);
   out.flush();


   // 读取返回数据
   in = new BufferedReader(new InputStreamReader(conn.getInputStream(), "UTF-8"));
   String line = "";
   boolean firstLine = true; // 读第一行不加换行符
   while ((line = in.readLine()) != null)
   {
   if (firstLine)
   {
    firstLine = false;
   } else
   {
    result += System.lineSeparator();
   }
   result += line;
   }
  } catch (Exception e)
  {
   e.printStackTrace();
  }
  return result;
 }
}

四、生成四位数的方法

public static String runNumber() {
 String str="ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
 StringBuilder sb=new StringBuilder(4);
 for(int i=0;i<4;i++)
 {
  char ch=str.charAt(new Random().nextInt(str.length()));
  sb.append(ch);
 }
 System.out.println(sb.toString());
 String code = sb.toString();
 return code;
}

执行方法 execute(),便会发送成功

public class IndustrySMS
{
 private static String operation = "/industrySMS/sendSMS";


 private static String accountSid = Config.ACCOUNT_SID;
 private static String to = "15342349382";
 private static String smsContent = "【小陶科技】登录验证码:{"+runNumber().toString()+"},如非本人操作,请忽略此短信。";


 /**
 * 验证码通知短信
 */
 public static void execute()
 {
  String tmpSmsContent = null;
  try{
   tmpSmsContent = URLEncoder.encode(smsContent, "UTF-8");
  }catch(Exception e){
  }
  String url = Config.BASE_URL + operation;
  String body = "accountSid=" + accountSid + "&to=" + to + "&smsContent=" + tmpSmsContent
   + HttpUtil.createCommonParam();


  // 提交请求
  String result = HttpUtil.post(url, body);
  System.out.println("result:" + System.lineSeparator() + result);
}

到此这篇关于springboot短信验证码登录功能的实现的文章就介绍到这了,更多相关springboot短信验证码登录内容请搜索猪先飞以前的文章或继续浏览下面的相关文章希望大家以后多多支持猪先飞!

[!--infotagslink--]

相关文章

  • 解决springboot使用logback日志出现LOG_PATH_IS_UNDEFINED文件夹的问题

    这篇文章主要介绍了解决springboot使用logback日志出现LOG_PATH_IS_UNDEFINED文件夹的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-04-28
  • php中登录后跳转回原来要访问的页面实例

    在很多网站用户先访问一个要登录的页面,但当时没有登录后来登录了,等待用户登录成功之后肯定希望返回到上次访问的页面,下面我就来给大家介绍登录后跳转回原来要访问的页...2016-11-25
  • SpringBoot实现excel文件生成和下载

    这篇文章主要为大家详细介绍了SpringBoot实现excel文件生成和下载,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-02-09
  • php中用curl模拟登录discuz以及模拟发帖

    本文章完美的利用了php的curl功能实现模拟登录discuz以及模拟发帖,本教程供参考学习哦。 代码如下 复制代码 <?php $discuz_url = &lsquo;ht...2016-11-25
  • PHP 验证码不显示只有一个小红叉的解决方法

    最近想自学PHP ,做了个验证码,但不知道怎么搞的,总出现一个如下图的小红叉,但验证码就是显示不出来,原因如下 未修改之前,出现如下错误; (1)修改步骤如下,原因如下,原因是apache权限没开, (2)点击打开php.int., 搜索extension=ph...2013-10-04
  • 详解springBoot启动时找不到或无法加载主类解决办法

    这篇文章主要介绍了详解springBoot启动时找不到或无法加载主类解决办法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2020-09-16
  • jQuery Real Person验证码插件防止表单自动提交

    本文介绍的jQuery插件有点特殊,防自动提交表单的验证工具,就是我们经常用到的验证码工具,先给大家看看效果。效果图如下: 使用说明 需要使用jQuery库文件和Real Person库文件 同时需要自定义验证码显示的CSS样式 使用实例...2015-11-08
  • SpringBoot集成Redis实现消息队列的方法

    这篇文章主要介绍了SpringBoot集成Redis实现消息队列的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧...2021-02-10
  • JS实现随机生成验证码

    这篇文章主要为大家详细介绍了JS实现随机生成验证码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-09-06
  • 解决Springboot get请求是参数过长的情况

    这篇文章主要介绍了解决Springboot get请求是参数过长的情况,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...2020-09-17
  • Ruby on Rails实现最基本的用户注册和登录功能的教程

    这里我们主要以has_secure_password的用户密码验证功能为中心,来讲解Ruby on Rails实现最基本的用户注册和登录功能的教程,需要的朋友可以参考下...2020-06-30
  • PHP中SSO Cookie登录分析和实现

    什么是SSO?单点登录SSO(Single Sign-On)是身份管理中的一部分。SSO的一种较为通俗的定义是:SSO是指访问同一服务器不同应用中的受保护资源的同一用户,只需要登录一次,即通过一个应用中的安全验证后,再访问其他应用中的受保护...2015-11-08
  • Spring Boot项目@RestController使用重定向redirect方式

    这篇文章主要介绍了Spring Boot项目@RestController使用重定向redirect方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-02
  • Springboot+TCP监听服务器搭建过程图解

    这篇文章主要介绍了Springboot+TCP监听服务器搭建过程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下...2020-10-28
  • php有效防止同一用户多次登录

    【问题描述】:同一用户在同一时间多次登录如果不能检测出来,是危险的。因为,你无法知道是否有其他用户在登录你的账户。如何禁止同一用户多次登录呢? 【解决方案】 (1) 每次登录,身份认证成功后,重新产生一个session_id。 s...2015-11-24
  • springBoot 项目排除数据库启动方式

    这篇文章主要介绍了springBoot 项目排除数据库启动方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教...2021-09-10
  • PHP中SSO Cookie登录分析和实现

    什么是SSO?单点登录SSO(Single Sign-On)是身份管理中的一部分。SSO的一种较为通俗的定义是:SSO是指访问同一服务器不同应用中的受保护资源的同一用户,只需要登录一次,即通过一个应用中的安全验证后,再访问其他应用中的受保护...2015-11-08
  • vue实现用户登录切换

    这篇文章主要为大家详细介绍了vue实现用户登录切换,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...2021-04-22
  • Jquery插件实现点击获取验证码后60秒内禁止重新获取

    通过jquery.cookie.js插件可以快速实现“点击获取验证码后60秒内禁止重新获取(防刷新)”的功能效果图:先到官网(http://plugins.jquery.com/cookie/)下载cookie插件,放到相应文件夹,代码如下:复制代码 代码如下: <!DOCTYPE ht...2015-03-15
  • php实现点击可刷新验证码

    验证码类文件 CreateImg.class.php <&#63;php class ValidationCode { private $width,$height,$codenum; public $checkcode; //产生的验证码 private $checkimage; //验证码图片 private $disturbColor = ''; /...2015-11-08