Android集成微信支付功能

准备工作这里就不说了,包括签约和申请APPID,附上微信开放平台APP开发步骤,不懂的同学可以参考这里:

https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=8_5

上面的步骤很详细,这里主要说下调起支付的注意事项。按照上面文档中说的商户服务器生成支付订单,先调用统一下单API生成预付单,获取到prepay_id后将参数再次签名传输给APP发起支付。

相关代码如下:

/**
   * 商户服务器生成支付订单,先调用统一下单API(详见第7节)生成预付单,获取到prepay_id后将参数再次签名传输给APP发起支付。
   */
  //商品描述
  String body = "iphone6s";
  //随机字符串
  String nonce_str = ResourceUtil.createRandomString(32);
  //通知地址
  String notify_url = "http://www.weixin.qq.com/wxpay/pay.php";
  //商户订单号
  String out_trade_no = ResourceUtil.generateOutTradeNo(32);
  //总金额(单位分)
  int total_fee = 1; 

  String url = "https://api.mch.weixin.qq.com/pay/unifiedorder"; 

  String sign = SignUtil.signByMD5("appid=" + Constants.APP_ID + "&body=" + body +
    "&mch_id=" + Constants.MCH_ID + "&nonce_str=" + nonce_str + "¬ify_url=" + notify_url +
     "&out_trade_no=" + out_trade_no + "&spbill_create_ip=127.0.0.1" +
    "&total_fee=" + total_fee + "&trade_type=APP" + "&key=" + Constants.KEY).toUpperCase(Locale.getDefault()); 

  //参数以xml格式传递
  String entity = "<xml><appid>" + Constants.APP_ID + "</appid><mch_id>" + Constants.MCH_ID + "</mch_id><nonce_str>" + nonce_str +"</nonce_str><sign>" + sign +
    "</sign><body>" + body + "</body><out_trade_no>" + out_trade_no + "</out_trade_no><total_fee>" + total_fee +
    "</total_fee><spbill_create_ip>127.0.0.1</spbill_create_ip><notify_url>http://www.weixin.qq.com/wxpay/pay.php</notify_url><trade_type>APP</trade_type></xml>";  

  Log.d("entity", entity);
  payButton.setEnabled(false);
  Toast.makeText(PayActivity.this, "获取订单中...", Toast.LENGTH_SHORT).show(); 

  byte[] buf = Util.httpPost(url, entity);
  if (buf != null && buf.length > 0) {
   String content = new String(buf);
   Log.d("get server pay params:", content); 

   OrderResult orderResult = ResourceUtil.parseXml(new ByteArrayInputStream(content.getBytes())); 

   if (!TextUtils.equals(orderResult.getReturnCode(), "SUCCESS")) {
    Toast.makeText(PayActivity.this, orderResult.getReturnMsg(), Toast.LENGTH_SHORT).show();
    return;
   } 

   if (!TextUtils.equals(orderResult.getResultCode(), "SUCCESS")) {
    Toast.makeText(PayActivity.this, orderResult.getErrorDesc(), Toast.LENGTH_SHORT).show();
    return;
   } 

   //下单成功,调起支付
   PayReq request = new PayReq();
   request.appId = Constants.APP_ID;
   request.partnerId = Constants.MCH_ID;
   request.prepayId = orderResult.getPrepayId();
   request.packageValue = "Sign=WXPay";
   request.nonceStr = nonce_str; 

   String timeStamp = String.valueOf(System.currentTimeMillis() / 1000);
   request.timeStamp = timeStamp;
   request.sign = SignUtil.signByMD5("appid=" + Constants.APP_ID + "&noncestr=" + nonce_str + "&package=Sign=WXPay" +
     "&partnerid=" + Constants.MCH_ID + "&prepayid=" + orderResult.getPrepayId() + "×tamp=" + timeStamp + "&key=" + Constants.KEY).toUpperCase(Locale.getDefault()); 

   api.sendReq(request); 

   payButton.setEnabled(true);
  }
 }
}); 

相关参数说明在文档上都注明了,我这里面nonce_str和out_trade_no都是我随机生成的字符创,附上我的工具类,方便大家参考。

ResourceUtil.java

package com.xylpay.sdk.pay.uikit; 

import java.io.IOException;
import java.io.InputStream;
import java.util.Random; 

import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException; 

import com.xylpay.sdk.pay.bean.OrderResult; 

import android.util.Xml; 

public class ResourceUtil { 

