利用Android Studio在App中集成第三方支付

简介: 利用Android Studio在App中集成第三方支付

觉得自己好久没有写博客了,看了一下时间,果然好久没写了。吓得我赶紧写篇博客压压惊。

第三方支付的选择

 目前主流的第三方支付平台,有以下几种:

  • 支付宝
  • 微信支付
  • 百度钱包
  • 网银支付
  • 第三方聚合支付

以上几种支付平台,除了第三方聚合支付以外,其他几个在使用时,都是需要公司信息的,这对一些个人开发者以及初学者就造成了一些困难,还好,有第三方聚合支付,它可以提供测试的接口给开发者,这里我们就用第三方聚合支付的测试接口进行付款。

 我知道的第三方聚合支付主要有:

  1. Ping++:https://pingxx.com
  2. Bmob : http://www.bmob.cn

这里,我用的是Ping++,至于Bmob大家可以自己研究,不过料想原理应该差不多。

使用前的准备工作

 在使用之前,我们需要到Ping++的官网完成注册,注册之后,就有了一个用于测试的Test Secret Key ,可以在使用者的企业设置下面发现Test Secret Key,如下图

20170625070938118.png

 我们可以在官网的首页,开发者中心下载集成的SDK。

开始集成

文件介绍

 下载SDK后,可以在~/pingpp-android/路径下发现一个lib文件夹,打开后还有三个文件夹,分别为一下三个文件夹

20170625072210530.png

这里我们只需要用到前两就行了,第一个文件夹是集成百度钱包需要用到的,第二个是集成其他的支付方式需要用到的。

集成方式

 在Android Studio集成第三方SDK有两种方式,第一种就是直接在自己的app所在的文件中进行集成,第二种则是新建一个性质为Library的Module,将第三方的SDK放在新建的Module中,然后在自己的app中引入。

 为了不让自己的App过于臃肿以及以后修改方便,这里采用第二种集成方式。我们可以按一下步骤在Android Studio新建一个Module

20170625074814979.png

20170625075004670.png

这样我们就建立了一个性质为Library的Module。

 下面我们需要做的工作就是把pingpp文件家中的东西搬运过来。

注意:这里要把文件结构试图改为Project视图,不然看不见libs文件夹。切换方式如下

20170625080959995.png

我们把 pingpp/libs下的jar包放进libs目录下,放进去后应该是这种结构

20170625081145615.png

这里我们需要在Android Studio中新建一个jniLibs文件夹,新建jniLibs文件夹步骤如下图

20170625081647746.png

这种方式新建以后是一个名为cpp的文件夹,我们只要把它的名字改为jniLibs即可,然后把/pingpp/libs/文件夹中除了jar文件,其他的文件夹放进jniLibs文件夹即可就行了,放进后的文件结构应该如下图所示

20170625082206578.png

这里我们只要将以下四个文件夹中的内容搬运进来就行了,必要时再替换一下清单文件。

20170625082750380.png

添加依赖

 我们只要把刚才新建的module引入到自己的app中就行了,在自己的app上右键选中下图的选项

20170625083305273.png

打开一下界面选中如下选项(红框内的),把新建的Module添加进去就行了。

20170625083733754.png

最好,我们把新建的Module中Gradle中引用的以下两个依赖删除,因为在自己的app已经引入了。

compile ‘com.android.support:appcompat-v7:26.+’

testCompile ‘junit:junit:4.12’

添加bdwallet_pay_sdk也按以上方式进行即可。

在清单文件中添加权限及Activity

添加权限及Activity可按官方指导文件进行操作。

开始使用

 以下代码是调用第三方支付

