- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) >
- SpringBoot使用榛子云實(shí)現手機短信發(fā)送驗證碼
首先去榛子云官方平臺申請注冊自己的賬號,官方網(wǎng)站:
有賬號的話(huà)就直接登錄,沒(méi)有注冊一個(gè)即可,很簡(jiǎn)單的注冊
登錄成功后就是這個(gè)樣子,官方提供免費發(fā)送一條,但是我反復測試一些功能效果顯然1條是不夠的,我沖了20,為了開(kāi)發(fā)我沖了?。?!憑這20元,我要20個(gè)贊不過(guò)分吧QAQ, 充值最低的話(huà)是20元,支持微信支付寶支付,一條短信也就3分錢(qián)左右,可以給朋友裝b用什么的,接下來(lái)進(jìn)入正題 在"應用管理"——>"我的應用"里,AppId,AppSecret,這都是用戶(hù)的唯一標識,很重要,一會(huì )在Java代碼中要用到
在"短信管理"——>"短信模板"中可以看到自己要發(fā)送的短信模板,會(huì )有自己默認的模板,當然也可以自己新建自定義模板,不要違規就好,這邊需要注意的是審核狀態(tài),審核通過(guò)后可以發(fā)送短信,我遇到好幾次出錯都是因為我新建的模板還沒(méi)審核通過(guò)就發(fā)送,所以一直失敗,這也是我后面想到的
做到這里,以及可以實(shí)現簡(jiǎn)單的借助第三方發(fā)送短信啦,但是逼格肯定不夠,進(jìn)別人的網(wǎng)址操作肯定不是我們的最終目標,我們接下來(lái)把它搬到自己的項目代碼中進(jìn)行實(shí)現,這邊我以SpringBoot為例
話(huà)不多說(shuō)直接上代碼
1.pom添加依賴(lài)
<!--轉換json數據--> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.58</version> </dependency> <!--榛子云提供短信接口平臺--> <dependency> <groupId>com.zhenzikj</groupId> <artifactId>zhenzisms</artifactId> <version>2.0.2</version> </dependency>
2.創(chuàng )建controller方法寫(xiě)發(fā)送方法
package com.wyh.controller; import com.alibaba.fastjson.JSONObject; import com.zhenzi.sms.ZhenziSmsClient; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.*; import javax.servlet.http.HttpSession; import java.util.HashMap; import java.util.Map; import java.util.Random; /** * @program: SpringBoot_01 * @description: 短信發(fā)送 * @author: wyh * @createDate: 2021-04-27 22:24 **/ @Controller public class SendCodeController { //短信平臺相關(guān)參數 //這個(gè)不用改 private String apiUrl = "https://sms_developer.zhenzikj.com"; //榛子云系統上獲取 private String appId = "108850"; private String appSecret = "NzhmN2JhNGQtNmRmOC00MWIwLTk1OGEtOTEyYzFiYjFlY2Vk"; @ResponseBody @RequestMapping("/sendCode") public boolean getCode(String memPhone, HttpSession httpSession){ try { JSONObject json = null; //隨機生成驗證碼 String code = String.valueOf(new Random().nextInt(999999)); //將驗證碼通過(guò)榛子云接口發(fā)送至手機 ZhenziSmsClient client = new ZhenziSmsClient(apiUrl, appId, appSecret); Map<String, Object> params = new HashMap<String, Object>(); //前臺輸入的手機號 params.put("number", memPhone); //這個(gè)模板id對應的是榛子云個(gè)人中心的模板id params.put("templateId", 5032); String[] templateParams = new String[2]; templateParams[0] = code; templateParams[1] = "5分鐘"; params.put("templateParams", templateParams); String result = client.send(params); System.out.println(result); json = JSONObject.parseObject(result); if (json.getIntValue("code")!=0){//發(fā)送短信失敗 return false; } //將驗證碼存到session中,同時(shí)存入創(chuàng )建時(shí)間 //以json存放,這里使用的是阿里的fastjson json = new JSONObject(); json.put("memPhone",memPhone); json.put("code",code); json.put("createTime",System.currentTimeMillis()); // 將認證碼存入SESSION httpSession.setAttribute("code",json); return true; } catch (Exception e) { e.printStackTrace(); return false; } } /** /* @Author wyh * @Description 跳轉發(fā)送短信頁(yè)面 * @Date 21:01 2021/5/7 * @Param [] * @return java.lang.String **/ @RequestMapping("/goSendCode") public String goSendCode(){ return "/sendCode"; } }
3.新建短信發(fā)送jsp頁(yè)面(ui我選用的是layui,前面文章有說(shuō)關(guān)于springboot引入layui等相關(guān)js)
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <%-- Created by IntelliJ IDEA. User: wyh Date: 2021/4/20 Time: 21:45 短信發(fā)送 --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>短信發(fā)送</title> <!--引入layui的css--> <link rel="stylesheet" href="../layui/css/layui.css" rel="external nofollow" > <!--引入layui的js--> <script type="text/javascript" src="../layui/layui.js"></script> <!--引入jquery的js --> <script type="text/javascript" src="../jquery/jquery.js"></script> </head> <body> <center> <div id="model2" > <div class="layui-form-item input-item"> <input type="text" placeholder="請輸入手機號" autocomplete="off" id="memPhone" name="memPhone" class="layui-input" style="width: 10%;"> </div> <div class="layui-form-item input-item"> <input type="text" placeholder="請輸入驗證碼" autocomplete="off" id="code" name="code" maxlength="6" class="layui-input" style="width: 10%;"> <input type="button" class="layui-btn layui-btn-primary" value="獲取驗證碼" id="sendBtn" style="width:10%;border-color:#1e9fff !important;" onclick="sendCode()" ></input> </div> </div> </center> </body> <script> function sendCode(){ var memPhone = $("#memPhone").val(); if(memPhone == '' || memPhone.length != 11){ layer.msg("請輸入正確的手機號!"); return; }else{ $.ajax({ type: 'get', url: '/sendCode', data: { memPhone : memPhone, }, dataType: 'json', success: function(data) { if(data){ timer(); }else{ layer.msg("獲取驗證碼失敗"); } }, error: function(data) { layer.msg('連接超時(shí)!'); }, }); } } var wait = 60; //倒計時(shí) function timer() { if(wait == 0){ $("#sendBtn").val("獲取驗證碼"); $("#sendBtn").removeAttr("disabled"); $("#sendBtn").css("border-color","1e9fff").css("background", "#ffffff").css("cursor", "pointer"); wait = 60; }else{ $("#sendBtn").attr("disabled","true"); $("#sendBtn").css("border-color","fbfbfb").css("background", "#ccc").css("cursor", "not-allowed"); $("#sendBtn").val(wait + "秒后重發(fā)"); wait--; setTimeout(function() {timer()}, 1000); } } </script> </html>
一個(gè)簡(jiǎn)單的頁(yè)面樣式如下
輸入正確的手機號進(jìn)行測試
收到短信如下
這樣一個(gè)簡(jiǎn)單的自己代碼實(shí)現短信發(fā)送就完成啦,以下為官方的一些參數類(lèi)型以及說(shuō)明
到此這篇關(guān)于SpringBoot使用榛子云實(shí)現手機短信發(fā)送驗證碼的文章就介紹到這了,更多相關(guān)SpringBoot短信發(fā)送驗證碼內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站