微信支付说明
1.统一下单接口
统一支付接口:
  url: https://api.mch.weixin.qq.com/pay/unifiedorder
  目的:通过此接口来创建预支付订单,获取订单支付需要的prepay_id
  过程:
    1.对所有的支付中使用到的参数以字典序排序,然后使用商户的key进行MD5加密,获得加密字符串sign,
    2.然后将sign加入以上信息中将其转化为xml,调用统一下单接口,获取prepay_id。
  代码说明:
    
   

1.构建支付参数
//写购买商品的详情
JSONObject object = new JSONObject();
JSONArray array = new JSONArray();
JSONObject object1 = new JSONObject();
object1.put("goods_id","购买商品id");
object1.put("goods_name","购买商品名称");
object1.put("quantity","购买商品数量");
object1.put("price","商品单价");
array.add(object1);
object.put("goods_detail",array);
//构建统一下单需要的参数
Map<String,String> map = new HashMap<>();
map.put('appid',"支付的微信公众号的appid");
map.put("mch_id","支付的商户号");
map.put("device_info","设备编号");
map.put("sign_type","加密类型,一般使用MD5");
map.put("body","商品描述");
map.put("out_trade_no","商户订单号");
map.put("total_url","购买总金额");
map.put("notify_url","支付成功后微信的回掉地址,地址不许带参数");
map.put("trade_type","交易类型");
map.put("nonce_str","随机字符串");
map.put("detail","商品详情");
map.put("openid","支付人的openid");
map.put("spbill_create_ip","支付人ip地址");
//将统一下单参数进行字典序排序,进行签名

