日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

腾讯云短信服务介绍

發布時間:2023/12/1 综合教程 31 生活家
生活随笔 收集整理的這篇文章主要介紹了 腾讯云短信服务介绍 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

下面主要介紹,在項目開發中需要集成短信服務,處理相關業務(此處本人使用的是騰訊云短信服務)

騰訊云短信服務步驟

登錄騰訊云

  1. 注冊騰訊云
  2. 個人實名認證
  3. 進入到控制臺, 在云產品中找到短信


默認是沒有開通的,閱讀服務協議后,點擊開始接入

目前來說,只要實名認證過的,直接就可以開通短信服務

這個時候,就可以查看短信控制面板了

測試短信發送


快速開始



現在創建簽名申請,網站的話,需要備案比較麻煩,可以用自己的微信去注冊一個公眾號,我這邊目前已經有公眾號,所以使用公眾號就可以使用短信服務(此處如何注冊公眾號,可以自行查閱資料)
下圖為網圖

創建短信模板

此處申請說明,請按實際的目的寫,請勿編造(這樣通過率高)


接下來耐心等待

初次使用,會有100條免費短信使用,這要比其他云廠商人性化

審核成功后就可以發送了

測試手動發送短信




excel格式為下圖所示

點擊發送

集成代碼進行短信發送

創建秘鑰



在pom.xml中引入騰訊云相關依賴

在相關工程下面的pom文件中加入騰訊云短信的依賴(如果不是maven的工程,就需要下載對應的jar包)具體可查看官方文檔 騰訊云短信 Java SDK

<dependency><groupId>com.tencentcloudapi</groupId><artifactId>tencentcloud-sdk-java</artifactId><version>3.1.270</version><!-- 注:這里只是示例版本號(可直接使用),可獲取并替換為 最新的版本號,注意不要使用4.0.x版本(非最新版本) -->
</dependency>

編寫配置文件

注:因為此處整合了redis設置驗證碼過期時間,所以此處需要添加redis配置

# 服務端口
server.port=8204
# 服務名
spring.application.name=service-msm#返回json的全局時間格式
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss
spring.jackson.time-zone=GMT+8#redis配置
spring.redis.host=
spring.redis.port=
spring.redis.database= 1
spring.redis.timeout=1800000
spring.redis.lettuce.pool.max-active=20
spring.redis.lettuce.pool.max-wait=-1
#最大阻塞等待時間(負數表示沒限制)
spring.redis.lettuce.pool.max-idle=5
spring.redis.lettuce.pool.min-idle=0