 /**
  * 随机生成字符串
  * @param length 字符串的长度
  * @return  随机字符串
  */
 public static String createRandomString(int length) {
  String source = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
  Random random = new Random();
  StringBuilder builder = new StringBuilder();
  for (int i = 0; i < length; i++) {
   int position = random.nextInt(source.length());
   builder.append(source.charAt(position));
  } 

  return builder.toString();
 } 

 public static String generateOutTradeNo(int n) {
  StringBuilder builder = new StringBuilder();
  Random random = new Random();
  for (int i = 0; i < n; i++) {
   builder.append(random.nextInt(10));
  } 

  return builder.toString();
 } 

 public static OrderResult parseXml(InputStream is) {
  //PULL解析xml数据
  XmlPullParser parser = Xml.newPullParser();
  OrderResult orderResult = null;
  try {
   parser.setInput(is, "UTF-8");
   int type = parser.getEventType();
   while(type != XmlPullParser.END_DOCUMENT) {
    switch (type) {
    case XmlPullParser.START_DOCUMENT:
     break;
    case XmlPullParser.START_TAG:
     if (parser.getName().equals("xml")) {
      orderResult = new OrderResult();
     } else if (parser.getName().equals("return_code")) {
      orderResult.setReturnCode(parser.nextText());
     } else if (parser.getName().equals("return_msg")) {
      orderResult.setReturnMsg(parser.nextText());
     } else if (parser.getName().equals("result_code")) {
      orderResult.setResultCode(parser.nextText());
     } else if (parser.getName().equals("err_code_des")) {
      orderResult.setErrorDesc(parser.nextText());
     } else if (parser.getName().equals("prepay_id")) {
      orderResult.setPrepayId(parser.nextText());
     }
     break;
    case XmlPullParser.END_TAG:
     break;
    } 

    type = parser.next();
   }
  } catch(XmlPullParserException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  } 

  return orderResult;
 }
}

其中关于sign的生成,参数的顺序一定要严格按照上面的顺序加上key进行MD5加密,查看签名规范。
关于key的说明,这里的key是需要自己生成然后配置到微信开放平台的,参考商户支付密钥key的生成与设置进行配置,两边需要保持一致。另外,下单时,参数要以xml的格式来传递。

最后附上自己的签名算法:

SignUtil.java

package com.xylpay.sdk.pay.uikit; 

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException; 

/**
 * Created by Jackie on 2016/2/15.
 * * MD5加密
 */
public class SignUtil {
 public static String signByMD5(String source) {
  byte[] bytes = null;
  try {
   MessageDigest digest = MessageDigest.getInstance("MD5");
   digest.update(source.getBytes()); //更新摘要 

   bytes = digest.digest(); //再通过执行诸如填充之类的最终操作完成哈希计算。在调用此方法之后,摘要被重置。
  } catch (NoSuchAlgorithmException e) {
   e.printStackTrace();
  } 

  StringBuilder builder = new StringBuilder(bytes.length * 2);
  for (byte b : bytes) {
   /**
    * 0xFF默认是整形,一个byte跟0xFF相与会先将那个byte转化成整形运算
    */
   if ((b & 0xFF) < 0x10) { //如果为1位 前面补个0
    builder.append("0");
   } 

   builder.append(Integer.toHexString(b & 0xFF));
  } 

  return builder.toString();
 }
}

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

(0)