/**
* 微信支付签名算法(详见:https://pay.weixin.qq.com/wiki/doc/api/tools/cash_coupon.php?chapter=4_3).
*
* @param params 参数信息
* @param signType 签名类型,如果为空,则默认为MD5
* @param signKey 签名Key
* @param ignoreSignType 签名时,是否忽略signType
* @return 签名字符串
*/
public static String createSign(Map<String, String> params, String signType, String signKey, boolean ignoreSignType) {
  SortedMap<String, String> sortedMap = new TreeMap<>(params);   StringBuilder toSign = new StringBuilder();
  for (String key : sortedMap.keySet()) {
    String value = params.get(key);
    boolean shouldSign = false;
    if (ignoreSignType && "sign_type".equals(key)) {
      shouldSign = false;
    } else if (StringUtils.isNotEmpty(value)
      && !Lists.newArrayList("sign", "key", "xmlString", "xmlDoc", "couponList").contains(key)) {
       shouldSign = true;
    }   if (shouldSign) {
    toSign.append(key).append("=").append(value).append("&");
  }
 }   toSign.append("key=").append(signKey);
  if ("HMAC_SHA256".equals(signType)) {
    return createHmacSha256Sign(toSign.toString(), signKey);
  } else {
    return DigestUtils.md5Hex(toSign.toString()).toUpperCase();
  }
} //将上一步得到的签名加入上一个支付参数中,转为xml请求统一支付下单接口,获取订单支付需要的prepay_id
map.put("sign","上一步得到的签名");
//将map转为xml
public static String map2XmlString(Map<String, String> map) {
  String xmlResult = "";   StringBuffer sb = new StringBuffer();
  sb.append("<xml>");
  for (String key : map.keySet()) {
    String value = "<![CDATA[" + map.get(key) + "]]>";
    sb.append("<" + key + ">" + value + "</" + key + ">");
  }
  sb.append("</xml>");
  xmlResult = sb.toString();
  return xmlResult;
}
//进行网络请求 public static String httpPostWithXml(String xml, String url){
  StringBuffer stringBuffer = new StringBuffer();
  HttpPost post = null;
  try {
    HttpClient httpClient = new DefaultHttpClient(); // 设置超时时间
//httpClient.getParams().setParameter(CoreConnectionPNames.CONNECTION_TIMEOUT, 2000);
//httpClient.getParams().setParameter(CoreConnectionPNames.SO_TIMEOUT, 2000);     post = new HttpPost(url);
// 构造消息头
    post.setHeader("Content-type", "application/json; charset=utf-8");
    post.setHeader("Connection", "Close"); // 构建消息实体
    StringEntity entity = new StringEntity(xml,"UTF-8");
    entity.setContentEncoding("UTF-8");
// 发送Json格式的数据请求
    entity.setContentType("application/json");
    post.setEntity(entity);     HttpResponse response = httpClient.execute(post);
// 检验返回码
    int statusCode = response.getStatusLine().getStatusCode();
    if(statusCode != HttpStatus.SC_OK){
      LogUtil.info("请求出错: "+statusCode);
    }else{
      InputStream inputStream = response.getEntity().getContent();
      BufferedReader br = new BufferedReader(new InputStreamReader(inputStream,"utf-8"));       String str= "";
      while((str = br.readLine()) != null){
        stringBuffer .append(str );
      }
    }
  } catch (Exception e) {
    e.printStackTrace();
  }
  return stringBuffer.toString();
}
//得到了prepay_id,获取支付的签名
Map<String,String> map = new HashMap<>();
map.put('appId',"支付的微信公众号的appid");
map.put("signType","加密类型");
map.put("nonceStr","随机字符串");
map.put("package","固定格式: prepay_id=上一步获得的prepay_id");
map.put("timeStamp","当前时间戳");
//将上面的参数使用商户key进行签名,得到paysign,将paySign加入上面的参数之中,发给h5页面调起支付。
map.put(paySign,"得到的签名"); //h5页面调起支付
WeixinJSBridge.invoke(
  'getBrandWCPayRequest', {
    "appId":rs.appId, //公众号名称,由商户传入
    "timeStamp":rs.timeStamp, //时间戳,自1970年以来的秒数
    "nonceStr":rs.nonceStr, //随机串
    "package":rs.package,
    "signType":"MD5", //微信签名方式:
    "paySign":rs.paySign //微信签名
  },
  function(res){
    if(res.err_msg == "get_brand_wcpay_request:ok" ) {
      //支付成功
    }else if(res.err_msg =="get_brand_wcpay_request:fail"){
      //支付失败
    }else if(res.err_msg == "get_brand_wcpay_request:cancel"){
      //取消支付
    }else {
      //其他情况
    }
  }
);

微信公众号H5支付的更多相关文章

  1. 微信公众号H5支付遇到的那些坑

    简史 官方文档说的很清楚,商户已有H5商城网站,用户通过消息或扫描二维码在微信内打开网页时,可以调用微信支付完成下单购买的流程. 当然,最近微信支付平台也加入了纯H5支付,也就是说用户可以在微信以外的 ...

  2. 微信公众号H5支付步骤

    微信公众平台:https://mp.weixin.qq.com/ 进入 微信支付 管理>开通支付功能. 微信支付|商户平台: 设置安全目录:https://pay.weixin.qq.com/i ...

  3. 微信公众号JSAPI支付

    微信公众号JSAPI支付 一:配置参数 申请成功后,获取接口文件, 将所有文件放入项目根目录weixin下,在WxPay.ub.config.php中填入配置账户信息; 二:设置授权 开发者中心-&g ...

  4. Vue3+Typescript+Node.js实现微信端公众号H5支付(JSAPI v3)教程--各种填坑

    ----微信支付文档,不得不说,挺乱!(吐槽截止) 功能背景 微信公众号中,点击菜单或者扫码,打开公众号中的H5页面,进行支付. 一.技术栈 前端:Vue:3.0.0,typescript:3.9.3 ...

  5. 微信公众号JSAPI支付-多公众号向同一商户号支付的问题解决

    一.背景 项目提供公众号商城集成,在公众号里进行商品的购买,并与多家公众号合作增加渠道流量. . 二.实现 有关微信公众号.商户号的开通与支付绑定不细说 从背景里可知,我们需要实现多个公众号购买向同一 ...

  6. java微信公众号JSAPI支付以及所遇到的坑

    上周做了个支付宝微信扫码支付,今天总结一下.微信相比支付宝要麻烦许多 由于涉及到代理商,没办法,让我写个详细的申请流程,懵逼啊. 笔记地址 http://note.youdao.com/notesha ...

  7. PHP应用如何对接微信公众号JSAPI支付

    微信支付的产品有很多,1. JSAPI支付  2. APP支付  3. Native支付  4.付款码支付  5. H5支付. 其中基于微信公众号开发的应用选择“JSAPI支付“产品,其他APP支付需 ...

  8. appium操作微信公众号H5 web页面

    安卓微信公众号的H5页面是webview,一般操作需要切换context. 在执行如下步骤,就能直接像识别native样识别webview 1.代码追加: ChromeOptions options ...

  9. 网站如何接入微信公众号JSAPI支付PHP版

    1.首先,我们要有一个微信公众号(分类类型有订阅号,服务号,企业号)我们的微信公众号一定是个服务号只有它才有微信支付接口.. 并且这个微信公众号一定要进行微信认证才能申请微信支付接口. 2.申请JSA ...

