Android开发:使用EasyPay打造全能移动支付框架
来源:互联网 发布:如何文本安装linux 编辑:程序博客网 时间:2024/06/04 18:35
- 前言
- EasyPay是什么
- 为什么要用EasyPay
- EasyPay和微信支付等移动支付SDK的区别
- EasyPay和其他第三方聚合支付的区别
- EasyPay怎么用
- 开发者需要做什么
- 开发者能做什么
- 后记
- EasyPay项目地址
- 附录
- 移动支付开发博文
- 移动支付的流程
- EasyPay的回调errCode错误码列表
前言
在这之前,笔者发布了两篇移动app支付相关博文,得到一些关注,但是由于博文中代码零碎,有些读者私信博主,以及加笔者qq咨询相关问题。考虑到这些,笔者把之前项目中的支付相关代码从业务中剥离出来,重构,形成了现在的EasyPay。
EasyPay项目地址:https://github.com/xiong-it/EasyPay
本文原创作者:MichaelX,博客链接:http://blog.csdn.net/xiong_it 转载请注明来源,谢谢合作!
EasyPay是什么
EasyPay旨在帮助Android开发者快速集成接入移动支付SDK,其中包括主流的微信APP支付,支付宝APP支付,银联支付(开发中)。
为什么要用EasyPay
EasyPay和微信支付等移动支付SDK的区别
EasyPay是一个开源的聚合支付可定制化框架,目前已集成微信APP支付,支付宝APP支付SDK。银联支付(开发中)。
Android开发者只需要简单调用EasyPay的几行代码,即可调起支付客户端,完成支付流程,得到支付结果。
EasyPay宗旨:简单,易用,可扩展。
EasyPay和其他第三方聚合支付的区别
第三方聚合支付,如知名的Ping++,需要同时接入其Server端SDK和Client端SDK,使接入企业面临风险:
1、信息泄露风险
2、支付集成服务商提供服务跟不上商户业务发展需要的风险
3、支付集成服务商系统稳定性、安全性的风险
4、资金安全风险
—知乎:《使用第三方支付集成有何风险,例如 Beecloud 或者 Ping++?》
此外,天下没有免费的午餐,第三方聚合支付平台一般需要收取5%~15%左右的手续费等各种服务费用,使得接入企业收益受损。
而使用开源的EasyPay,代码透明,与Server端无关,Android开发者只需要根据自己需求对EasyPay进行个性化定制,即可打造一个支付平台齐全的无风险支付框架。但是客观的讲,这同时也是EasyPay的短板,它只简化了APP端开发者的调用工作,Server端工作人员仍需要按照移动支付第三方平台的SDK文档进行开发。
如果觉得EasyPay对你有帮助,你付出的仅仅是一个点赞,或者一个star或者fork,如果不满意,请帮忙提issue指出,而不是5%-15%左右的手续费等各种服务费用。
通过阅读EasyPay源码,你可以知道移动支付的流程是怎样的:
APP->APP服务器->支付平台后台服务器->APP服务器->APP->支付客户端->APP
通过扩展EasyPay,你可以较快的搭建一个私有的功能完善的支付框架。
EasyPay怎么用
用户场景:
APP用户选择一个价格为666元的商品:”皮皮虾”,商品描述:”此商品属性过于强大,难以调教,一般人切勿轻易购买,吼吼!”,然后用户进入收款台,选择了微信支付。
好勒,皮皮虾,咱们走!此处省略:皮皮虾,咱们走.jpg
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
开发者调用步骤:
1. 通过建造者模式创建支付参数PayParams实例并传入EasyPay的创建方法中
2. 传入支付结果回调接口实例得到支付结果回调
假如你的app中每个商品有id,请求服务器时可以用商品id代替价格,让服务器自己去查询价格,防止客户端中的商品价格被恶意修改。
开发者需要做什么
上一节是开发者在Activity/Fragment之类的View层调用代码,除此之外,开发者还需要做一些少量的额外的工作。
需要导入EasyPay/library源码依赖并修改app客户端相关文件
- 下载EasyPay源码到本地
- 在Android Studio中打开你的app项目
- Android Studio左上角File->New->Import Module->… 选择library目录导入,app会自动依赖library这个module
- 复制
EasyPay/sample
下wxapi
包到你的包路径下,假如你的包名:com.app.payclient
,那么wxapi包应该放在payclient包下面 - 按照
EasyPay/sample
的AndroidMenifest.xml
文件修改你的清单文件 - 按照
EasyPay/sample
的proguard-rules.pro
修改你的混淆文件
需要修改服务器请求路径和请求字段和返回的json解析
由于笔者并不知道你的服务器地址和请求路径及字段和返回json格式,所以你只需要动动小手改下library中的相应代码即可。
假如你的支付api接口文档如下:
host:http://api.yourhost.com/
路径:pay/
请求方式为:Http,get
请求需要的参数字段为:
假设你想使用的网络框架是Retrofit2。那么network/NetwrokClientInterf
的实现类RetrofitClient需要做如下修改:
由于Retrofit请求一般需要借助一个xxService类,那么实际修改的是xxService类,以EasyPay源码中的network/PrePayInfoService
为例,它需要修改成如下:
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
当网络连接使用其他框架时,需要在NetworkClientInterf对应的实现类中修改路径及请求参数字段。
假如当前用户使用了微信支付,当服务器返回的数据格式如下时:
假如json的格式如下:
以你们server端人员给出的实际json字段来修改pay/PrePayInfo
。
当为其他支付方式时,也需要在对应的PayStragetyInterf支付实现策略类中修改解析。
library源码中需要修改的地方都打上了TODO
标签,导入Android Studio后,如下图方式查看:
开发者能做什么
EasyPay目前实现了微信,支付宝app支付,如果你觉得支付逻辑代码不OK?完全可以通过实现PayStragetyInterf来完全重写一个自己的微信,支付宝支付策略。
EasyPay支持的平台(微信,支付宝,银联)不在你的需求范围内?可以通过实现PayStragetyInterf来扩展一种支付方式。
EasyPay支持的网络框架(HttpUrlConnection,OkHttp3(前两者严格意义上不属于框架),Volley,Retrofit2)用的不顺手?那就自己撸一个NetworkClientInterf接口的实现类来实现自己的网络请求客户端。
其他,还是不够满足你的需求,欢迎提出issue,或者加入一起开发,完善该repo,打造一个更加优秀的EasyPay。
本文原创作者:MichaelX,博客地址:http://blog.csdn.net/xiong_it.转载请注明来源
欢迎光临:MichaelX’s Blog
后记
EasyPay算笔者的第一个正式的开源项目吧,受益于开源社区,也希望为开源奉献一点力量,帮助一些开发者快速打造一个无风险的功能完备的支付框架。
EasyPay项目地址
https://github.com/xiong-it/EasyPay
附录
移动支付开发博文
微信支付:Android App支付系列(一):微信支付接入详细指南
支付宝:Android App支付系列(二):支付宝SDK接入详细指南
移动支付的流程
- APP将商品信息post给APP服务器
- APP服务器携带商品信息和一些其他信息请求支付平台服务器,获取预支付订单信息
- APP服务器得到预支付订单信息并返给APP
- APP解析预支付订单信息
- APP利用解析后的预支付信息调起支付客户端(微信,支付宝,等)
- 支付客户端将支付结果返给APP
- APP向用户展示支付结果
EasyPay的回调errCode错误码列表
- Android开发:使用EasyPay打造全能移动支付框架
- Android开发:使用EasyPay打造全能移动支付框架
- Android开发 : 使用EasyPay打造全能移动支付框架
- EasyPay移动支付框架
- 第三方支付框架EasyPay
- android开发之全能多媒体开发框架Vitamio
- Android开发 接入支付宝移动支付
- Vitamio一款Android&iOS上的全能多媒体开发框架
- EasyPay(易支付),两分钟集成三种Android支付方式
- 全能多媒体开发框架Vitamio
- 全能多媒体开发框架Vitamio
- Vitamio-全能多媒体开发框架
- 高二学生开发全能语音助手,打造Android中文Siri
- MUI移动开发框架——微信支付(android部分)
- Android开发 打造自己的Annotation框架
- 支付宝移动支付开发
- 打造全能的WebViewActivity
- 移动开发支付宝
- Android屏幕适配终极手段
- leetcode-375 猜数游戏
- js修改form表单的action属性,commit提交后,再更改action属性。发现表单没有提交
- 快速Android开发系列网络篇之Retrofit
- @property使用详情
- Android开发:使用EasyPay打造全能移动支付框架
- nginx负载均衡的五种模式
- 排序算法之基数排序
- Failed to execute goal org.apache.maven.plugins
- MATLAB下的共轭转置与非共轭转置
- TextView多文本折叠/展开效果
- Spring的@PostConstruct与ApplicationContextAware冲突问题
- js eval替代方法学习笔记
- linux open files