相关推荐

  • Android仿支付宝微信支付密码界面弹窗封装dialog

    一,功能效果 二,实现过程 1,先写xml文件:dialog_keyboard.xml 注意事项 (1),密码部分用的是一个线性布局中6个TextView,并设置android:inputType="numberPassword",外框是用的一个有stroke属性的shape, (2),1-9数字是用的recycleview ,每个item的底部和右边有1dp的黑线,填充后形成分割线. (3),recycleview 要设置属性  android:overScrollMode=&quo

  • Android支付宝和微信支付集成

    场景 随着移动支付的兴起,在我们的app'中,会经常有集成支付的需求.这时候一般都会采用微信和支付宝的sdk 来集成 (一)支付宝支付 在使用支付宝支付的过程中,我们是在服务器端生成订单,客户端访问接口,并得到订单信息,调用接口支付,支付成功后支付宝会分别 异步调用服务器端,并向客户端返回支付结果. 开发步骤: ①注册支付宝账号--进行实名认证--提交审核资料--审核通过 支付宝无线快捷支付接口: b.alipay.com/order/productDetail.htm?productId=20

  • Android编程实现的微信支付功能详解【附Demo源码下载】

    本文实例讲述了Android编程实现的微信支付功能.分享给大家供大家参考,具体如下: 最近公司弄Ionic框架,项目中需要微信支付,无奈,把我调过去弄,期间也是几近崩溃,好在皇天不负有心人,在看别人的文档,终于是在项目中集成了微信支付,下面作为一个小白的我,想要把我的经验分享给大家,希望对大家有所帮助. 先给一个可用的demo吧(运行前先看txt文件) demo代码点击此处本站下载. 这个demo是基于eclipse开发的,博主也在Android Studio开发过微信支付,原理都是一样的,大家

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

    本文实例为大家分享了Android微信支付获取二次签名Sign的方法,供大家参考,具体内容如下 /** * 获取sign签名 * * @return */ private String genPayReq() { // 获取参数的值 PayReq request = new PayReq(); request.appId = ConstantsMember.APP_ID; request.partnerId = ConstantsMember.MCHID; request.prepayId =

  • Android第三方微信支付教程

    做了微信支付,下载了Demo,发现和之前有所改动,v3.0的版本,也许有的朋友还在摸索,这里我已经成功支付,话不多说,直接进入主题: 一.首先要在微信开发平台注册账号,新增应用,填写正确的包名,正确的签名(MD5中的一串字符冒号去掉,全部小写),当然也会生成的AppID和AppSecret都有用!最后还要花300大洋开通支付功能! 二.分析一下微信支付的流程 三.界面交互流程 上面都看明白了,接下来就是写代码了 四.这里必须要有wxapi这个包名,同时必须有WXPayEntryActivity这

  • Android实现微信支付功能

    开发Android APP微信支付功能,需要完成三个步骤:第一步生成预支付订单.第二步生成微信支付参数.第三步调起微信APP支付.除了需要审核通过的APP应用外,还需要获得微信支付接口权限,然后获取对应的商户号.API密钥,这两者缺一不可,并且在APP微信支付中使用 获得商户号.API密钥 在微信开放平台中查看审核通过的APP应用,是否申请支付功能,若已申请,登录微信支付|商户平台:http://pay.weixin.qq.com 查看对应的商户号.API密钥 >申请微信支付接口 >登录商户平

  • Android—基于微信开放平台v3SDK开发(微信支付填坑)

    接触微信支付之前听说过这是一个坑,,,心里已经有了准备...我以为我没准跳坑出不来了,没有想到我填上了,调用成功之后我感觉公司所有的同事都是漂亮的,隔着北京的大雾霾我仿佛看见了太阳~~~好了,装逼结束...进入正题 开发准备: 1.在微信开放平台申请账号 2.成功后创建应用,就是填一些看似很官方很正经的资料了...(说审核7天左右,没有意外的情况下你的app第二天就审核成功了是不是很开心,有了appid,是不是就可以调用微   信支付了????-------想多了,真的) 3.微信支付是需要额外

  • Android 支付宝支付、微信支付、银联支付 整合第三方支付接入方法(后台订单支付API设计)

    客户端获取后台支付API请求参数的设计 参数样例: { data: { method: 1, platform: 1, version:"1.0", relate_orders:"B201602031023,B2016020310231", order_no: "BZY201604200952100", order_type: 1, total_fee: 1, description: "商品购买", client_ip:'1

  • Android微信支付开发问题

    并不是所有的BAT的API都是非常好用的,微信支付就有不少的缺陷,总结一下微信支付实现中出现的问题   坑点一: PayReq的参数 sign的生成   PayReq对象有个参数为packageValue 而sign生成时要用到packageValue,但是对应的Key是package,这里的key容易弄错 复制代码 代码如下: List<NameValuePair> signParams = new LinkedList<NameValuePair>();         sig

  • Android仿微信支付密码弹出层功能

    预览 使用 这个弹出层是一个DialogFragment,逻辑都封装在其内部,使用起来很简单: Bundle bundle = new Bundle(); bundle.putString(PayFragment.EXTRA_CONTENT, "提现:¥ " + 100.00); PayFragment fragment = new PayFragment(); fragment.setArguments(bundle); fragment.setPaySuccessCallBack(

  • android微信支付源码分享

    本文为大家分享了android微信支付源码,供大家参考,具体内容如下 参数配置 public static final String APP_ID ; /** 在微信开放平台注册app,微信给分配的id **/ public static final String MCH_ID; /** 申请开通微信支付,成功后微信会给你发一封邮件,给你分配一个商户平台账号,在资料里有商户ID **/ public static final String API_KEY; /** 在微信发给你的那封邮件里,给你

随机推荐