随机推荐

  1. 磁盘配额(Quota)的应用与实践

    1>什么是Quota      在Linux中,由于是多用户,多任务的环境,所以会有多用户共同使用一个硬盘空间的情况发生,如果其中有少数几个用户大量占用掉了硬盘空间的话,那肯定影响其他用户的使 ...

  2. Spring MVC深入讲解

    一.前言: 大家好,Spring3 MVC是非常优秀的MVC框架,由其是在3.0版本发布后,现在有越来越多的团队选择了Spring3 MVC了.Spring3 MVC结构简单,应了那句话简单就是美,而 ...

  3. 仿建设银行APP首页效果

    仿建设银行APP首页效果 下载地址: http://pan.baidu.com/s/1eRMYEzC 下载后需要解压,解压密码联系:390980233  收费88元 HTML+JS实现,下载即可试用. ...

  4. jQuery截取字符串、日期字符串转Date、获取html中的纯文本

    jQuery截取字符串.日期字符串转Date.获取html中的纯文本. var com = com || {}; (function ($, com) { /* * 截取字符串 * @param st ...

  5. jquery批量控制表单元素

    网上查了很久,避免下次再遇到相同的问题,记录一下: $("form input").prop("readonly", true); $("form i ...

  6. OPC测试常用的OPCClient和OPCServer软件推荐

    各位在进行OPC通讯时,常会遇到两种情况: 1)使用一个OPCClient在同一台计算机上连接远程计算机上的多个OPCServer时,发现某个OPCServer是通畅的,但其他的OPCServer却无 ...

  7. JEECG(二) JEECG框架下调用webservice java springmvc maven 调用 webservice

    JEECG系列教程二 如何在JEECG框架下使用webservice 本文所使用的webservice是c#开发的 其实无论是什么语言开发的webservice用法都一样 java springmvc ...

  8. 使用Navicat 创建mysql存储过程,实现日期加流水号序列

    目的:使用Navicat 创建mysql存储过程,实现格式为8位日期(年月日)+5位流水号序列. 步骤: 1.打开Navicat 登录数据库,点击导航栏上的函数,如下图: 2.点击新建函数,选择“过程 ...

  9. Android 美学设计基础 <1>

    在做原型的时候,和设计师交流的过程中,发现在设计安卓交互的过程中,其实是存在一些基本规则的.那这些规则,可以保证第一应用美观,第二不会出现反人类的开发难度,第三,用设计师的话说就是可能会有“最好的体现 ...

  10. 【Hight Performance Javascript】——脚本加载和运行

    脚本加载和运行 当浏览器遇到一个<script>标签时,无法预知javascript是否在<p>标签中添加内容.因此,浏览器停下来,运行javascript代码,然后继续解析. ...