package wxdemo.util;
import java.io.File;
import java.io.FileInputStream;
import java.security.KeyStore;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Date;
import java.util.HashMap;
import java.util.UUID;
import javax.net.ssl.SSLContext;
import javax.servlet.http.HttpServletRequest;
import org.apache.commons.codec.digest.DigestUtils;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.conn.ssl.SSLConnectionSocketFactory;
import org.apache.http.conn.ssl.SSLContexts;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
public class SendRedEnUtil {
// 全局数组
private static final String mchId = "1232434302"; // 商户号
private static final String wxappid = "wx274b122ecbf3b8a3";// 公众账号appid
private static final String nickName = "part";// 提供方名称
private static final String sendName = "一何一世界";// 商户名称
private static final String totalAmount = "100"; // 付款金额
private static final String reOpenid = "oh-IEj5ss4kH4etg9ZqswWOd7W4A";// 接受红包的用户openid
private static final String minValue = "100";// 最小红包金额
private static final String maxValue = "100";// 最大红包金额
private static final String totalNum = "1";// 红包发送人数
private static final String wishing = "happy";// 祝福语
private static final String clientIp = "10.17.100.140";// 调用接口的地址ip
private static final String actName = "action";// 活动名字
private static final String remark = "actionRe";// 备注
private static final String actId = "69227";// 活动ID
private static final String key = "ZHONGXINGejiashiyaofafafa888HAHA";// 微信商户平台(pay.weixin.qq.com)-->账户设置-->API安全-->密钥设置
// 发送红包的方法 URLEncoder.encode("", "UTF-8")
public static void sendRedEn(HttpServletRequest request) throws Exception {
// 存放键值对的map
HashMap<String, String> hm = getSign();
// 设置请求参数
StringBuffer sb = new StringBuffer();
sb.append("<xml>");
sb.append("<sign><![CDATA[" + hm.get("sign") + "]]></sign>");
sb.append("<mch_billno><![CDATA[" + hm.get("mch_billno")
+ "]]></mch_billno>");
sb.append("<mch_id><![CDATA[" + hm.get("mch_id") + "]]></mch_id>");
sb.append("<wxappid><![CDATA[" + hm.get("wxappid") + "]]></wxappid>");
sb.append("<nick_name><![CDATA[" + hm.get("nick_name")
+ "]]></nick_name>");
sb.append("<send_name><![CDATA[" + hm.get("send_name")
+ "]]></send_name>");
sb.append("<re_openid><![CDATA[" + hm.get("re_openid")
+ "]]></re_openid>");
sb.append("<total_amount><![CDATA[" + hm.get("total_amount")
+ "]]></total_amount>");
sb.append("<min_value><![CDATA[" + hm.get("min_value")
+ "]]></min_value>");
sb.append("<max_value><![CDATA[" + hm.get("max_value")
+ "]]></max_value>");
sb.append("<total_num><![CDATA[" + hm.get("total_num")
+ "]]></total_num>");
sb.append("<wishing><![CDATA[" + hm.get("wishing") + "]]></wishing>");
sb.append("<client_ip><![CDATA[" + hm.get("client_ip")
+ "]]></client_ip>");
sb.append("<act_name><![CDATA[" + hm.get("act_name") + "]]></act_name>");
sb.append("<act_id><![CDATA[" + hm.get("act_id") + "]]></act_id>");
sb.append("<remark><![CDATA[" + hm.get("remark") + "]]></remark>");
sb.append("<nonce_str><![CDATA[" + hm.get("nonce_str")
+ "]]></nonce_str>");
sb.append("</xml>");
System.out.println(sb.toString());
System.setProperty("proxyHost", "proxy.zte.com.cn");
System.setProperty("proxyPort", "80");
System.setProperty("proxyUser", "0236000061");
System.setProperty("proxyPassword", "lijielove520!");
KeyStore keyStore = KeyStore.getInstance("PKCS12");
String realPath = request.getSession().getServletContext()
.getRealPath("")
+ File.separator + "file";
FileInputStream instream = new FileInputStream(new File(realPath
+ File.separator + "apiclient_cert.p12"));
try {
keyStore.load(instream, mchId.toCharArray());
} finally {
instream.close();
}
// Trust own CA and all self-signed certs
SSLContext sslcontext = SSLContexts.custom()
.loadKeyMaterial(keyStore, mchId.toCharArray()).build();
// Allow TLSv1 protocol only
SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(
sslcontext, new String[] { "TLSv1" }, null,
SSLConnectionSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER);
CloseableHttpClient httpclient = HttpClients.custom()
.setSSLSocketFactory(sslsf).build();
HttpPost httppost = new HttpPost(
"https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack");
StringEntity entity = new StringEntity(sb.toString(),"utf-8");
httppost.setEntity(entity);
HttpResponse response = httpclient.execute(httppost);
HttpEntity resEntity = response.getEntity();
if (resEntity != null) {
String result = EntityUtils.toString(resEntity);
System.out.println(result);
}
}
/**
* 获取32随机码
*
* @return
*/
public static String getRand() {
String uuid = UUID.randomUUID().toString();
uuid = uuid.replaceAll("-", "");
return uuid;
}
/**
* 获取商户订单号 mch_id+yyyymmdd+10位一天内不能重复的数字。
*
* @param args
*/
public static String getMchBillno(String mchId) {
StringBuffer sb = new StringBuffer();
sb.append(mchId);
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");
String time = sdf.format(new Date());
sb.append(time);
// 获取10位不重复数据
String rand = getRand();
rand = rand.substring(0, 10);
sb.append(rand);
return sb.toString();
}
/**
* 获取sign值
*
* @param args
*/
public static HashMap<String, String> getSign() {
HashMap<String, String> hm = new HashMap<String, String>();
ArrayList<String> kl = new ArrayList<String>();
// 随机数
String nonceStr = getRand();
hm.put("nonce_str", nonceStr);
kl.add("nonce_str");
// 商户号
hm.put("mch_id", mchId);
kl.add("mch_id");
// 商品订单号
String mchBillno = getMchBillno(mchId);
hm.put("mch_billno", mchBillno);
kl.add("mch_billno");
// 公众账号appid
hm.put("wxappid", wxappid);
kl.add("wxappid");
// 提供方名称
hm.put("nick_name", nickName);
kl.add("nick_name");
// 商户名称
hm.put("send_name", sendName);
kl.add("send_name");
// 接受红包的用户openid
hm.put("re_openid", reOpenid);
kl.add("re_openid");
// 付款金额
hm.put("total_amount", totalAmount);
kl.add("total_amount");
// 最小红包金额
hm.put("min_value", minValue);
kl.add("min_value");
// 最大红包金额
hm.put("max_value", maxValue);
kl.add("max_value");
// 红包发送人数
hm.put("total_num", totalNum);
kl.add("total_num");
// 祝福语
hm.put("wishing", wishing);
kl.add("wishing");
// 调用接口的地址ip
hm.put("client_ip", clientIp);
kl.add("client_ip");
// 活动名字
hm.put("act_name", actName);
kl.add("act_name");
// 备注
hm.put("remark", remark);
kl.add("remark");
// 活动ID
hm.put("act_id", actId);
kl.add("act_id");
// 排序
String[] kls = kl.toArray(new String[] {});
Arrays.sort(kls);
// 拼接处待加密的String
StringBuffer sb = new StringBuffer();
for (String k : kls) {
sb.append(k);
sb.append("=");
sb.append(hm.get(k));
sb.append("&");
}
// 把stringA与上key
String stringSignTemp = sb.toString() + "key=" + key;
System.out.println(stringSignTemp);
// 进行MD5加密然后转为大写
String sign = DigestUtils.md5Hex(stringSignTemp);
hm.put("sign", sign.toUpperCase());
return hm;
}
public static void main(String[] args) throws Exception {
}
}

