作为独立开发者产品需要收款是非常麻烦的,注册公司维护成本太高,市面上各种收款工具要么手续费太高,要么到账很慢,体验很不好。

看到 「BufPay.com 个人收款」 这个收款工具,挺有意思的。原理是监控手机微信、支付宝的二维码扫码支付到账通知并回调开发者应用,通知开发者应用订单支付结果。

「BufPay.com 个人收款」的优点是个人支付宝、微信就可以收款,不用签约,不用公司资质,并且费率非常低,接入速度非常快。一般人一个下午就可以搞定。

这样用自己的微信和支付宝收款二维码就可以用来给自己的产品收款了,收到款后「BufPay.com 个人收款」 会有回调。

收款即时到账, 非常安全靠谱,费率也挺低的, 最低千分之一。下面我们就来看怎么把「BufPay.com 个人收款」接入到我们的产品中。

根据 「BufPay.com 个人收款」的 接口文档 接口非常简单,只有两个接口,第一个是发起支付请求,一个是支付结果查询请求,如果发起请求的时候是使用 BufPay 的默认支付页面的话,第二个支付查询接口都可以不用要。

注意: 在接入之前,先需要用一个闲置的 Android 手机安装 Bufpay 的监控 App 哦,安装步骤

接口地址:https://bufpay.com/api/pay/aid 这个地址在用户后台的配置页面

调用方法:POST

调用参数:

- name, 必填, 订单销售商品名称

- pay_type, 必填, 支付方式(可选alipay/wechat)

- price, 必填, 订单价格

- order_id, 必填, 订单号

- order_uid, 选填, 订单购买用户(建议设置为购买用户编号,便于后续对账)

- notify_url, 必填, 支付城后回调地址

- return_url, 选填, 支付城后前台跳转地址

- sign, 必填, 将参数按 name + pay_type + price + order_id + order_uid + notify_url + return_url + app secret 顺序拼接后 MD5

注意:接口默认直接跳转支付页面,如果 api 后面加 ?format=json 那么返回结果就是 json 格式的,需要开发者自己展示付款二维码

json 格式接口返回:

{

    "status": "ok",

    "aoid": "cad5076f55834f5fadddcfc018cc4068",

    "pay_type": "wechat",

    "price": "35.00",

    "qr_price": "",

    "qr": "wxp://f2f0-vFHHDCw3L4kPne1JzXyQ0nO0QKpQK2e"

    "qr_img": "......Bxiv/2Q==",

    "expires_in": 270,

    "return_url": "http://v2ex.com/bufpay_return",

}

- status, 付款请求结果(只有为 ok 的时候才有其他的值)

- aoid, bufpay平台订单唯一标示可用于查询订单状态

- pay_type, 支付类型 alipay/wechat

- price, 订单价格

- qr_price, 支付二维码的金额,如果为空表示使用的是不固定金额二维码,具体金额需要用户输入

- qr, 支付二维码内容

- qr_img, 支付二维码图片 base64 格式

- expire_in, 支付二维码剩余有效秒数

- return_url, 支付成功跳转地址

错误代码:

- {"status": "sign_error"}, 签名错误

- {"status": "order_payed"}, 订单已支付

- {"status": "order_expire"}, 订单已过期

- {"status": "qr_limit"}, 支付二维码不足

这个是 Python 的签名函数

import hashlib

def sign(*p):
return hashlib.md5(u''.join(p).encode('utf8')).hexdigest().lower() sign(
u'内容订阅一年期',
'wechat',
'50.00',
'',
'hi@sideidea.com',
'http://sideidea.com/bufpay_notify',
'http://sideidea.com',
'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' #app secret
)

下面用 Python 写个完整的Demo

#!/usr/bin/env python
#coding: utf8 import requests
import json
import hashlib def sign(*p):
return hashlib.md5(u''.join(p).encode('utf8')).hexdigest().lower() def pay():
resp = requests.post(
'https://bufpay.com/api/pay/2?format=json',
data={
'name': u'内容订阅一年期',
'pay_type': 'wechat',
'price': '50.00',
'order_id': '',
'order_uid': 'hi@sideidea.com',
'notify_url': 'http://sideidea.com/bufpay_notify',
'return_url': 'http://sideidea.com',
'sign': sign(
u'内容订阅一年期',
'wechat',
'50.00',
'',
'hi@sideidea.com',
'http://sideidea.com/bufpay_notify',
'http://sideidea.com',
'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx' #app secret
)
}
)
return json.loads(resp.text) def query(aoid):
resp = requests.get('https://bufpay.com/api/query/' + aoid)
return json.loads(resp.text) if __name__ == '__main__':
resp = pay()
print resp
print query(resp['aoid'])

怎么样?是不是很简单, 哦对了, 在正式接入之前,还需要去 BufPay.com 的后台,配置页面配置一下自己的收款二维码

接下来就可以收款啦。。。

