利用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");
        }
    }

参考代码请点击这里

结束语


目录
打赏
0
0
0
0
2
分享
相关文章
|
2月前
|
Android Studio的插件生态非常丰富
Android Studio的插件生态非常丰富
150 1
Android Studio支持多种操作系统
Android Studio支持多种操作系统
134 1
婚恋交友系统匹配功能 婚恋相亲软件实现定位 语音社交app红娘系统集成高德地图SDK
在婚恋交友系统中集成高德地图,可实现用户定位、导航及基于地理位置的匹配推荐等功能。具体步骤如下: 1. **注册账号**:访问高德开放平台,注册并创建应用。 2. **获取API Key**:记录API Key以备开发使用。 3. **集成SDK**:根据开发平台下载并集成高德地图SDK。 4. **配置功能**:实现定位、导航及基于位置的匹配推荐。 5. **注意事项**:保护用户隐私,确保API Key安全,定期更新地图数据,添加错误处理机制。 6. **测试优化**:完成集成后进行全面测试,并根据反馈优化功能。 通过以上步骤,提升用户体验,提供更便捷的服务。
【05】2025年1月首发完整版-篇幅较长-苹果app如何上架到app store完整流程·不借助第三方上架工具的情况下无需花钱但需仔细学习-优雅草央千澈详解关于APP签名以及分发-们最关心的一篇来了-IOS上架app
【05】2025年1月首发完整版-篇幅较长-苹果app如何上架到app store完整流程·不借助第三方上架工具的情况下无需花钱但需仔细学习-优雅草央千澈详解关于APP签名以及分发-们最关心的一篇来了-IOS上架app
155 75
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
app开发之安卓Android+苹果ios打包所有权限对应解释列表【长期更新】-以及默认打包自动添加权限列表和简化后的基本打包权限列表以uniapp为例-优雅草央千澈
Android Studio JNI 使用模板:c/cpp源文件的集成编译,快速上手
本文提供了一个Android Studio中JNI使用的模板,包括创建C/C++源文件、编辑CMakeLists.txt、编写JNI接口代码、配置build.gradle以及编译生成.so库的详细步骤,以帮助开发者快速上手Android平台的JNI开发和编译过程。
424 1
Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍
本文深入探讨了Flutter前端开发中的调试技巧与工具使用方法,涵盖调试的重要性、基本技巧如打印日志与断点调试、常用调试工具如Android Studio/VS Code调试器和Flutter Inspector的介绍,以及具体操作步骤、常见问题解决、高级调试技巧、团队协作中的调试应用和未来发展趋势,旨在帮助开发者提高调试效率,提升应用质量。
76 8
|
3月前
|
Android|集成 slf4j + logback 作为日志框架
做个简单改造,统一 Android APP 和 Java 后端项目打印日志的体验。
178 1
|
3月前
|
Android Studio中Terminal运行./gradlew clean build提示错误信息
遇到 `./gradlew clean build`命令执行出错时,首先应检查错误信息的具体内容,这通常会指向问题的根源。从权限、环境配置、依赖下载、版本兼容性到项目配置本身,逐一排查并应用相应的解决措施。记住,保持耐心,逐步解决问题,往往复杂问题都是由简单原因引起的。
461 2

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等