美文网首页web支付功能android新手
webview页面中调用原生支付宝APP支付

webview页面中调用原生支付宝APP支付

作者: _Sisyphus | 来源:发表于2017-08-28 16:43 被阅读0次

网上方案,经测试可行

//启动支付宝,并跳转到付款页面
if (url.contains("platformapi/startapp")) {
    startAlipayActivity(url);
}

private void startAlipayActivity(String url) {
    Intent intent;
    try {
        intent = Intent.parseUri(url,
                Intent.URI_INTENT_SCHEME);
        intent.addCategory(Intent.CATEGORY_BROWSABLE);
        intent.setComponent(null);
        startActivity(intent);
        LogUtils.d("alipay", "start intent = " + intent.toString());
    } catch (Exception e) {
        e.printStackTrace();
        LogUtils.d("alipay", "error " + e.getMessage());
    }
}

详情看这个作者 http://www.jianshu.com/p/e335333574a8

该方案通过拦截支付宝支付uri的方式,调用支付宝app付款。但是有一个问题,支付完成之后没有回调,你不知道什么时候成功,完成之后停留在之前页面,体验有点差。通过https://open.alipay.com/support/supportCenter.htm 支付宝技术客服提供的方案,不得不说,阿里的技术客服还是很到位的,比微信文档和技术客服友好太多,为支付宝点赞~

好了,以下是具体步骤:

  • 下载Demo
    http://p.tb.cn/rmsportal_6680_WS_APP_PAY_SDK_BASE_2.0.zip

  • 导入开发资源

    1. 将alipaySdk-xxxxxxxx.jar包放入商户应用工程的libs目录下。
    2. 将libs目录下的alipaySDK-xxxxxxxx.jar导入
  • 修改Manifest

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

      <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>
      
    2. 权限声明:

      <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"/>
      
    3. 添加混淆规则

      -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 *;}
      -keep class com.alipay.sdk.app.H5PayCallback {
            <fields>;
            <methods>;
        }
      -keep class com.alipay.android.phone.mrpc.core.** { *; }
      -keep class com.alipay.apmobilesecuritysdk.** { *; }
      -keep class com.alipay.mobile.framework.service.annotation.** { *; }
      -keep class com.alipay.mobilesecuritysdk.face.** { *; }
      -keep class com.alipay.tscenter.biz.rpc.** { *; }
      -keep class org.json.alipay.** { *; }
      -keep class com.alipay.tscenter.** { *; }
      -keep class com.ta.utdid2.** { *;}
      -keep class com.ut.device.** { *;}
      

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

如何实现手机网站转Native支付?

步骤一: 在接入方App中拦截H5的URL;
步骤二: 调用新增拦截+支付二合一接口(payInterceptorWithUrl...)进行URL拦截及支付转化;具体参照如下接口说明。

具体代码

     mWebView.setWebViewClient(new android.webkit.WebViewClient() {

         public boolean shouldOverrideUrlLoading(final WebView view, String url) {

             if (!(url.startsWith("http") || url.startsWith("https"))) {
                 return true;
             }

             /**
              * 推荐采用的新的二合一接口(payInterceptorWithUrl),只需调用一次
              */
             final PayTask task = new PayTask(CommonWebActivity.this);

             /**
              * 支付宝H5支付URL拦截器,完成拦截及支付方式转化
              * 本接口首先是个拦截器,拦截支付宝H5支付URL;其次是个支付方式转化器,将手机网站支付方式转化为APP支付方式。
              *
              * @param h5PayUrl          待过滤拦截的 URL  手机网站支付的请求URL
              * @param isShowPayLoading  是否出现loading
              * @param callback          异步回调接口
              */

             /**
              * 返回值
              * 1.   如果h5PayUrl是有效的支付宝H5支付URL,则说明拦截转化成功,返回ture,商户容器无需再加载该URL;
              * 2.   如果是无效的,则返回false,商户容器需要继续加载该URL。
              */
             boolean isIntercepted = task.payInterceptorWithUrl(url, true, new H5PayCallback() {

                 @Override
                 public void onPayResult(final H5PayResultModel result) {

                     final String url = result.getReturnUrl();
                     String resultCode = result.getResultCode();

                     if (!TextUtils.isEmpty(url)) {

                         CommonWebActivity.this.runOnUiThread(new Runnable() {
                             @Override
                             public void run() {
                                 view.loadUrl(url);
                             }
                         });
                     }
                     //这里返回支付结果,根据resultCode 回调 返回码 做不同处理 
                     if (TextUtils.equals(resultCode, "9000")) {
                         ToastUtils.showToast("支付成功");
                         startActivity(FreeOrderActivity.class, true);        //跳转支付成功页面
                     }
                 }
             });

             /**
              * 判断是否成功拦截
              * 若成功拦截,则无需继续加载该URL;否则继续加载
              */
             if (!isIntercepted)
                 view.loadUrl(url);
             return true;

         }
     });

以上方案基于支付宝最新支付SDK,alipaySdk-20170725,详细请查看支付宝文档,真的很清晰~ 手机网站支付转Native支付

相关文章

网友评论

    本文标题:webview页面中调用原生支付宝APP支付

    本文链接:https://www.haomeiwen.com/subject/clsgdxtx.html