微信支付代码示例-java
import java.util.HashMap;
import java.util.Map;
import java.util.SortedMap;
import java.util.TreeMap;
public class WechatPayDemo {
// 微信支付统一下单接口地址
private static final String UNIFIED_ORDER_URL = "https://api.mch.weixin.qq.com/pay/unifiedorder";
// 微信支付分配的商户号
private static final String MCH_ID = "your_mch_id";
// 微信支付分配的密钥
private static final String KEY = "your_key";
// 微信支付异步通知地址
private static final String NOTIFY_URL = "your_notify_url";
public static void main(String[] args) {
// 构建请求参数
SortedMap<String, String> paramMap = new TreeMap<>();
paramMap.put("appid", "your_appid");
paramMap.put("mch_id", MCH_ID);
paramMap.put("nonce_str", "your_nonce_str");
paramMap.put("body", "your_order_body");
paramMap.put("out_trade_no", "your_order_no");
paramMap.put("total_fee", "your_order_total_fee");
paramMap.put("spbill_create_ip", "your_spbill_create_ip");
paramMap.put("notify_url", NOTIFY_URL);
paramMap.put("trade_type", "JSAPI");
paramMap.put("openid", "your_openid");
// 生成签名
String sign = createSign(paramMap);
paramMap.put("sign", sign);
// 发起统一下单请求
String xmlParams = mapToXml(paramMap);
// 发送xmlParams到UNIFIED_ORDER_URL并解析响应结果
}
// 生成签名
private static String createSign(SortedMap<String, String> paramMap) {
StringBuilder sb = new StringBuilder();
for (Map.Entry<String, String> entry : paramMap.entrySet()) {
String k = entry.getKey();
String v = entry.getValue();
if (v != null && !v.isEmpty() && !"sign".equals(k) && !"key".equals(k)) {
sb.append(k).append("=").append(v).append("&");
}
}
sb.append("key=").append(KEY);
return md5(sb.toString()).toUpperCase();
}
// 将Map转换为XML格式
private static String mapToXml(Map<String, String> paramMap) {
StringBuilder sb = new StringBuilder("<xml>");
for (Map.Entry<String, String> entry : paramMap.entrySet()) {
String k = entry.getKey();
String v = entry.getValue();
sb.append("<").append(k).append(">").append(v).append("</").append(k).append(">");
}
sb.append("</xml>");
return sb.toString();
}
// 计算字符串的MD5摘要
private static String md5(String str) {
// 实现略
return null;
}
}
请注意,上述代码中的参数需要根据您的微信支付账户和具体的业务需求进行相应的替换。此示例仅演示了如何构造请求参数、生成签名和将参数转换为XML格式,并未实际发送请求或处理响应。实际使用时,您需要发送HTTP POST请求到UNIFIED_ORDER_URL,并解析响应结果。