文字说明;

前提:注册、申请服务号,开通微信支付。

涉及到的参数:AppId、AppSecret、原始ID(自动回复)、mch_id(商户号)、Key(商户密钥:自己设定。)

统一规范:

  • 要求
  1. 认证方式:HTTPS 认证,退款和冲正接口调用需要商户证书(证书在审核邮件附件中)。

  2. 请求采用POST 方式。
  3. 提交和返回结果采用XML格式。
  4. 字符集默认使用UTF-8,请勿使用其它字符集。
  5. 商户与微信之间的交互(特别是Native 回调和支付通知回调),都需要验证签名
  6. 处理返回时先判断协议返回错误码,再判断业务返回错误码,最后判断交易状态。
  • 统一加密方式:MD5。
  • 统一签名生成方式:

    •   传入参数按字段名ascii码从小到大排序,使用url键值对的格式(key1=value1&key2=value2...)拼接成字符串注:值为空的参数不参与签名)。在字符串最后再拼接上&key=Key(商户密钥),然后进行MD5加密处理,最后得到的字符串转换为大写

微信支付:

  • jsapi支付和native支付都需要调用统一支付接口(URL 地址:https://api.mch.weixin.qq.com/pay/unifiedorder)
  • jsapi支付
    • jsapi 调用统一支付接口需要参数openid(通过Oath2.0授权获取)。
    • 统一支付接口返回参数需要先验证签名,然后获取prepay_id。
    • document.addEventListener('WeixinJSBridgeReady', function onBridgeReady() {
      
        //公众号支付
        jQuery('#wxPay').click(function(e){     WeixinJSBridge.invoke('getBrandWCPayRequest',{
          "appId" : appId, //公众号名称,由商户传入
          "timeStamp" : timeStamp,   //时间戳
          "nonceStr" : nonceStr,    //随机串
          "package" : package,     //格式:prepay_id=xxxx
          "signType" : signType,    //签名方式:MD5
          "paySign" : paySign      //签名:生成签名参数appId、timeStamp、nonceStr、package、signType、key 注意参数名大小写。
          },function(res){
            if(res.err_msg == "get_brand_wcpay_request:ok" ) {
              window.location.href=url;   //支付成功后跳转到的页面用于展示
            }
            // else {
              // alert(res.err_code+res.err_desc+res.err_msg);
            // }
          });   }); }, false) 
    • 注:jsapi页面点击了两次“微信支付”,生成了两笔订单,需要在页面微信支付按钮上增加防二次点击的机制。
  • native支付

    • 参数product_id必须的
    • 调用统一支付接口获取code_url,并生成二维码图片。

微信支付回调notify_url:

    获取xml格式参数,验证签名,处理逻辑(通知后台会多次回调,先检查是否处理过,在执行)。

代码区:

  • 生成Sign公共方法:
  • public string CreateSign(Dictionary<string, string> collection)
    {
      //排序
      List<KeyValuePair<string, string>> list = new List<KeyValuePair<string, string>>(collection);
      list.Sort(delegate(KeyValuePair<string, string> pair1, KeyValuePair<string, string> pair2)
      {
        return pair1.Key.CompareTo(pair2.Key);
      });   StringBuilder sb = new StringBuilder();
      foreach (KeyValuePair<string, string> pair in list)
      {
        sb.Append(pair.Key);
        sb.Append("=");
        sb.Append(pair.Value);
        sb.Append("&");
      }
      string str = sb.Append("key=value").ToString();
      string signValue = MD5(str).ToUpper(); //md5加密并转换成大写
      return signValue ;
    }
  • xml 和 Dictionary 转换方法:
  • public string DictionaryToXml(Dictionary<string, string> collection)
    {
      StringBuilder sb = new StringBuilder();
      sb.Append("<xml>");
      foreach (KeyValuePair<string, string> pair in collection)
      {
        sb.Append("<" + pair.Key + ">");
        sb.Append("<![CDATA[" + pair.Value + "]]>");
        sb.Append("</" + pair.Key + ">");
      }
      sb.Append("</xml>");
      return sb.ToString();
    } public Dictionary<string, string> XmlToDictionary(XmlDocument doc)
    {
      Dictionary<string, string> collection = new Dictionary<string, string>();
      foreach (XmlElement element in doc.DocumentElement.ChildNodes)
      {
        string key = element.Name;
        string value = element.InnerText;
        if (value != "")
        {
          collection.Add(key, value);
        }
      }
      return collection;
    }
  • 获取Json某一key值:
  • public string GetJosnValue(string jsonStr, string key)
    {
      string result = string.Empty;
      if (!string.IsNullOrEmpty(jsonStr))
      {
        key = "\"" + key.Trim('"') + "\"";
        int index = jsonStr.IndexOf(key) + key.Length + ;
        if (index > key.Length + )
        {
          //先截逗号,若是最后一个,截“}”号,取最小值       int end = jsonStr.IndexOf(',', index);
          if (end == -)
          {
            end = jsonStr.IndexOf('}', index);
          }
          //index = json.IndexOf('"', index + key.Length + 1) + 1;
          result = jsonStr.Substring(index, end - index);
          //过滤引号或空格
          result = result.Trim(new char[] { '"', ' ', '\'' });
        }
      }
      return result;
    }

  

微信支付 v 3.3.6的更多相关文章

  1. Android—基于微信开放平台v3SDK,开发微信支付填坑。

    接触微信支付之前听说过这是一个坑,,,心里已经有了准备...我以为我没准跳坑出不来了,没有想到我填上了,调用成功之后我感觉公司所有的同事都是漂亮的,隔着北京的大雾霾我仿佛看见了太阳~~~好了,装逼结束 ...

  2. ***CodeIgniter集成微信支付(转)

    微信支付Native扫码支付模式二之CodeIgniter集成篇  http://www.cnblogs.com/24la/p/wxpay-native-qrcode-codeigniter.html ...

  3. ****基于H5的微信支付开发详解[转]

    这次总结一下用户在微信内打开网页时,可以调用微信支付完成下单功能的模块开发,也就是在微信内的H5页面通过jsApi接口实现支付功能.当然了,微信官网上的微信支付开发文档也讲解的很详细,并且有实现代码可 ...

  4. 到处都是坑的微信支付V3

    业务需要一个在微信上能付款的功能,于是乎想到了最普遍的支付宝,坑爹的是T与A是水火不容啊,默默的还是接微信支付吧,没想到从此掉进了连环坑…… 网上写微信支付接口的还是很多,PHP官方有(鄙视源码作者, ...

  5. NET微信公众号开发-5.0微信支付(待测试)

    开发前准备. 1.0微信支付官方开发者文档 2.0官方demo下载 我们用c#所以选择.net版本 不过这个官方的demo根本跑步起来 3.0官方demo运行起来解决方案 4.0微信支付官方.net版 ...

  6. 微信支付Native扫码支付模式二之CodeIgniter集成篇

    CI:3.0.5 微信支付API类库来自:https://github.com/zhangv/wechat-pay 请先看一眼官方场景及支付时序图:https://pay.weixin.qq.com/ ...

  7. 微信支付JSAPI模式及退款CodeIgniter集成篇

    微信支付接口文档:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_1 首先你得知道这个jsapi是不能离开微信进行调用支付的,明白 ...

  8. android微信支付总结+自己搭建服务器

    1.前期注册操作 1-1:微信开发平台:https://open.weixin.qq.com/ 1-2:创建移动应用 签名获取: 1.将自己的apk签名打包,运行到手机上. 2.将微信支付的签名工具, ...

  9. (实用篇)php官方微信接口大全(微信支付、微信红包、微信摇一摇、微信小店)

    微信入口绑定,微信事件处理,微信API全部操作包含在这些文件中.内容有:微信摇一摇接口/微信多客服接口/微信支付接口/微信红包接口/微信卡券接口/微信小店接口/JSAPI <?php class ...

随机推荐

  1. 普林斯顿大学算法课 Algorithm Part I Week 3 比较器 Comparators

    比较器接口(Comparator interface):用可选顺序(alternate order)进行排序 public interface Comparator<key> int co ...

  2. ubuntu系统下设置静态IP

    改动 /etc/network/interfaces文件 加入下面内容 # The loopback network interface auto lo eth0 iface lo inet loop ...

  3. Mac  任何选项没有了怎么办?

    1.如果需要恢复允许"任何来源"的选项,即关闭 Gatekeeper,请打开终端 2.然后使用 spctl 命令:  sudo spctl --master-disable

  4. nutch2.3中nutch-site.xml设置说明

    nutch-site.xml是运行nutch的非必须设置文件,也就是说你不设置,nutch照样可以运行. nutch-site.xml是nutch-default.xml的一个客制化文件. nutch ...

  5. Excel中公式的绝对引用和相对引用单元格

    在Excel的表格中,非常常用的就是公式里的绝对引用和相对引用了,具体情况请看下列表格吧. 步骤1 打开做好的excel表格.公式中的相对单元格引用是基于包含公式和单元格引用的单元格的相对位置,若公式 ...

  6. 关于nvarchar与varchar的区别

    varchar(x),  nvarchar(x)这里面的x指的是最大的列宽  如果存储的字符串没达到最大列宽  那么他也只获得对应的列宽的存储空间  并不意味着系统就会给它分配x的空间给它 varch ...

  7. AngularJS 实战讲义笔记

    第一部分 快速上手 1.1 感受AngularJs四大核心特性(MVC, 模块化,指令系统,双向数据绑定)1.2 搭建自动化的前端开发,调试,测试环境 代码编辑工具 (sublime) 断点调试工具 ...

  8. OC中最难的一部分内容:内存管理

    OC中最难的一部分内容:内存管理为什么说他难呢?因为内存如果需要我们程序员去管理的话,那个难度肯定是很大的,如果是Java,垃圾回收器会把这份工作给做了,我们不需要关心,但是就是因为如此,Androi ...

  9. 20151205--JDBC-2

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  10. 关于智能指针auto_ptr

    智能指针auto_ptr和shared_ptr也是面试中经常被问到的一个 感觉看auto_ptr的源码反而更加容易理解一些,因为源码的代码量并不大,而且比较容易理解. 本篇主要介绍auto_ptr 其 ...