ANDROID集成支付宝SDK_APP应用支付宝开发DEMO

最近公司的项目有使用到支付功能、昨天写了一篇关于使用微信支付的文章、既然有微信支付、那么支付宝肯定少不了
这里跟大家分享一个可以正常支付的支付宝demo、但是demo需要开发者配置自己的参数才可以运行起来、首先在PayDemoActivity中设置相关参数、具体请查看该文件注释、同时需要添加两个支付宝相关的Activity到androidmanifest.xml文件、具体可以参照《支付宝钱包支付接口开发包2.0标准版接入与使用规则》里面的5.2.2、里面已经写得很清楚了
这里跟大家分享一下、个人觉得比较重要的地方、让大家少走弯路、商户ID和商户收款帐号和支付宝公钥都是在支付宝后台获取的、需要注意的是商户私钥,pkcs8格式、要通过openssl生成的、这里是需要注意的地方、生成方法在压缩包里面有的、大家下载下面的资源包就好了、当然你也可以到支付宝后台下载、效果如下
这里写图片描述

android支付宝demo

1、创建订单信息
public String getOrderInfo(String subject, String body, String price) {
// 签约合作者身份ID
String orderInfo = “partner=” “”” PARTNER “”“;

// 签约卖家支付宝账号
orderInfo  = "&seller_id="   """   SELLER   """;

// 商户网站唯一订单号
orderInfo  = "&out_trade_no="   """   getOutTradeNo()   """;

// 商品名称
orderInfo  = "&subject="   """   subject   """;

// 商品详情
orderInfo  = "&body="   """   body   """;

// 商品金额
orderInfo  = "&total_fee="   """   price   """;

// 服务器异步通知页面路径
orderInfo  = "&notify_url="   """   "http://notify.msp.hk/notify.htm"
          """;

// 服务接口名称, 固定值
orderInfo  = "&service="mobile.securitypay.pay"";

// 支付类型, 固定值
orderInfo  = "&payment_type="1"";

// 参数编码, 固定值
orderInfo  = "&_input_charset="utf-8"";

// 设置未付款交易的超时时间
// 默认30分钟,一旦超时,该笔交易就会自动被关闭。
// 取值范围:1m~15d。
// m-分钟,h-小时,d-天,1c-当天(无论交易何时创建,都在0点关闭)。
// 该参数数值不接受小数点,如1.5h,可转换为90m。
orderInfo  = "&it_b_pay="30m"";

// extern_token为经过快登授权获取到的alipay_open_id,带上此参数用户将使用授权的账户进行支付
// orderInfo  = "&extern_token="   """   extern_token   """;

// 支付宝处理完请求后,当前页面跳转到商户指定页面的路径,可空
orderInfo  = "&return_url="m.alipay.com"";

// 调用银行卡支付,需配置此参数,参与签名, 固定值 (需要签约《无线银行卡快捷支付》才能使用)
// orderInfo  = "&paymethod="expressGateway"";

return orderInfo;

}

2、call alipay sdk pay. 调用SDK支付
public void pay(View v) {
// 订单
String orderInfo = getOrderInfo(“测试的商品”, “该测试商品的详细描述”, “0.01”);

// 对订单做RSA 签名
String sign = sign(orderInfo);
try {
    // 仅需对sign 做URL编码
    sign = URLEncoder.encode(sign, "UTF-8");
} catch (UnsupportedEncodingException e) {
    e.printStackTrace();
}

// 完整的符合支付宝参数规范的订单信息
final String payInfo = orderInfo   "&sign=""   sign   ""&"
          getSignType();

Runnable payRunnable = new Runnable() {
    @Override
    public void run() {
        // 构造PayTask 对象
        PayTask alipay = new PayTask(PayDemoActivity.this);
        // 调用支付接口,获取支付结果
        String result = alipay.pay(payInfo);

        Message msg = new Message();
        msg.what = SDK_PAY_FLAG;
        msg.obj = result;
        mHandler.sendMessage(msg);
    }
};
// 必须异步调用
Thread payThread = new Thread(payRunnable);
payThread.start();

}

3、处理请求
private Handler mHandler = new Handler() {
public void handleMessage(Message msg) {
switch (msg.what) {
case SDK_PAY_FLAG: {
PayResult payResult = new PayResult((String) msg.obj);

        // 支付宝返回此次支付结果及加签,建议对支付宝签名信息拿签约时支付宝提供的公钥做验签
        String resultInfo = payResult.getResult();
        String resultStatus = payResult.getResultStatus();
        // 判断resultStatus 为“9000”则代表支付成功,具体状态码代表含义可参考接口文档
        if (TextUtils.equals(resultStatus, "9000")) {
            Toast.makeText(PayDemoActivity.this, "支付成功",
                    Toast.LENGTH_SHORT).show();
        } else {
            // 判断resultStatus 为非“9000”则代表可能支付失败
            // “8000”代表支付结果因为支付渠道原因或者系统原因还在等待支付结果确认
            //最终交易是否成功以服务端异步通知为准(小概率状态)
            if (TextUtils.equals(resultStatus, "8000")) {
                Toast.makeText(PayDemoActivity.this, "支付结果确认中",
                        Toast.LENGTH_SHORT).show();

            } else {
                // 其他值就可以判断为支付失败,包括用户主动取消支付,或者系统返回的错误
                Toast.makeText(PayDemoActivity.this, "支付失败",
                        Toast.LENGTH_SHORT).show();
            }
        }
        break;
    }
    case SDK_CHECK_FLAG: {
        Toast.makeText(PayDemoActivity.this, "检查结果为:"   msg.obj,
                Toast.LENGTH_SHORT).show();
        break;
    }
    default:
        break;
    }
};

};
有兴趣的可以加群!扫码直接进入一起探讨学习!
这里写图片描述
转载请注明出处!http://blog.csdn.net/qq_15950325/article/details/52753344/

评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值