c# 微信商户转零钱 金额大于2000 遇到的问题

金额大于2000,提示缺少 Headers  中的  Wechatpay-Serial

这个,我们需要访问一下微信的接口,来获取到这个序列号 直接上代码

 public static string GetWechatpay_Serial()
        {
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create("https://api.mch.weixin.qq.com/v3/certificates");
            request.Method = "GET";
            request.ContentType = "application/json;charset=UTF-8";
            request.UserAgent = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/60.0.3100.0 Safari/537.36";
            request.Accept = "application/json";
            string Authorization = GetAuthorization("https://api.mch.weixin.qq.com/v3/certificates", "GET", "", mchid, serialNo);
            request.Headers.Add("Authorization", Authorization);
            //request.Headers.Add("User-Agent", "https://zh.wikipedia.org/wiki/User_agent");
            //request.Headers.Add("Accept", "application/json");

            string reslut = "";
            HttpWebResponse wbResponse = (HttpWebResponse)request.GetResponse();
            using (Stream responseStream = wbResponse.GetResponseStream())
            {
                using (StreamReader sReader = new StreamReader(responseStream))
                {
                    reslut = sReader.ReadToEnd();
                }
            }
            return reslut;

        }

这里面的 商户id  和商户的序列号,自己替换哈

获取内容后,返回的内容中,会有一个序列号,

接上篇文章中的  https://blog.csdn.net/Little_Code/article/details/130243211  WxV3PostJson,添加这个代码

 request.Headers.Add("Wechatpay-Serial", "刚刚的序列号");

这个时候,会提示,需要某些信息加密

然后就用到了这个代码

private string ALGORITHM = "AES/GCM/NoPadding";
        private  int TAG_LENGTH_BIT = 128;
        private  int NONCE_LENGTH_BYTE = 12;
        //APIV3  密钥   
        private  string AES_KEY = "APIV3密钥";//我这边用的V3,如果你是V2可能就是V2的密钥

        public  string AesGcmDecrypt(string associatedData, string nonce, string ciphertext)
        {
            GcmBlockCipher gcmBlockCipher = new GcmBlockCipher(new AesEngine());
            AeadParameters aeadParameters = new AeadParameters(
                new KeyParameter(Encoding.UTF8.GetBytes(AES_KEY)),
                128,
                Encoding.UTF8.GetBytes(nonce),
                Encoding.UTF8.GetBytes(associatedData));
            gcmBlockCipher.Init(false, aeadParameters);
            byte[] data = Convert.FromBase64String(ciphertext);
            byte[] plaintext = new byte[gcmBlockCipher.GetOutputSize(data.Length)];
            int length = gcmBlockCipher.ProcessBytes(data, 0, data.Length, plaintext, 0);
            gcmBlockCipher.DoFinal(plaintext, length);
            return Encoding.UTF8.GetString(plaintext);
        }

这个方法中的  参数,就是GetWechatpay_Serial(),这个方法返回的数据,然后放进去进行解密,解密得到的就是这样一串 ------BEGIN  CEFT...这样一串公钥,拿着这个公钥,对用户的名称等信息进行加密

public static string RSAEncrypt(string text, byte[] publicKey)
        {
            using (var x509 = new X509Certificate2(publicKey))
            {
                using (var rsa = (RSACryptoServiceProvider)x509.PublicKey.Key)
                {
                    var buff = rsa.Encrypt(Encoding.UTF8.GetBytes(text), true);

                    return Convert.ToBase64String(buff);
                }
            }
        }

最后     使用这个方法:

 

 string jiami = RSAEncrypt(user_name, System.Text.Encoding.UTF8.GetBytes(publicKey.Replace("-----BEGIN CERTIFICATE-----", "").Replace("-----END CERTIFICATE-----", "").Replace("\n", "")));
            //publickKey.Replace("-----BEGIN CERTIFICATE-----", "") .Replace("-----END CERTIFICATE-----", "").Replace("\n", "")
            dic1.Add("user_name", jiami);

这样,就成功发出申请了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一段 Java 的微信公众号加签代码,用于生成微信公众号的签名: ```java import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.Arrays; import java.util.HashMap; import java.util.Map; public class WechatSignUtil { /** * 生成微信公众号签名 * @param params 待签名参数 * @param apiKey API密钥 * @return 签名字符串 */ public static String generateSign(Map<String, String> params, String apiKey) { String[] keyArray = params.keySet().toArray(new String[0]); Arrays.sort(keyArray); StringBuilder sb = new StringBuilder(); for (String key : keyArray) { String value = params.get(key); if (value != null && !"".equals(value.trim())) { sb.append(key).append("=").append(value.trim()).append("&"); } } sb.append("key=").append(apiKey); String sign = null; try { MessageDigest md5 = MessageDigest.getInstance("MD5"); byte[] digest = md5.digest(sb.toString().getBytes("UTF-8")); sign = byteToStr(digest); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); } catch (Exception e) { e.printStackTrace(); } return sign.toUpperCase(); } /** * 将字节数组换成字符串 * @param byteArray 字节数组 * @return 字符串 */ private static String byteToStr(byte[] byteArray) { StringBuilder strDigest = new StringBuilder(); for (byte b : byteArray) { strDigest.append(byteToHexStr(b)); } return strDigest.toString(); } /** * 将字节换成十六进制字符串 * @param mByte 字节 * @return 十六进制字符串 */ private static String byteToHexStr(byte mByte) { char[] digit = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'}; char[] tempArr = new char[2]; tempArr[0] = digit[(mByte >>> 4) & 0X0F]; tempArr[1] = digit[mByte & 0X0F]; return new String(tempArr); } /** * 示例:生成微信公众号签名 */ public static void main(String[] args) { Map<String, String> params = new HashMap<>(); params.put("appid", "wx1234567890abcdef"); // 公众号appid params.put("mch_id", "1234567890"); // 商户号 params.put("nonce_str", "5K8264ILTKCH16CQ2502SI8ZNMTM67VS"); // 随机字符串 params.put("body", "test"); // 商品描述 params.put("out_trade_no", "20150806125346"); // 商户订单号 params.put("total_fee", "1"); // 标价金额,单位为分 params.put("spbill_create_ip", "123.12.12.123"); // 终端IP params.put("notify_url", "http://www.weixin.qq.com/wxpay/pay.php"); // 通知地址 params.put("trade_type", "JSAPI"); // 交易类型 params.put("openid", "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o"); // 用户标识 String apiKey = "192006250b4c09247ec02edce69f6a2d"; String sign = generateSign(params, apiKey); System.out.println("签名结果:" + sign); } } ``` 需要注意的是,这段代码中的 `params` 参数是一个键值对集合,包含了所有需要参与签名的参数。其中,`apiKey` 参数是微信支付的 API 密钥,用于最后的签名计算。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值