demo

package com.demo.wx;

import java.io.BufferedReader;
import java.io.DataOutputStream;
import java.io.InputStreamReader;
import java.net.URL;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.cert.CertificateException;
import java.security.cert.X509Certificate;
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.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;

public class SendRedEnUtil {


private static class TrustAnyTrustManager implements X509TrustManager {

public void checkClientTrusted(X509Certificate[] chain, String authType)
throws CertificateException {
}

public void checkServerTrusted(X509Certificate[] chain, String authType)
throws CertificateException {
}

public X509Certificate[] getAcceptedIssuers() {
return new X509Certificate[] {};
}
}

private static class TrustAnyHostnameVerifier implements HostnameVerifier {
public boolean verify(String hostname, SSLSession session) {
return true;
}
}

// 全局数组
private final static String[] strDigits = { "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "a", "b", "c", "d", "e", "f" };
private static final String mchId = ""; // 商户号
private static final String wxappid = "";// 公众账号appid
private static final String nickName = "part";// 提供方名称
private static final String sendName = "oneDemo";// 商户名称
private static final String totalAmount = "2"; // 付款金额
private static final String reOpenid = "";// 接受红包的用户openid
private static final String minValue = "2";// 最小红包金额
private static final String maxValue = "2";// 最大红包金额
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 = "63507 ";// 活动ID63507
private static final String key = "";// 微信商户平台(pay.weixin.qq.com)-->账户设置-->API安全-->密钥设置

// 发送红包的方法 URLEncoder.encode("", "UTF-8")
public static void sendRedEn() 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());
// HttpsUtils.post("https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack",
// sb.toString(), "utf-8");
// 通用的请求属性

SSLContext ctx = SSLContext.getInstance("TLS");
ctx.init(null, new TrustManager[] { new TrustAnyTrustManager() },
new java.security.SecureRandom());
URL url = new URL(
"https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack");
HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
conn.setHostnameVerifier(new TrustAnyHostnameVerifier());
conn.setDoOutput(true);
conn.connect();
DataOutputStream out = new DataOutputStream(conn.getOutputStream());
out.write(sb.toString().getBytes("utf-8"));
// 刷新、关闭
out.flush();
out.close();

BufferedReader in = new BufferedReader(new InputStreamReader(
conn.getInputStream()));
String line = "";
String result = "";
while ((line = in.readLine()) != null) {
result += line + "\n";
}
out.close();
in.close();
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("clientIp");
// 活动名字
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;
System.out.println(stringSignTemp);
// 进行MD5加密然后转为大写
String sign = getMD5Code(stringSignTemp);
hm.put("sign", sign.toUpperCase());
return hm;
}

// 进行MD5加密
public static String getMD5Code(String strObj) {
String resultString = null;
try {
resultString = new String(strObj);
MessageDigest md = MessageDigest.getInstance("MD5");
// md.digest() 该函数返回值为存放哈希值结果的byte数组
resultString = byteToString(md.digest(strObj.getBytes()));
} catch (NoSuchAlgorithmException ex) {
ex.printStackTrace();
}
return resultString;
}

// 转换字节数组为16进制字串
private static String byteToString(byte[] bByte) {
StringBuffer sBuffer = new StringBuffer();
for (int i = 0; i < bByte.length; i++) {
sBuffer.append(byteToArrayString(bByte[i]));
}
return sBuffer.toString();
}

// 返回形式为数字跟字符串
private static String byteToArrayString(byte bByte) {
int iRet = bByte;
if (iRet < 0) {
iRet += 256;
}
int iD1 = iRet / 16;
int iD2 = iRet % 16;
return strDigits[iD1] + strDigits[iD2];
}

public static void main(String[] args) throws Exception {
// 设置代理
System.setProperty("proxyHost", "");
System.setProperty("proxyPort", "");
System.setProperty("proxyUser", "");
System.setProperty("proxyPassword", "");
sendRedEn();
}

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值