Alipay, China's leading third-party online payment solutionAlipay, China's leading third-party online payment solutionDOCS

      Android

      #导入开发资源

      1、将alipaySDK-<日期>.jar包放入商户应用工程的libs目录下,如下图。

      Android

      2、进入商户应用工程的Java Build Path,将libs目录下的alipaySDK-<日期>.jar导入,如下图。

      Android

      3、选中Order and Export,勾选alipaySDK-<日期>.jar,如下图。

      Android

      #修改 Manifest

      在商户应用工程的AndroidManifest.xml文件里面添加声明:

      copy
      <activity
                  android:name="com.alipay.sdk.app.H5PayActivity"
                  android:configChanges="orientation|keyboardHidden|navigation"
                  android:exported="false"
                  android:screenOrientation="behind" >
      </activity>
      <activity
                  android:name="com.alipay.sdk.auth.AuthActivity"
                  android:configChanges="orientation|keyboardHidden|navigation"
                  android:exported="false"
                  android:screenOrientation="behind" >
       </activity>

      和权限声明:

      copy
      <uses-permission android:name="android.permission.INTERNET" />
      <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
      <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
      <uses-permission android:name="android.permission.READ_PHONE_STATE" />
      <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

      #添加混淆规则

      在商户应用工程的proguard-project.txt里添加以下相关规则:

      copy
      -libraryjars libs/alipaySDK-(Date).jar
       
      -keep class com.alipay.android.app.IAlixPay{*;}
      -keep class com.alipay.android.app.IAlixPay$Stub{*;}
      -keep class com.alipay.android.app.IRemoteServiceCallback{*;}
      -keep class com.alipay.android.app.IRemoteServiceCallback$Stub{*;}
      -keep class com.alipay.sdk.app.PayTask{ public *;}
      -keep class com.alipay.sdk.app.AuthTask{ public *;}

      至此,开发包开发资源导入完成。

      #订单数据生成

      在调用开发包支付时需要提交订单信息info,其中参数以key=”value”形式呈现,参数之间以“&”分隔,所有参数不可缺。

      #支付接口调用

      需要在新线程中调用支付接口。(可参考alipay_demo实现)

      获取PayTask支付对象调用支付(支付或者授权的行为需要在独立的非ui线程中执行),代码示例:

      copy
      final String orderInfo = info;   // 订单信息
       
              Runnable payRunnable = new Runnable() {
       
                  @Override
                  public void run() {
                      PayTask alipay = new PayTask(DemoActivity.this);
                      String result = alipay.pay(orderInfo,true);
       
                      Message msg = new Message();
                      msg.what = SDK_PAY_FLAG;
                      msg.obj = result;
                      mHandler.sendMessage(msg);
                  }
              };
                // 必须异步调用
              Thread payThread = new Thread(payRunnable);
              payThread.start();

      #支付结果获取和处理

      调用pay方法支付后,将通过2种途径获得支付结果:


      #同步返回

      商户应用客户端通过当前调用支付的Activity的Handler对象,通过它的回调函数获取支付结果。(可参考alipay_demo实现)

      代码示例

      copy
      private Handler mHandler = new Handler() {
          public void handleMessage(Message msg) {
              Result result = new Result((String) msg.obj);
              Toast.makeText(DemoActivity.this, result.getResult(),
                          Toast.LENGTH_LONG).show();
          };
      };


      #异步通知

      商户需要提供一个http协议的接口,包含在参数里传递给快捷支付,即notify_url。支付宝服务器在支付完成后,会以POST方式调用notify_url,以xml数据格式传输支付结果。

      #获取当前开发包版本号

      调用PayTask对象的getVersion()方法查询。

      代码示例:

      copy
      PayTask payTask = new PayTask(activity);
      String version = payTask.getVersion();