1. 集成准备
1.1 获得DBKEY和APPKEY
访问地址:https://pay.dangbei.com/open,注册并添加应用后,系统会自动生成DBKEY和APPKEY,也可在配置页面查看
1.2 下载SDK
1.3 配置
回调接口:请在后台配置页面填写回调接口;
支付方式:微信支付(必选)、支付宝(必选)、短信支付(非必选,金额只能为:1,2,4,5,6,8,10,12,15,20,25,30中的一个,目前仅支持电信运营商,请根据实际情况勾选)。
1.4 导入SDK
#1.4 .1 Eclipse导入SDK
将下载包中的aar文件解压,将解压得到的jar(最好将class.jar重命名,例如:libDangbeiPay**_v1.8.8.jar**)以及googlezxing-3.1.1.jar合并到本地工程libs子目录下;
在Eclipse中右键工程根目录,选择Properties -> Java Build Path -> Libraries,然后点击Add External JARs... 选择指向jar的路径,点击OK,即导入成功。(ADT17及以上不需要手动导入)。
#1.4 .2 Android Studio导入SDK
将下载包中的aar以及googlezxing-3.1.1.jar合并到本地工程libs子目录下,通过如下方式导入:
compile files('libs/googlezxing-3.1.1.jar')
compile(name:'edeviceid-1.0.9', ext:'aar')
compile(name:'libDangbeiPay', ext:'aar')
2. 基本功能集成
2.1 支付流程图
2.2 配置manifestxxxxxxxxxx
//连接互联网权限
2.3 DBKEY&APPKEY填写
将中的yourDBKEY替换为您的应用DBKEY,APPKEY同理,标签在application下,其他部分不需改动。配置文件如下所示xxxxxxxxxx
2.4 页面的调用x
Intent intent = new Intent();intent.setClass(MainActivity.this, DangBeiPayActivity.class);intent.putExtra("PID","String类型"); //商品id,最大长度为40个字符,必填intent.putExtra("Pname","String类型"); //商品名称,最大长度为60个字符,必填intent.putExtra("Pprice",“String类型"); //商品价格,必填intent.putExtra("Pdesc",“String类型"); //商品描述,最大长度为60个字符,必填
intent.putExtra("Pchannel",“String类型"); //渠道号
intent.putExtra("order","string类型"); //order为订单号,可选intent.putExtra("extra",“String类型"); //extra为备用字段,可选
startActivityForResult(intent, 0);
注意:渠道号配置可以在调用SDK传参的intent中设置,也可以在清单文件中meta-data节点中配置,必须以DANGBEI_CHANNEL命名,两者当中至少选一项,SDK会优先使用intent中设置的渠道参数,具体配置的渠道,请参照https://pay.dangbei.com/channel.php进行设置.
2.5 获得返回值的方法xxxxxxxxxx
protected void onActivityResult(intrequestCode, intresultCode, Intent data) {super.onActivityResult(requestCode, resultCode, data);if (requestCode == 0 &&resultCode == Activity.RESULT_OK) {Bundle bundle = data.getExtras();int back = bundle.getInt("back");//back为返回值
String Out_trade_no= bundle.getString("Out_trade_no"); // Out_trade_no为订单号
}
2.6 回调接口
要求接入方提供回调地址,SDK服务端即时推送支付状态至接入方,接入方根据SDK服务端的支付状态以及SDK客户端的支付状态进行二次确认判断,可在该应用的配置页面填写回调接口。
2.6.1 回调接口返回信息xxxxxxxxxx
[datastr]=> %7b%22mtime%22%3a%222016-08-16+09%3a22%3a38%22%2c%22start%22%3a%22success%22%2c%22Total_fee%22%3a%2251.00%22%2c%22Out_trade_no%22%3a%22123028300220160816092237867%22%2c%22User_no%22%3a%221471282278611%22%2c%22Pay_user%22%3a%22o_7yAuLV3zuC6nHGqMZ2e5Qq1SD0%22%2c%22Pay_type%22%3a%221%22%2c%22extra%22%3a%221471282278611%22%2c%22pid%22%3a%228741%22%7d
[sign] => b99a4addae122ddd1dfe5c17037bada1
2.6.2 回调接口参数说明
1. datastr**是支付信息,urldecode解码后信息如下所示**xxxxxxxxxx
{"mtime":"2016-08-16-09:22:38","start":"success","Total_fee":"51.00","Out_trade_no":"123028300220160816092237867","User_no":"1471282278611","Pay_user":"o_7yAuLV3zuC6nHGqMZ2e5Qq1SD0","Pay_type":"1","extra":"1471282278611","pid":"8741"}
2. sign 是签名,用来校验信息是否正确
加密算法:md5(Out_trade_no + appkey + openid + sign_85445221145)
以上加密字段不包含特殊符号分别为订单号、应用appkey、支付标识、固定字符串
2.6.3回调接口返回说明
支付成功之后当贝支付服务端会回调接入方的回调地址,将支付信息传给接入方,接入方收到回调信息之后,返回字符串success即可。
特别说明*:如果遇到特殊情况,导致接入方的回调接口不可用,第一次回调失败之后,当贝支付会进行三次回调。回调返回信息后台展示
2.6.4支付状态查询接口
为了防止漏单(接入方回调接口调用失败),当贝支付提供支付状态查询接口
请求方式:POST
请求参数字段描述示例值dbkey当贝keydaebb9ee52fba3e75c5e4696c1d2b0de
orderno订单号147831417983235
timestamp时间戳1478782659
salt盐值Paydangbei2016#$%
sign签名0c2d5d61a5801860786a49acd6895218
签名算法示例
sign = md5("dbkey=daebb9ee52fba3e75c5e4696c1d2b0de&orderno=147831417983235
×tamp=1478782659&salt=Paydangbei2016#$%")
返回信息{ "order_no": "147831417983235", "result": 1}
说明order_no:订单号 result:1 支付成功0不存在或未支付
2.7 特殊情况说明
若以上步骤中,用户将当贝支付SDK关闭后再进行支付,则当贝SDK是无法返回支付结果到接入方的APP,需要接入方自行和APP服务器进行支付确认,否则可能造成无法发放奖品,造成用户投诉。
3. 技术支持
服务端技术QQ:531201650
客户端技术QQ:504345877
商务QQ:1733812055
产品QQ:925503594