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

参考代码请点击这里

结束语


相关文章
|
18天前
|
ARouter IDE 开发工具
Android面试题之App的启动流程和启动速度优化
App启动流程概括: 当用户点击App图标,Launcher通过Binder IPC请求system_server启动Activity。system_server指示Zygote fork新进程,接着App进程向system_server申请启动Activity。经过Binder通信,Activity创建并回调生命周期方法。启动状态分为冷启动、温启动和热启动,其中冷启动耗时最长。优化技巧包括异步初始化、避免主线程I/O、类加载优化和简化布局。
32 3
Android面试题之App的启动流程和启动速度优化
|
3天前
|
机器学习/深度学习 人工智能 文字识别
文本,文字扫描01,OCR文本识别技术展示,一个安卓App,一个简单的设计,文字识别可以应用于人工智能,机器学习,车牌识别,身份证识别,银行卡识别,PaddleOCR+SpringBoot+Andr
文本,文字扫描01,OCR文本识别技术展示,一个安卓App,一个简单的设计,文字识别可以应用于人工智能,机器学习,车牌识别,身份证识别,银行卡识别,PaddleOCR+SpringBoot+Andr
|
3天前
|
Android开发
Android面试题经典之如何全局替换App的字体
在Android应用中替换字体有全局和局部方法。全局替换涉及在`Application`的`onCreate`中设置自定义字体,并创建新主题。局部替换则可在布局中通过`ResourcesCompat.getFont()`加载字体文件并应用于`TextView`。
15 2
|
4天前
|
监控 关系型数据库 分布式数据库
PolarDB开源项目成熟,强调插件开发与第三方工具集成,打造丰富生态。
【7月更文挑战第3天】PolarDB开源项目成熟,强调插件开发与第三方工具集成,打造丰富生态。插件开发涉及需求分析、接口设计、编码、测试和文档撰写。示例展示了性能监控插件的Go代码实现。此外,与DMS的数据迁移工具及Prometheus+Grafana监控系统的集成示例,展示了其易用性。PolarDB通过开放接口鼓励开发者参与生态建设,共同推动数据库技术进步。
15 1
|
16天前
|
缓存 JSON 网络协议
Android面试题:App性能优化之电量优化和网络优化
这篇文章讨论了Android应用的电量和网络优化。电量优化涉及Doze和Standby模式,其中应用可能需要通过用户白名单或电池广播来适应限制。Battery Historian和Android Studio的Energy Profile是电量分析工具。建议减少不必要的操作,延迟非关键任务,合并网络请求。网络优化包括HTTPDNS减少DNS解析延迟,Keep-Alive复用连接,HTTP/2实现多路复用,以及使用protobuf和gzip压缩数据。其他策略如使用WebP图像格式,按网络质量提供不同分辨率的图片,以及启用HTTP缓存也是有效手段。
36 9
|
17天前
|
XML 监控 安全
Android App性能优化之卡顿监控和卡顿优化
本文探讨了Android应用的卡顿优化,重点在于布局优化。建议包括将耗时操作移到后台、使用ViewPager2实现懒加载、减少布局嵌套并利用merge标签、使用ViewStub减少资源消耗,以及通过Layout Inspector和GPU过度绘制检测来优化。推荐使用AsyncLayoutInflater异步加载布局,但需注意线程安全和不支持特性。卡顿监控方面,提到了通过Looper、ChoreographerHelper、adb命令及第三方工具如systrace和BlockCanary。总结了Choreographer基于掉帧计算和BlockCanary基于Looper监控的原理。
23 3
|
20天前
|
安全 JavaScript 前端开发
kotlin开发安卓app,JetPack Compose框架,给webview新增一个按钮,点击刷新网页
在Kotlin中开发Android应用,使用Jetpack Compose框架时,可以通过添加一个按钮到TopAppBar来实现WebView页面的刷新功能。按钮位于右上角,点击后调用`webViewState?.reload()`来刷新网页内容。以下是代码摘要:
|
25天前
|
缓存 Android开发 Kotlin
【安卓app开发】kotlin Jetpack Compose框架 | 先用OKhttp下载远程音频文件再使用ExoPlayer播放
使用 Kotlin 的 Jetpack Compose 开发安卓应用时,可以结合 OkHttp 下载远程音频文件和 ExoPlayer 进行播放。在 `build.gradle` 添加相关依赖后,示例代码展示了如何下载音频并用 ExoPlayer 播放。代码包括添加依赖、下载文件、播放文件及简单的 Compose UI。注意,示例未包含完整错误处理和资源释放,实际应用需补充这些内容。
|
2天前
|
XML Java 数据格式
支付系统----微信支付20---创建案例项目--集成Mybatis-plus的补充,target下只有接口的编译文件,xml文件了,添加日志的写法
支付系统----微信支付20---创建案例项目--集成Mybatis-plus的补充,target下只有接口的编译文件,xml文件了,添加日志的写法
|
26天前
|
存储 Android开发 Kotlin
开发安卓app OKhttp下载后使用MediaPlayer播放
在Android Jetpack Compose应用程序中,要使用OkHttp下载远程音频文件并在本地播放,你需要完成以下几个步骤: 1. **添加依赖**:确保`build.gradle`文件包含OkHttp和Jetpack Compose的相关依赖。 2. **下载逻辑**:创建一个`suspend`函数,使用OkHttp发起网络请求下载音频文件到本地。 3. **播放逻辑**:利用`MediaPlayer`管理音频播放状态。 4. **Compose UI**:构建用户界面,包含下载和播放音频的按钮。