class PaymentTask extends AsyncTask<PaymentRequest, Void, String> {
        @Override
        protected void onPreExecute() {
            //按键点击之后的禁用,防止重复点击
            mCreateOrder.setEnabled(false);
        }
        @Override
        protected String doInBackground(PaymentRequest... pr) {
            PaymentRequest paymentRequest = pr[0];
            String data = null;
            try {
                JSONObject object = new JSONObject();
                object.put("channel", paymentRequest.channel);
                object.put("amount", paymentRequest.amount);
                String json = object.toString();
                //向Your Ping++ Server SDK请求数据
                data = postJson(CHARGE_URL, json);
            } catch (Exception e) {
                e.printStackTrace();
            }
            return data;
        }
        /**
         * 获取charge
         *
         * @param urlStr charge_url
         * @param json   获取charge的传参
         * @return charge
         * @throws IOException
         */
        private String postJson(String urlStr, String json) throws IOException {
            URL url = new URL(urlStr);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setConnectTimeout(8000);
            conn.setReadTimeout(8000);
            conn.setRequestMethod("POST");
            conn.setRequestProperty("Content-Type", "application/json");
            conn.setDoOutput(true);
            conn.setDoInput(true);
            conn.getOutputStream().write(json.getBytes());
            if (conn.getResponseCode() == 200) {
                BufferedReader
                        reader = new BufferedReader(new InputStreamReader(conn.getInputStream(), "utf-8"));
                StringBuilder response = new StringBuilder();
                String line;
                while ((line = reader.readLine()) != null) {
                    response.append(line);
                }
                return response.toString();
            }
            return null;
        }
        /**
         * 获得服务端的charge,调用ping++ sdk。
         */
        @Override
        protected void onPostExecute(String data) {
            if (null == data) {
                showMsg("请求出错", "请检查URL", "URL无法获取charge");
                return;
            }
            Log.d("charge", data);
            //除QQ钱包外,其他渠道调起支付方式:
            //参数一:Activity  当前调起支付的Activity
            //参数二:data  获取到的charge或order的JSON字符串
            Pingpp.createPayment(MainActivity.this, data);
            //QQ钱包调用方式
            //参数一:Activity  当前调起支付的Activity
            //参数二:data  获取到的charge或order的JSON字符串
            //参数三:“qwalletXXXXXXX”需与AndroidManifest.xml中的scheme值一致
            //Pingpp.createPayment(ClientSDKActivity.this, data, "qwalletXXXXXXX");
        }
    }

参考代码请点击这里

结束语


相关文章
|
3月前
|
前端开发 Linux API
无缝融入,即刻智能[一]:Dify-LLM大模型平台,零编码集成嵌入第三方系统,42K+星标见证专属智能方案
【8月更文挑战第3天】无缝融入,即刻智能[一]:Dify-LLM大模型平台,零编码集成嵌入第三方系统,42K+星标见证专属智能方案
无缝融入,即刻智能[一]:Dify-LLM大模型平台,零编码集成嵌入第三方系统,42K+星标见证专属智能方案
|
3月前
【Azure App Service】列举为App Service集成虚拟网络(VNET)操作时所需要的最小权限
【Azure App Service】列举为App Service集成虚拟网络(VNET)操作时所需要的最小权限
|
3月前
|
JavaScript Linux API
【Azure 应用服务】NodeJS Express + MSAL 应用实现AAD集成登录并部署在App Service Linux环境中的实现步骤
【Azure 应用服务】NodeJS Express + MSAL 应用实现AAD集成登录并部署在App Service Linux环境中的实现步骤
|
3月前
【Azure Function】Function App和Powershell 集成问题, 如何安装PowerShell的依赖模块
【Azure Function】Function App和Powershell 集成问题, 如何安装PowerShell的依赖模块
|
3月前
|
域名解析 网络协议 API
【Azure 应用服务】App Service与APIM同时集成到同一个虚拟网络后,如何通过内网访问内部VNET的APIM呢?
【Azure 应用服务】App Service与APIM同时集成到同一个虚拟网络后,如何通过内网访问内部VNET的APIM呢?
|
4月前
|
JSON API 数据格式
App Inventor 2 天气预报App开发 - 第三方API接入的通用方法
通过调用第三方天气api,填入必要的参数,通过Web客户端请求url。返回json格式的数据结果,使用AppInventor2解析json结果,显示到App上即可。
142 5
|
3月前
|
移动开发 前端开发 JavaScript
|
4月前
|
前端开发 API Android开发
|
4月前
|
监控 安全 Java
在Java中集成第三方API调用的最佳实践
在Java中集成第三方API调用的最佳实践
|
4月前
|
监控 关系型数据库 分布式数据库
PolarDB开源项目成熟,强调插件开发与第三方工具集成,打造丰富生态。
【7月更文挑战第3天】PolarDB开源项目成熟,强调插件开发与第三方工具集成,打造丰富生态。插件开发涉及需求分析、接口设计、编码、测试和文档撰写。示例展示了性能监控插件的Go代码实现。此外,与DMS的数据迁移工具及Prometheus+Grafana监控系统的集成示例,展示了其易用性。PolarDB通过开放接口鼓励开发者参与生态建设,共同推动数据库技术进步。
70 1
下一篇
无影云桌面