- 大小: 7.6 KB
分享到:
相关推荐
c语言学习
人脸识别项目源码实战
人脸识别项目源码实战
本图书进销存管理系统管理员功能有个人中心,用户管理,图书类型管理,进货订单管理,商品退货管理,批销订单管理,图书信息管理,客户信息管理,供应商管理,库存分析管理,收入金额管理,应收金额管理,我的收藏管理。 用户功能有个人中心,图书类型管理,进货订单管理,商品退货管理,批销订单管理,图书信息管理,客户信息管理,供应商管理,库存分析管理,收入金额管理,应收金额管理。因而具有一定的实用性。 本站是一个B/S模式系统,采用Spring Boot框架,MYSQL数据库设计开发,充分保证系统的稳定性。系统具有界面清晰、操作简单,功能齐全的特点,使得图书进销存管理系统管理工作系统化、规范化。本系统的使用使管理人员从繁重的工作中解脱出来,实现无纸化办公,能够有效的提高图书进销存管理系统管理效率。 关键词:图书进销存管理系统;Spring Boot框架;MYSQL数据库
基于动态规划和模型预测控制的并联混合电动汽车最佳控制 简介:利用动态规划,使用模型预测控制,实现对并联混合动力电动汽车的最佳控制,并降低总体成本函数 使用动态规划可以实现混合动力电动汽车的优化控制 混合动力电动汽车的模型预测控制是通过使用动态规划在缩短的时域内实现的 代码为纯matlab脚本,附带说明电子文档 ,并联混合电动汽车; 动态规划; 模型预测控制; 最佳控制; 总体成本函数; Matlab脚本。,动态规划与模型预测控制在并联混合动力电动汽车的最优控制策略
人脸识别项目实战
2025 DeepSeek技术全景解析-重塑全球AI生态的中国力量.pdf
能够爬取非会员视频和音频资源,可通过ffmpeg等工具将视频资源和音频资源合并
基于差分进化算法DE的机器人路径规划 本产品基于优化的差分进化算法,专为机器人山地路径规划而设计 通过模拟差分进化过程中的变异、交叉与选择机制,算法能够智能探索并确定最优行进路线,全面考量路径长度、能量消耗及地形适应性 优化之处在于融合了动态差分权重与精英保留策略,显著增强了算法的搜索效率和求解质量,有效规避了早熟收敛的风险 该算法在山地这一复杂且多变的自然环境中展现出卓越性能,完美适配于机器人探险、山地救援、环境监测等多种应用场景 我们矢志为用户提供卓越、稳健的机器人路径规划方案,推动各类山地作业迈向更为精确与高效的路径规划新时代 ,差分进化算法DE; 机器人路径规划; 山地路径规划; 算法优化; 早熟收敛风险规避; 山地探险应用场景; 环境监测场景。,DE算法赋能机器人,优化山地路径规划方案
情侣游戏情侣飞行棋10元真心话大冒险情侣情趣骰子php源码 ----- 程序特色 ----- 1、完整的分销制度,可自定义多种不同的返佣比例 2、支持情侣飞行棋、情趣骰子,多种等级 3、无感微信自动授权登录,支持微信第三方授权登录 4、完全开源无加密
HeidiSQL的12.2.0.6576安装压缩包
监护人,小孩和玩具数据集 4647张原始图片 监护人 食物 孩子 玩具 精确率可达85.4% yolov5pytorch格式
本课程是 PHP 进阶系列之 Swoole 入门精讲,系统讲解 Swoole 在 PHP 高性能开发中的应用,涵盖 协程、异步编程、WebSocket、TCP/UDP 通信、任务投递、定时器等核心功能。通过理论解析和实战案例相结合,帮助开发者掌握 Swoole 的基本使用方法及其在高并发场景下的应用。 适用人群: 适合 有一定 PHP 基础的开发者、希望提升后端性能优化能力的工程师,以及 对高并发、异步编程感兴趣的学习者。 能学到什么: 掌握 Swoole 基础——理解 Swoole 的核心概念,如协程、异步编程、事件驱动等。 高并发处理——学习如何使用 Swoole 构建高并发的 Web 服务器、TCP/UDP 服务器。 实战项目经验——通过案例实践,掌握 Swoole 在 WebSocket、消息队列、微服务等场景的应用。 阅读建议: 建议先掌握 PHP 基础,了解 HTTP 服务器和并发处理相关概念。学习过程中,结合 官方文档和实际项目 进行实践,加深理解,逐步提升 Swoole 开发能力。
机器人先进视觉赛-基于深度学习yolov8的3D识别项目源码含gui界面(最新发布).zip 实现机器人的3D目标识别和分割功能 支持深度图像的处理和分析 【资源详情说明】 【1】该项目为近期精心打造开发,完整代码。同时,配套资料一应俱全,涵盖详细的设计文档 【2】项目上传前源码经过严格测试,在多种环境下均能稳定运行,功能完善且稳定运行,技术研究、教学演示还是项目实践,都能轻松复现,节省时间和精力。 【3】本项目面向计算机相关专业领域的各类人群,对于高校学生,可作为毕业设计、课程设计、日常作业的优质参考;对于科研工作者和行业从业者,可作为项目初期立项演示,助力快速搭建原型,验证思路。 【4】若具备一定技术基础,可在此代码上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 【5】小白,在配置环境或运行项目时遇到困难,可提供远程指导和全方位技术支持。 欢迎下载学习本项目资源,期待与你共同探讨技术问题,交流项目经验!
Matlab实现TSO-XGBoost多变量回归预测 Matlab实现TSO-XGBoost多变量回归预测,金枪鱼算法优化XGBoost多变量回归预测 1.data为数据集,7个输入特征,1个输出特征 2.MainTSO XGboost.m为主程序文件,其他为函数文件,无需运行 3.命令窗口输出R2、MAE、MAE和RMSEP等评价指标,可在下载区获取数据和程序内容 注意程序和数据放在一个文件夹,文件夹不可以XGBoost命名,因为有函数已经用过,运行环境为 Matlab2018及以上,预测效果如下 ,TSO-XGBoost; 多变量回归预测; Matlab实现; 金枪鱼算法优化; 评价指标; 预测效果; 文件夹结构; 运行环境,Matlab中TSO-XGBoost多变量回归预测优化实践
实时音视频SRT协议中文完整版
学习WiFi,入手资料
c语言学习
jl5104开发板的代码,sdk