From 279d3bbbe15d4839cba8dfb48053c75b504aacc3 Mon Sep 17 00:00:00 2001
From: Pu Zhibing <393733352@qq.com>
Date: 星期二, 22 四月 2025 10:55:25 +0800
Subject: [PATCH] 修改缓存连接方式

---
 ManagementZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/HuaWeiSMSUtil.java |  342 ++++++++++++++++++++++++++++----------------------------
 1 files changed, 171 insertions(+), 171 deletions(-)

diff --git a/ManagementZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/HuaWeiSMSUtil.java b/ManagementZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/HuaWeiSMSUtil.java
index daf0a94..c800b1e 100644
--- a/ManagementZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/HuaWeiSMSUtil.java
+++ b/ManagementZYTravel/guns-admin/src/main/java/com/stylefeng/guns/modular/system/util/HuaWeiSMSUtil.java
@@ -1,171 +1,171 @@
-package com.stylefeng.guns.modular.system.util;
-
-import org.apache.commons.codec.binary.Hex;
-import org.apache.commons.codec.digest.DigestUtils;
-import org.apache.http.HttpHeaders;
-import org.apache.http.HttpResponse;
-import org.apache.http.NameValuePair;
-import org.apache.http.client.methods.RequestBuilder;
-import org.apache.http.client.utils.URLEncodedUtils;
-import org.apache.http.conn.ssl.NoopHostnameVerifier;
-import org.apache.http.entity.StringEntity;
-import org.apache.http.impl.client.CloseableHttpClient;
-import org.apache.http.impl.client.HttpClients;
-import org.apache.http.message.BasicNameValuePair;
-import org.apache.http.ssl.SSLContextBuilder;
-import org.apache.http.util.EntityUtils;
-
-import java.nio.charset.Charset;
-import java.text.SimpleDateFormat;
-import java.util.*;
-
-//如果JDK版本是1.8,可使用原生Base64类
-
-public class HuaWeiSMSUtil {
-
-    //无需修改,用于格式化鉴权头域,给"X-WSSE"参数赋值
-    private static final String WSSE_HEADER_FORMAT = "UsernameToken Username=\"%s\",PasswordDigest=\"%s\",Nonce=\"%s\",Created=\"%s\"";
-    //无需修改,用于格式化鉴权头域,给"Authorization"参数赋值
-    private static final String AUTH_HEADER_VALUE = "WSSE realm=\"SDP\",profile=\"UsernameToken\",type=\"Appkey\"";
-
-    public static void main(String[] args) throws Exception{
-
-//        sendSms("[\""+1235+"\"]","17623778642","10690400999303617","d8f8f781b6e04c848f8148f4d6604bcd");
-//        sendSms("[\"17623778642\",\"蓉A-7823\"]","17623778642","8819122535459","6c848255000c4619833ab690e393f906");
-        sendSms("[\"17623778642\",\"蓉A-7823\",\"2019/12/27\",\"14:00\"]","17623778642","8819122535459","bb13d00d11e043659001a89c72d54cab");
-    }
-
-    public static void sendSms(String code,String phone,String sender,String templateId) throws Exception{
-        //必填,请参考"开发准备"获取如下数据,替换为实际值
-        String url = "https://rtcsms.cn-north-1.myhuaweicloud.com:10743/sms/batchSendSms/v1"; //APP接入地址+接口访问URI
-        String appKey = "qnay92s7V0K7719H10m7X4yo3fl3"; //APP_Key
-        String appSecret = "6nSHQzZ3o18JeW6UtS448BbblOa0"; //APP_Secret
-//        String sender = "10690400999303617"; //国内短信签名通道号或国际/港澳台短信通道号
-//        String templateId = "d8f8f781b6e04c848f8148f4d6604bcd"; //模板ID
-
-        //条件必填,国内短信关注,当templateId指定的模板类型为通用模板时生效且必填,必须是已审核通过的,与模板类型一致的签名名称
-        //国际/港澳台短信不用关注该参数
-        String signature = "超级过客"; //签名名称
-
-        //必填,全局号码格式(包含国家码),示例:+8615123456789,多个号码之间用英文逗号分隔
-        String receiver = "+86"+phone; //短信接收人号码
-
-        //选填,短信状态报告接收地址,推荐使用域名,为空或者不填表示不接收状态报告
-        String statusCallBack = "";
-
-        /**
-         * 选填,使用无变量模板时请赋空值 String templateParas = "";
-         * 单变量模板示例:模板内容为"您的验证码是${NUM_6}"时,templateParas可填写为"[\"369751\"]"
-         * 双变量模板示例:模板内容为"您有${NUM_2}件快递请到${TXT_20}领取"时,templateParas可填写为"[\"3\",\"人民公园正门\"]"
-         * ${DATE}${TIME}变量不允许取值为空,${TXT_20}变量可以使用英文空格或点号替代空值,${NUM_6}变量可以使用0替代空值
-         * 查看更多模板和变量规范:产品介绍>模板和变量规范
-         */
-//        String templateParas = "[\""+code+"\"]"; //模板变量
-        String templateParas = code; //模板变量
-
-        //请求Body,不携带签名名称时,signature请填null
-        String body = buildRequestBody(sender, receiver, templateId, templateParas, statusCallBack, signature);
-        if (null == body || body.isEmpty()) {
-            System.out.println("body is null.");
-            return;
-        }
-
-        //请求Headers中的X-WSSE参数值
-        String wsseHeader = buildWsseHeader(appKey, appSecret);
-        if (null == wsseHeader || wsseHeader.isEmpty()) {
-            System.out.println("wsse header is null.");
-            return;
-        }
-
-        //如果JDK版本低于1.8,可使用如下代码
-        //为防止因HTTPS证书认证失败造成API调用失败,需要先忽略证书信任问题
-        //CloseableHttpClient client = HttpClients.custom()
-        //        .setSSLContext(new SSLContextBuilder().loadTrustMaterial(null, new TrustStrategy() {
-        //            @Override
-        //            public boolean isTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {
-        //                return true;
-        //            }
-        //        }).build()).setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE).build();
-
-        //如果JDK版本是1.8,可使用如下代码
-        //为防止因HTTPS证书认证失败造成API调用失败,需要先忽略证书信任问题
-        CloseableHttpClient client = HttpClients.custom()
-                .setSSLContext(new SSLContextBuilder().loadTrustMaterial(null,
-                        (x509CertChain, authType) -> true).build())
-                .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE)
-                .build();
-
-        HttpResponse response = client.execute(RequestBuilder.create("POST")//请求方法POST
-                .setUri(url)
-                .addHeader(HttpHeaders.CONTENT_TYPE, "application/x-www-form-urlencoded")
-                .addHeader(HttpHeaders.AUTHORIZATION, AUTH_HEADER_VALUE)
-                .addHeader("X-WSSE", wsseHeader)
-                .setEntity(new StringEntity(body)).build());
-
-        System.out.println(response.toString()); //打印响应头域信息
-        System.out.println(EntityUtils.toString(response.getEntity())); //打印响应消息实体
-    }
-
-    /**
-     * 构造请求Body体
-     * @param sender
-     * @param receiver
-     * @param templateId
-     * @param templateParas
-     * @param statusCallbackUrl
-     * @param signature | 签名名称,使用国内短信通用模板时填写
-     * @return
-     */
-    static String buildRequestBody(String sender, String receiver, String templateId, String templateParas,
-                                   String statusCallbackUrl, String signature) {
-        if (null == sender || null == receiver || null == templateId || sender.isEmpty() || receiver.isEmpty()
-                || templateId.isEmpty()) {
-            System.out.println("buildRequestBody(): sender, receiver or templateId is null.");
-            return null;
-        }
-        List<NameValuePair> keyValues = new ArrayList<NameValuePair>();
-
-        keyValues.add(new BasicNameValuePair("from", sender));
-        keyValues.add(new BasicNameValuePair("to", receiver));
-        keyValues.add(new BasicNameValuePair("templateId", templateId));
-        if (null != templateParas && !templateParas.isEmpty()) {
-            keyValues.add(new BasicNameValuePair("templateParas", templateParas));
-        }
-        if (null != statusCallbackUrl && !statusCallbackUrl.isEmpty()) {
-            keyValues.add(new BasicNameValuePair("statusCallback", statusCallbackUrl));
-        }
-        if (null != signature && !signature.isEmpty()) {
-            keyValues.add(new BasicNameValuePair("signature", signature));
-        }
-
-        return URLEncodedUtils.format(keyValues, Charset.forName("UTF-8"));
-    }
-
-    /**
-     * 构造X-WSSE参数值
-     * @param appKey
-     * @param appSecret
-     * @return
-     */
-    static String buildWsseHeader(String appKey, String appSecret) {
-        if (null == appKey || null == appSecret || appKey.isEmpty() || appSecret.isEmpty()) {
-            System.out.println("buildWsseHeader(): appKey or appSecret is null.");
-            return null;
-        }
-        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'");
-        String time = sdf.format(new Date()); //Created
-        String nonce = UUID.randomUUID().toString().replace("-", ""); //Nonce
-
-        byte[] passwordDigest = DigestUtils.sha256(nonce + time + appSecret);
-        String hexDigest = Hex.encodeHexString(passwordDigest);
-
-        //如果JDK版本是1.8,请加载原生Base64类,并使用如下代码
-        String passwordDigestBase64Str = Base64.getEncoder().encodeToString(hexDigest.getBytes()); //PasswordDigest
-        //如果JDK版本低于1.8,请加载三方库提供Base64类,并使用如下代码
-        //String passwordDigestBase64Str = Base64.encodeBase64String(hexDigest.getBytes(Charset.forName("utf-8"))); //PasswordDigest
-        //若passwordDigestBase64Str中包含换行符,请执行如下代码进行修正
-        //passwordDigestBase64Str = passwordDigestBase64Str.replaceAll("[\\s*\t\n\r]", "");
-
-        return String.format(WSSE_HEADER_FORMAT, appKey, passwordDigestBase64Str, nonce, time);
-    }
-}
+//package com.stylefeng.guns.modular.system.util;
+//
+//import org.apache.commons.codec.binary.Hex;
+//import org.apache.commons.codec.digest.DigestUtils;
+//import org.apache.http.HttpHeaders;
+//import org.apache.http.HttpResponse;
+//import org.apache.http.NameValuePair;
+//import org.apache.http.client.methods.RequestBuilder;
+//import org.apache.http.client.utils.URLEncodedUtils;
+//import org.apache.http.conn.ssl.NoopHostnameVerifier;
+//import org.apache.http.entity.StringEntity;
+//import org.apache.http.impl.client.CloseableHttpClient;
+//import org.apache.http.impl.client.HttpClients;
+//import org.apache.http.message.BasicNameValuePair;
+//import org.apache.http.ssl.SSLContextBuilder;
+//import org.apache.http.util.EntityUtils;
+//
+//import java.nio.charset.Charset;
+//import java.text.SimpleDateFormat;
+//import java.util.*;
+//
+////如果JDK版本是1.8,可使用原生Base64类
+//
+//public class HuaWeiSMSUtil {
+//
+//    //无需修改,用于格式化鉴权头域,给"X-WSSE"参数赋值
+//    private static final String WSSE_HEADER_FORMAT = "UsernameToken Username=\"%s\",PasswordDigest=\"%s\",Nonce=\"%s\",Created=\"%s\"";
+//    //无需修改,用于格式化鉴权头域,给"Authorization"参数赋值
+//    private static final String AUTH_HEADER_VALUE = "WSSE realm=\"SDP\",profile=\"UsernameToken\",type=\"Appkey\"";
+//
+//    public static void main(String[] args) throws Exception{
+//
+////        sendSms("[\""+1235+"\"]","17623778642","10690400999303617","d8f8f781b6e04c848f8148f4d6604bcd");
+////        sendSms("[\"17623778642\",\"蓉A-7823\"]","17623778642","8819122535459","6c848255000c4619833ab690e393f906");
+//        sendSms("[\"17623778642\",\"蓉A-7823\",\"2019/12/27\",\"14:00\"]","17623778642","8819122535459","bb13d00d11e043659001a89c72d54cab");
+//    }
+//
+//    public static void sendSms(String code,String phone,String sender,String templateId) throws Exception{
+//        //必填,请参考"开发准备"获取如下数据,替换为实际值
+//        String url = "https://rtcsms.cn-north-1.myhuaweicloud.com:10743/sms/batchSendSms/v1"; //APP接入地址+接口访问URI
+//        String appKey = "1"; //APP_Key
+//        String appSecret = "1"; //APP_Secret
+////        String sender = "10690400999303617"; //国内短信签名通道号或国际/港澳台短信通道号
+////        String templateId = "d8f8f781b6e04c848f8148f4d6604bcd"; //模板ID
+//
+//        //条件必填,国内短信关注,当templateId指定的模板类型为通用模板时生效且必填,必须是已审核通过的,与模板类型一致的签名名称
+//        //国际/港澳台短信不用关注该参数
+//        String signature = "xxx"; //签名名称
+//
+//        //必填,全局号码格式(包含国家码),示例:+8615123456789,多个号码之间用英文逗号分隔
+//        String receiver = "+86"+phone; //短信接收人号码
+//
+//        //选填,短信状态报告接收地址,推荐使用域名,为空或者不填表示不接收状态报告
+//        String statusCallBack = "";
+//
+//        /**
+//         * 选填,使用无变量模板时请赋空值 String templateParas = "";
+//         * 单变量模板示例:模板内容为"您的验证码是${NUM_6}"时,templateParas可填写为"[\"369751\"]"
+//         * 双变量模板示例:模板内容为"您有${NUM_2}件快递请到${TXT_20}领取"时,templateParas可填写为"[\"3\",\"人民公园正门\"]"
+//         * ${DATE}${TIME}变量不允许取值为空,${TXT_20}变量可以使用英文空格或点号替代空值,${NUM_6}变量可以使用0替代空值
+//         * 查看更多模板和变量规范:产品介绍>模板和变量规范
+//         */
+////        String templateParas = "[\""+code+"\"]"; //模板变量
+//        String templateParas = code; //模板变量
+//
+//        //请求Body,不携带签名名称时,signature请填null
+//        String body = buildRequestBody(sender, receiver, templateId, templateParas, statusCallBack, signature);
+//        if (null == body || body.isEmpty()) {
+//            System.out.println("body is null.");
+//            return;
+//        }
+//
+//        //请求Headers中的X-WSSE参数值
+//        String wsseHeader = buildWsseHeader(appKey, appSecret);
+//        if (null == wsseHeader || wsseHeader.isEmpty()) {
+//            System.out.println("wsse header is null.");
+//            return;
+//        }
+//
+//        //如果JDK版本低于1.8,可使用如下代码
+//        //为防止因HTTPS证书认证失败造成API调用失败,需要先忽略证书信任问题
+//        //CloseableHttpClient client = HttpClients.custom()
+//        //        .setSSLContext(new SSLContextBuilder().loadTrustMaterial(null, new TrustStrategy() {
+//        //            @Override
+//        //            public boolean isTrusted(X509Certificate[] x509Certificates, String s) throws CertificateException {
+//        //                return true;
+//        //            }
+//        //        }).build()).setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE).build();
+//
+//        //如果JDK版本是1.8,可使用如下代码
+//        //为防止因HTTPS证书认证失败造成API调用失败,需要先忽略证书信任问题
+//        CloseableHttpClient client = HttpClients.custom()
+//                .setSSLContext(new SSLContextBuilder().loadTrustMaterial(null,
+//                        (x509CertChain, authType) -> true).build())
+//                .setSSLHostnameVerifier(NoopHostnameVerifier.INSTANCE)
+//                .build();
+//
+//        HttpResponse response = client.execute(RequestBuilder.create("POST")//请求方法POST
+//                .setUri(url)
+//                .addHeader(HttpHeaders.CONTENT_TYPE, "application/x-www-form-urlencoded")
+//                .addHeader(HttpHeaders.AUTHORIZATION, AUTH_HEADER_VALUE)
+//                .addHeader("X-WSSE", wsseHeader)
+//                .setEntity(new StringEntity(body)).build());
+//
+//        System.out.println(response.toString()); //打印响应头域信息
+//        System.out.println(EntityUtils.toString(response.getEntity())); //打印响应消息实体
+//    }
+//
+//    /**
+//     * 构造请求Body体
+//     * @param sender
+//     * @param receiver
+//     * @param templateId
+//     * @param templateParas
+//     * @param statusCallbackUrl
+//     * @param signature | 签名名称,使用国内短信通用模板时填写
+//     * @return
+//     */
+//    static String buildRequestBody(String sender, String receiver, String templateId, String templateParas,
+//                                   String statusCallbackUrl, String signature) {
+//        if (null == sender || null == receiver || null == templateId || sender.isEmpty() || receiver.isEmpty()
+//                || templateId.isEmpty()) {
+//            System.out.println("buildRequestBody(): sender, receiver or templateId is null.");
+//            return null;
+//        }
+//        List<NameValuePair> keyValues = new ArrayList<NameValuePair>();
+//
+//        keyValues.add(new BasicNameValuePair("from", sender));
+//        keyValues.add(new BasicNameValuePair("to", receiver));
+//        keyValues.add(new BasicNameValuePair("templateId", templateId));
+//        if (null != templateParas && !templateParas.isEmpty()) {
+//            keyValues.add(new BasicNameValuePair("templateParas", templateParas));
+//        }
+//        if (null != statusCallbackUrl && !statusCallbackUrl.isEmpty()) {
+//            keyValues.add(new BasicNameValuePair("statusCallback", statusCallbackUrl));
+//        }
+//        if (null != signature && !signature.isEmpty()) {
+//            keyValues.add(new BasicNameValuePair("signature", signature));
+//        }
+//
+//        return URLEncodedUtils.format(keyValues, Charset.forName("UTF-8"));
+//    }
+//
+//    /**
+//     * 构造X-WSSE参数值
+//     * @param appKey
+//     * @param appSecret
+//     * @return
+//     */
+//    static String buildWsseHeader(String appKey, String appSecret) {
+//        if (null == appKey || null == appSecret || appKey.isEmpty() || appSecret.isEmpty()) {
+//            System.out.println("buildWsseHeader(): appKey or appSecret is null.");
+//            return null;
+//        }
+//        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd'T'HH:mm:ss'Z'");
+//        String time = sdf.format(new Date()); //Created
+//        String nonce = UUID.randomUUID().toString().replace("-", ""); //Nonce
+//
+//        byte[] passwordDigest = DigestUtils.sha256(nonce + time + appSecret);
+//        String hexDigest = Hex.encodeHexString(passwordDigest);
+//
+//        //如果JDK版本是1.8,请加载原生Base64类,并使用如下代码
+//        String passwordDigestBase64Str = Base64.getEncoder().encodeToString(hexDigest.getBytes()); //PasswordDigest
+//        //如果JDK版本低于1.8,请加载三方库提供Base64类,并使用如下代码
+//        //String passwordDigestBase64Str = Base64.encodeBase64String(hexDigest.getBytes(Charset.forName("utf-8"))); //PasswordDigest
+//        //若passwordDigestBase64Str中包含换行符,请执行如下代码进行修正
+//        //passwordDigestBase64Str = passwordDigestBase64Str.replaceAll("[\\s*\t\n\r]", "");
+//
+//        return String.format(WSSE_HEADER_FORMAT, appKey, passwordDigestBase64Str, nonce, time);
+//    }
+//}

--
Gitblit v1.7.1