創建controller

	@Autowiredprivate MsmService msmService;@Autowiredprivate RedisTemplate<String, String> redisTemplate;@GetMapping("/send/{phone}")@ApiOperation(value = "發送手機驗證碼")public Result sendCode(@PathVariable String phone) {//從redis獲取驗證碼,如果獲取獲取到,返回ok// key 手機號  value 驗證碼String code = redisTemplate.opsForValue().get(phone);if (!StringUtils.isEmpty(code)) {return Result.success(code);}//如果從redis獲取不到//生成驗證碼code = RandomUtils.getSixBitRandom();//整合騰訊云短信服務進行發送boolean flag = msmService.send(phone, code);if (flag) {//生成驗證碼放到redis里面,設置有效時間redisTemplate.opsForValue().set(phone, code, 5, TimeUnit.MINUTES);return Result.success();}return Result.fail().message("發送短信失敗");}

生成驗證碼的工具類

/*** 生成驗證碼的工具類* <p>* 創建時間: 2022-03-20 22:21** @author fuxshen* @version v1.0.0* @since v1.0.0*/
public class RandomUtils {private static final Random random = new Random();private static final DecimalFormat fourdf = new DecimalFormat("0000");private static final DecimalFormat sixdf = new DecimalFormat("000000");/*** 生成四位驗證碼** @return java.lang.String* @Description* @author fuxshen* @date 2022-03-20 22:23:22**/public static String getFourBitRandom() {return fourdf.format(random.nextInt(10000));}/*** 生成六位驗證碼** @return java.lang.String* @Description* @author fuxshen* @date 2022-03-20 22:23:37**/public static String getSixBitRandom() {return sixdf.format(random.nextInt(1000000));}/*** 給定數組,抽取n個數據** @param list* @param n* @return*/public static ArrayList getRandom(List list, int n) {Random random = new Random();HashMap<Object, Object> hashMap = new HashMap<Object, Object>();// 生成隨機數字并存入HashMapfor (int i = 0; i < list.size(); i++) {int number = random.nextInt(100) + 1;hashMap.put(number, i);}// 從HashMap導入數組Object[] robjs = hashMap.values().toArray();ArrayList r = new ArrayList();// 遍歷數組并打印數據for (int i = 0; i < n; i++) {r.add(list.get((int) robjs[i]));System.out.print(list.get((int) robjs[i]) + "\t");}System.out.print("\n");return r;}
}

創建service

import com.tencentcloudapi.common.Credential;
import com.tencentcloudapi.common.exception.TencentCloudSDKException;
//導入可選配置類
import com.tencentcloudapi.common.profile.ClientProfile;
import com.tencentcloudapi.common.profile.HttpProfile;
// 導入 SMS 模塊的 client
import com.tencentcloudapi.sms.v20190711.SmsClient;
// 導入要請求接口對應的 request response 類
import com.tencentcloudapi.sms.v20190711.models.SendSmsRequest;
import com.tencentcloudapi.sms.v20190711.models.SendSmsResponse;
import org.springframework.stereotype.Service;
import org.springframework.util.StringUtils;/*** 短信相關接口實現類* <p>* 創建時間: 2022-03-20 21:46** @author fuxshen* @version v1.0.0* @since v1.0.0*/
@Service
public class MsmServiceImpl implements MsmService {@Overridepublic boolean send(String phone, String code) {//判斷手機是否為nullif (StringUtils.isEmpty(phone)){return false;}try {/* 必要步驟:* 實例化一個認證對象,入參需要傳入騰訊云賬戶密鑰對 secretId 和 secretKey* 本示例采用從環境變量讀取的方式,需要預先在環境變量中設置這兩個值* 您也可以直接在代碼中寫入密鑰對,但需謹防泄露,不要將代碼復制、上傳或者分享給他人* CAM 密鑰查詢:https://console.cloud.tencent.com/cam/capi*/Credential cred = new Credential("secretId", "secretKey");/* 實例化 SMS 的 client 對象* 第二個參數是地域信息,可以直接填寫字符串 ap-guangzhou,或者引用預設的常量 */SmsClient client = new SmsClient(cred, "ap-guangzhou");/* 實例化一個請求對象,根據調用的接口和實際情況,可以進一步設置請求參數* 您可以直接查詢 SDK 源碼確定接口有哪些屬性可以設置* 屬性可能是基本類型,也可能引用了另一個數據結構* 推薦使用 IDE 進行開發,可以方便地跳轉查閱各個接口和數據結構的文檔說明 */SendSmsRequest req = new SendSmsRequest();/* 填充請求參數,這里 request 對象的成員變量即對應接口的入參* 您可以通過官網接口文檔或跳轉到 request 對象的定義處查看請求參數的定義* 基本類型的設置:* 幫助鏈接:* 短信控制臺:https://console.cloud.tencent.com/smsv2* sms helper:https://cloud.tencent.com/document/product/382/3773 *//* 短信應用 ID: 在 [短信控制臺] 添加應用后生成的實際 SDKAppID,例如1400006666 */String appid = "1400006666 ";req.setSmsSdkAppid(appid);/* 短信簽名內容: 使用 UTF-8 編碼,必須填寫已審核通過的簽名,可登錄 [短信控制臺] 查看簽名信息 */String sign = "簽名內容";req.setSign(sign);/* 模板 ID: 必須填寫已審核通過的模板 ID,可登錄 [短信控制臺] 查看模板 ID */String templateID = "13406824";req.setTemplateID(templateID);/* 下發手機號碼,采用 e.164 標準,+[國家或地區碼][手機號]* 例如+8613711112222, 其中前面有一個+號 ,86為國家碼,13711112222為手機號,最多不要超過200個手機號*/String[] phoneNumbers = {"+86"+phone};req.setPhoneNumberSet(phoneNumbers);/* 模板參數: 若無模板參數,則設置為空模版參數,從前往后對應的是模版的{1}、{2},可以傳多個用逗號隔開*/String[] templateParams = {code};req.setTemplateParamSet(templateParams);/* 通過 client 對象調用 SendSms 方法發起請求。注意請求方法名與請求對象是對應的* 返回的 res 是一個 SendSmsResponse 類的實例,與請求對象對應 */SendSmsResponse res = client.SendSms(req);// 輸出 JSON 格式的字符串回包System.out.println(SendSmsResponse.toJsonString(res));// 可以取出單個值,您可以通過官網接口文檔或跳轉到 response 對象的定義處查看返回字段的定義System.out.println(res.getRequestId());return true;} catch (TencentCloudSDKException e) {e.printStackTrace();}return false;}
}


總結

以上是生活随笔為你收集整理的腾讯云短信服务介绍的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。