当前位置: 首页 > 编程笔记 >

Android微信支付获取二次签名Sign的方法

池麒
2023-03-14
本文向大家介绍Android微信支付获取二次签名Sign的方法,包括了Android微信支付获取二次签名Sign的方法的使用技巧和注意事项,需要的朋友参考一下

本文实例为大家分享了Android微信支付获取二次签名Sign的方法,供大家参考,具体内容如下

/**
  * 获取sign签名
  * 
  * @return
  */
 private String genPayReq() {

  // 获取参数的值
  PayReq request = new PayReq();
  request.appId = ConstantsMember.APP_ID;
  request.partnerId = ConstantsMember.MCHID;
  request.prepayId = mPrepayId;
  request.packageValue = "Sign=WXPay";
  request.nonceStr = DataUtil.getGuid();
  request.timeStamp = DataUtil.getTimeStamp();

  // 把参数的值传进去SortedMap集合里面
  SortedMap<Object, Object> parameters = new TreeMap<Object, Object>();
//  {appid=wx34df375d7dae8c90, noncestr=3BF34EF2CA4A462DB8D4EA48E785CDC3, 
//    package=Sign=WXPay, partnerid=1349967601, 
//    prepayid=wx2016070910354542c7155d4e0846850809, timestamp=1468031760}
  parameters.put("appid", request.appId);
  parameters.put("noncestr", request.nonceStr);
  parameters.put("package", request.packageValue);
  parameters.put("partnerid", request.partnerId);
  parameters.put("prepayid", request.prepayId);
  parameters.put("timestamp", request.timeStamp);

  String characterEncoding = "UTF-8";
  String mySign = createSign(characterEncoding, parameters);
  System.out.println("我的签名是:" + mySign);
  return mySign;
 }

 /**
  * 微信支付签名算法sign
  * 
  * @param characterEncoding
  * @param parameters
  * @return
  */
 public static String createSign(String characterEncoding,
   SortedMap<Object, Object> parameters) {

  StringBuffer sb = new StringBuffer();
  Set es = parameters.entrySet();// 所有参与传参的参数按照accsii排序(升序)
  Iterator it = es.iterator();
  while (it.hasNext()) {
   @SuppressWarnings("rawtypes")
   Map.Entry entry = (Map.Entry) it.next();
   String k = (String) entry.getKey();
   Object v = entry.getValue();
   if (null != v && !"".equals(v) && !"sign".equals(k)
     && !"key".equals(k)) {
    sb.append(k + "=" + v + "&");
   }
  }
  sb.append("key=" + ConstantsMember.KEY); //KEY是商户秘钥
  String sign = MD5Util.MD5Encode(sb.toString(), characterEncoding)
    .toUpperCase();
  return sign; // D3A5D13E7838E1D453F4F2EA526C4766
      // D3A5D13E7838E1D453F4F2EA526C4766
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • wx.BaaS.pay(OBJECT) OBJECT 参数说明 参数 类型 必填 参数描述 totalCost Number Y 支付总额 merchandiseDescription String Y 微信支付凭证-商品详情的内容 merchandiseSchemaID Integer N 商品表 ID,可用于定位用户购买的物品 merchandiseRecordID String N 商品记录

  • 本文向大家介绍php微信支付之APP支付方法,包括了php微信支付之APP支付方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了微信开放平台移动应用集成微信支付功能。分享给大家供大家参考。具体分析如下: WechatAppPay文件代码如下: 希望本文所述对大家的php程序设计有所帮助。

  • 发起一个微信支付请求 wx.chooseWXPay({ timestamp: 0, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符 nonceStr: '', // 支付签名随机串,不长于 32 位 package: '', // 统一支付接口返回的prepay_id参

  • 关于微信二维码防止重复支付,假如我现在前端显示一个二维码,用户没有关闭,重复扫支付,这样不是直接走微信那边了吗,那我该如何阻止他重复支付

  • 一样问了很多网络相关&网络攻防相关的问题,有4点没答好 抓包工具怎么抓的?安装CA证书就可以进行中间人攻击了吗?(应该是) form表单可以发送跨域POST请求,那有A,B网站,A网站是正常,B网站是恶意网站,那么我在B网站用form发送请求,如果在服务端设置了CORS,会被拦截吗?(会)(下去可以抓包试试) 浏览器是怎么做到跨域拦截的, 是会发送两次请求吗?我说是的,其实应该分2种情况 QUIC

  • 本文向大家介绍Java将微信和支付宝支付的个二维码合二为一的方法,包括了Java将微信和支付宝支付的个二维码合二为一的方法的使用技巧和注意事项,需要的朋友参考一下 因公司需要将支付宝和微信的二维码合成一个,不管用户用支付宝扫还是微信扫都能打开对应的支付页面,在网上找了一些文章,很感谢各位大神的经验,我也记录下我是如何将两个二维码合二为一的~。 原理:支付宝或微信生成的二维码中本质都内嵌了一个url