https://software.intel.com/zh-cn/blogs/2015/03/05/android-android/
最近在做一个关于购物商城的项目,项目里面付款这块我选的是调用支付宝的接口,因为用的人比较多。
1、到支付宝官网,下载支付宝集成开发包
由于android设备一般用的都是无线支付,所以我们申请的就是支付宝无线快捷支付接口。下面是申请的地址以及下载接口开发包的网址:https://b.alipay.com/order/productDetail.htm?productId=2014110308141993(如果链接失效,你可以到支付宝官网商家服务模块中找到 快捷支付(无线)这个服务。)
下载集成开发包(http://download.alipay.com/public/api/base/WS_MOBILE_PAY_SDK_BASE.zip),解压发现里面有三个文件夹,打开其中“移动支付接口SDK2.0标准版(20150121)”文件夹,你将看到“DEMO”文件夹即说明文档,在打开“DEMO”文件夹,会看到“客户端的demo”文件夹,在客户端的demo中又有两个压缩包,分别是Android、IOS使用的,解压Android使用的压缩包,你将看到“alipay_demo”、“alipay-sdk-common”文件夹,这个就是你要用的支付宝接口及demo。
↓
↓
↓
↓
把“alipay_demo”项目导入到Eclipse中,run一下;成功之后,好好的研究研究该demo,至于到时候如何集成到你的项目里面,文档上说明很详细,按着文档上一步一步来就行了。我的建议是先把这个demo弄懂再设计你的项目,看看调用接口是需要哪些数据,这样也有利于你一开始设计数据。
2、介绍接口demo里面的结构
· 打开项目会发现里面有5个类:
其中,Base64.java、PayResult.java、SignUtils.java这三个类不需要动,到时候直接放到项目里面就行了,如果你想了解它们也可以看看。重点就是ExternalFragment.java和PayDemoActivity.java这两个类。先来说说PayDemoActivity.java类。
01 |
package com.alipay.sdk.pay.demo; |
08 |
public class PayDemoActivity extends FragmentActivity { |
11 |
public static final String PARTNER = "" ; |
13 |
public static final String SELLER = "" ; |
15 |
public static final String RSA_PRIVATE = "" ; |
17 |
public static final String RSA_PUBLIC = "" ; |
PayDemoActivity.java这个类等你申请支付宝签约成功后再配置,先放在这不用管,如何配置我注释里面已经写的很明白了。
然后是ExternalFragment.java这个类。这个类其实很简单,你运行这个demo会发现其实在PayDemoActivity.java类的onCreate()方法中填充的布局包含了ExternalFragment类,因此就会显示ExternalFragment类填充的布局,然后点击“支付”按钮,就会调用支付宝接口(因为PayDemoActivity.java未配置,所以你现在估计调用不成功)。我们找到按钮的点击事件的方法就找到调用支付宝的入口了,这个类的代码如下:
02 |
* call alipay sdk pay. 调用SDK支付 |
05 |
public void pay(View v) { |
07 |
String orderInfo = getOrderInfo( "测试的商品" , "该测试商品的详细描述" , "0.01" ); |
10 |
String sign = sign(orderInfo); |
13 |
sign = URLEncoder.encode(sign, "UTF-8" ); |
14 |
} catch (UnsupportedEncodingException e) { |
19 |
final String payInfo = orderInfo + "&sign=\"" + sign + "\"&" |
22 |
Runnable payRunnable = new Runnable() { |
27 |
PayTask alipay = new PayTask(PayDemoActivity. this ); |
29 |
String result = alipay.pay(payInfo); |
31 |
Message msg = new Message(); |
32 |
msg.what = SDK_PAY_FLAG; |
34 |
mHandler.sendMessage(msg); |
39 |
Thread payThread = new Thread(payRunnable); |
现在,你已经知道代码是如何调用支付宝接口了。接下来的问题就是:如何把这些代码集成到你的项目中去?
3、写好你的项目
4、如何将支付宝接口集成到你的项目当中
1.解压接口压缩文件(文件名是WS_MOBILE_PAY_SDK_BASE.zip),找到安卓的压缩文件(文件名是支付宝移动支付SDK标准版(Android).zip)。标准SDK以jar包方式提供给商户应用工程集成,打开alipay-sdk-common文件夹分别是alipaysdk.jar、alipaysecsdk.jar、alipayutdid.jar这三个jar包。
2.导入开发资源
(1) 将这 3 个 jar 包放入商户应用工程的 libs 目录下,如下图。
图1-1 libs目录结构
(2) 进入商户应用工程的 Java Build Path,将 libs 目录下的 jar 导入,如下图。
图1-2 导入jar
(3) 选中 Order and Export,勾选 3 个 jar 包,如下图。
图1-3 勾选3个jar包
3.修改Manifest文件
在商户应用工程的AndroidManifest.xml文件里面添加声明:
02 |
android:name= "com.alipay.sdk.app.H5PayActivity" |
03 |
android:configChanges= "orientation|keyboardHidden|navigation" |
04 |
android:exported= "false" |
05 |
android:screenOrientation= "behind" > |
08 |
android:name= "com.alipay.sdk.auth.AuthActivity" |
09 |
android:configChanges= "orientation|keyboardHidden|navigation" |
10 |
android:exported= "false" |
11 |
android:screenOrientation= "behind" > |
和权限声明:
1 |
<uses-permission android:name= "android.permission.INTERNET" /> |
2 |
<uses-permission android:name= "android.permission.ACCESS_NETWORK_STATE" /> |
3 |
<uses-permission android:name= "android.permission.ACCESS_WIFI_STATE" /> |
4 |
<uses-permission android:name= "android.permission.READ_PHONE_STATE" /> |
5 |
<uses-permission android:name= "android.permission.WRITE_EXTERNAL_STORAGE" /> |
6 |
<uses-permission android:name= "android.permission.ACCESS_COARSE_LOCATION" /> |
4.添加混淆规则
在商户应用工程的proguard-project.txt里添加以下相关规则:
01 |
-libraryjars libs/alipaysdk.jar |
02 |
-libraryjars libs/alipaysecsdk.jar |
03 |
-libraryjars libs/alipayutdid.jar |
04 |
-keep class com.alipay.android.app.IAlixPay{*;} |
05 |
-keep class com.alipay.android.app.IAlixPay$Stub{*;} |
06 |
-keep class com.alipay.android.app.IRemoteServiceCallback{*;} |
07 |
-keep class com.alipay.android.app.IRemoteServiceCallback$Stub{*;} |
08 |
-keep class com.alipay.sdk.app.PayTask{ public *;} |
09 |
-keep class com.alipay.sdk.app.AuthTask{ public *;} |
10 |
-keep class com.alipay.mobilesecuritysdk.* |
至此,SDK开发资源导入完成。
5.订单数据生成
在调用SDK支付时需要提交订单信息info,其中参数以key=“value”形式呈现,参数之间以“&”分割,所有参数不可缺。
6.支付接口调用
需要在新线程支付接口。(可参考alipay_demo来实现)
获取PayTask支付对象调用支付,代码实例:
01 |
final String orderInfo = info; |
02 |
Runnable payRunnable = new Runnable() { |
05 |
PayTask alipay = new PayTask(DemoActivity. this ); |
06 |
String result = alipay.pay(orderInfo); |
07 |
Message msg = new Message(); |
08 |
msg.what = SDK_PAY_FLAG; |
10 |
mHandler.sendMessage(msg); |
14 |
Thread payThread = new Thread(payRunnable); |
7.支付结果获取和处理
调用pay方法支付后,将通过2种途径获得支付结果:
· 同步返回
商户应用客户端通过当前调用支付的Activity的Handler对象,通过它的回调函数获取支付结果。(可参考alipay_demo来实现)
代码示例:
1 |
private Handler mHandler = new Handler() { |
2 |
public void handleMessage(Message msg) { |
3 |
Result result = new Result((String) msg.obj); |
4 |
Toast.makeText(DemoActivity. this , result.getResult(), |
5 |
Toast.LENGTH_LONG).show(); |
· 异步通知
商户需要提供一个http协议的接口,包含在参数里传递给快捷支付,即notify_url。支付宝服务器在支付完成后,会以POST方式调用notify_url,以xml数据格式传输支付结果。
8.查询有效账号接口调用
调用PayTask对象的checkAccountIfExist()方法查询。(可参考alipay_demo来实现)。
代码示例:
01 |
Runnable checkRunnable = new Runnable() { |
04 |
PayTask payTask = new PayTask(DemoActivity. this ); |
05 |
boolean isExist = payTask.checkAccountIfExist(); |
06 |
Message msg = new Message(); |
07 |
msg.what = SDK_CHECK_FLAG; |
09 |
mHandler.sendMessage(msg); |
12 |
Thread checkThread = new Thread(checkRunnable); |
9.获取当前SDK版本号
调用PayTask对象的getVersion()方法查询。
代码示例:
1 |
PayTask payTask = new PayTask(activity); |
2 |
String version = payTask.getVersion(); |
3 |
点击文章开头给的网址,直接点击“在线申请”,目的是为了获得PID与密钥,到时候你好按照文档配置你的PayDemoActivity.java文件。 |
5 |
申请要上传你的apk或者产品说明文档,我用的是产品说明文档,里面要包括产品说明(最好有产品截图,我第一次没截图直接没成功)、接口使用场景、资费说明。 |
7 |
申请成功后按文档上说明,做几个密钥什么的哈哈,上传你做的公钥。然后PayDemoActivity.java里面配置。这里要注意的是,String RSA_PRIVATE=“”;这里要用PKCS8格式的私钥。 |
9 |
好了,android集成支付宝接口我认为比较快的过程就是这些了,祝你配置成功! |