BufPay.com 个人收款接口 接入步骤的更多相关文章

  1. 个人免签即时到账收款接口 bufpay.com 支持多账号收款

    有很多 bufpay 的用户反馈,单个手机收款有些时候不太方便,切换手机太麻烦:或者是营业额比较多,希望分摊到多个账号上面. 基于以上的问题,bufpay 开发了多手机收款的功能:每个收款的手机安装 ...

  2. PC软件/web网站/小程序/手机APP产品如何增加个人收款接口

    接入前准备 通过 XorPay 注册个人收款接口,原理是帮助你签约支付宝和微信(不需要营业执照)支持个人支付宝和个人微信支付接口,大概几分钟可以开通,开通后即可永久使用 PC 网站接入 效果:用户点击 ...

  3. 微信SDK开发——接口接入

    园子里面很多关于微信接口开发的文章,Github也一堆的开源代码. 官方文档地址:http://mp.weixin.qq.com/wiki/home/index.html 接下来主要以代码为主,接口说 ...

  4. jdbc执行Statement接口的步骤

    jdbc执行Statement接口的步骤如下: 1)驱动注册程序: Class.forName(com.mysql.jdbc.Driver); 2)获取连接对象: Connection conn = ...

  5. ios的Ping++支付接入步骤-b

    1. Client 发送支付要素给 Server 2. Server 发送支付请求并将返回的支付凭据传给 Client 3. Client 调起支付控件完成支付 4. 渠道同步返回支付结果给 Clie ...

  6. 个人免签收款接口 bufpay.com 支持限额设置

    有产品希望收款分布到不同的手机,每个当手机达到某一限额以后就停止改手机的收款. bufpay.com 近期上线了收款限额设置功能,配置界面如下图: 每个手机微信或支付宝可以单独设置每日限额,如果该手机 ...

  7. xddpay.com 个人支付接口接入流程

    作为一个独立开发者产品需要支付接口是挺麻烦的,支付宝微信都不对个人开放,注册公司维护成本太高,市面上各种收款工具要么手续费太高,要么到账很慢,体验很不好. 看到 「小叮当支付」 这个收款工具,挺有意思 ...

  8. 淘宝API学习之道:淘宝TOP之API接口接入教程

    作为一个中小型站点开发人员,淘宝API的开放大大缩短了站点的开发周期和运作效率.面对海量的数据.开发人员仅仅要细致阅读开发文档,熟悉对应的接口,就能够把数据导入自己的站点,这样就不必望洋兴叹了. 眼下 ...

  9. 微信App支付接入步骤&支付中前后端交互流程

    最近对微信App支付(App端集成微信支付SDK)申请步骤,以及终端在进行微信支付时商户App.商户Server.微信App.微信支付Server的交互流程进行了简单了解.这篇文章应该算是学习笔记,分 ...

随机推荐

  1. Python-常用模块2

    今天我们继续来看模块的那些事儿 一.os模块 所有和操作系统相关内容都在os模块 os.makedirs('dirname1/dirname2') 可生成多层递归目录 os.removedirs('d ...

  2. iview中事件获取自定义参数

    前提:页面渲染多个cascaer组件,根据不同cascader组件选中的值,加载不同内容 解决:此时需要解决的问题是,在on-change事件中返回index索引使用如下格式: <Cascade ...

  3. ActiveMQ相关:

    MQ连接字符串:failover:tcp://127.0.0.1:61616 管理地址:http://localhost:8161/admin/

  4. Android PopupWindow显示位置设置

    当点击某个按钮并弹出PopupWindow时,PopupWindow左下角默认与按钮对齐,但是如果PopupWindow是下图的那样,会发 生错位的情况,尤其是不同尺寸的平板上,那错位错的不是一般的不 ...

  5. IIFE

    一.IIFE IIFE:immediately-invoked function expression,即时调用函数表达式. 如果一个函数,在定义的时候,就想直接调用它,就是一个IIFE. 函数执行方 ...

  6. 利用NVM在系统中维护多个版本的nodejs

      0. 背景 开发时可能同时进行多个项目,而这些项目所依赖的node版本又不是一样的.比如我现在的angular项目采用的node是8.9.3版本,而vue项目的vue-cli则依赖更高.由于ang ...

  7. 使用jQuery操作input的value值

    表单控件是我们的重中之重,因为一旦牵扯到数据交互,离不开form表单的使用,比如用户的注册登录功能等 那么通过上节知识点我们了解到,我们在使用jquery方法操作表单控件的方法: $(selector ...

  8. QT组件与std性能

    https://blog.csdn.net/zy19940906/article/details/53694909

  9. laravel where筛选会判断类型吗?

    laravel where筛选会判断类型吗? laravel where筛选会判断类型吗? laravel where筛选会判断类型吗? 这个说会判断不对,说不会判断也不对. 当字符串'1'和数值1是 ...

  10. Doing Research Needs Efforts

    What is research?   From YouTube Video or baiduyun Links What does not? spend many hours before you ...