码迷,mamicode.com
首页 > 微信 > 详细

微信红包的坑~参数详解和密钥的坑

时间:2017-01-19 09:36:12      阅读:388      评论:0      收藏:0      [点我收藏+]

标签:xtu   bdc   ilo   clu   tor   gdk   idf   diy   wls   

对于之前微信支付的文章中,我们谈过了它的很多"坑",而在进行红包开发时,这种坑依然不少,主要是微信为我们提供的各种账号和密钥太多,把开发人员都搞晕了,下面大叔总结一下:

一 微信支付的密钥

统一使用公众号密钥:Key

技术分享

二 微信红包的密钥

统一使用商户账号的密钥:AppSecret

技术分享

三 红包进行签名要注意的

使用场景可以排除,如果大于200元时才需要这个参数,如果你随便写一个场景,而商户平台没有开通,反而会报错

技术分享

四 向微信发送红包请求时要带上证书

需要现时读取apiclient_cert.p12的签名内容,因为https是双向检验的,在.net平台,程序要加载p12这个证书,并发到微信;在操作系统上,还要安装这个证书,两者缺一不可.

public static string Post(string url, string param)
        {
            try
            {
                string cert = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "apiclient_cert.p12");
                string password = WxPayConfig.MCHID;
                ServicePointManager.ServerCertificateValidationCallback = new RemoteCertificateValidationCallback(CheckValidationResult);
                X509Certificate cer = new X509Certificate(cert, password);

                HttpWebRequest webrequest = (HttpWebRequest)HttpWebRequest.Create(url);
                webrequest.ClientCertificates.Add(cer);
                webrequest.Method = "post";

                byte[] someBytes = System.Text.Encoding.UTF8.GetBytes(param);
                webrequest.ContentLength = someBytes.Length;
                Stream reqStream = webrequest.GetRequestStream();
                reqStream.Write(someBytes, 0, someBytes.Length);
                reqStream.Close(); //必须要关闭 请求

                HttpWebResponse webreponse = (HttpWebResponse)webrequest.GetResponse();
                Stream stream = webreponse.GetResponseStream();
                string resp = string.Empty;
                using (StreamReader reader = new StreamReader(stream))
                {
                    resp = reader.ReadToEnd();
                }
                return resp;
            }
            catch (Exception e)
            {
                Lind.DDD.Logger.LoggerFactory.Instance.Logger_Info(string.Format("微信红包接口日志:错误代码:{0} {1}", e.Message, e.StackTrace));
                throw;
            }

五 签名时的key一定要用AppSecret,下面代码是错误的

技术分享

有了上面几个经验之后,我们的红包模块才可以测试成功!

真的挺不容易的,尤其是.net平台,还要安装个人证书,为证书添加用户权限等.

微信红包的坑~参数详解和密钥的坑

标签:xtu   bdc   ilo   clu   tor   gdk   idf   diy   wls   

原文地址:http://www.cnblogs.com/lori/p/6305411.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!