在开发 在线银联在线支付账户验证支付的时候,出现 验签失败 是怎么回事

相关文章推荐
最近做了支付,现在把后台支付的流程记录下来,方便以后查找。
前一段时间在帮公司申请各种支付接口,在银联支付接口消耗了不少时间,其实银联支付申请还是比较简单的(不用上传app截图什么的),只是申请入口比较难找,还有填写的资料比较多。下面我给大家介绍下银联支付接口...
银联联调测试文档
刚接触了下银联支付,在网上搜还是看官方文档银联支付都不是很清晰,所以自己总结一篇,希望可以帮助大家快速集成。
一.进入下载官网,选择下载手机控件支付demo:
https://open.union...
chinapay接口整合到网站中要注意的一些细节
这几天在做chinapay的接口整合,银联的文档写得太烂,代码规范也不行,给用户带来不便就不多说,废话少说了,整理一下碰到的一些文档中没...
银联支付(网关支付B2C)
官网下载demo后进行测试及后续自己项目代码整合
首先去银联官网注册测试支付账户
下载对应的demo
下载地址:/ajweb/help/file
下载页面如下:
红框表示出来的地方,看你需要...
一功能描述
二实现过程
1下载银联支付SDK和Demo
1银联商家服务地址httpsopenunionpaycomajwebindex
2下载的文件如下
1先试官方Demo
2集成到自己的...
他的最新文章
他的热门文章
您举报文章:
举报原因:
原文地址:
原因补充:
(最多只允许输入30个字)Android支付宝,微信,银联支付支付的集成
我的图书馆
Android支付宝,微信,银联支付支付的集成
用户使用移动的终端完成对所购买商品或者服务的支付功能;分为近场支付(蓝牙支付,刷卡,滴卡),和远程支付(网上支付,短信支付)
app支付模块
常见的支付厂商--&常见的支付方式
支付宝:阿里公司微信:腾讯公司银联:联合起来的结构财付通:腾讯公司支付宝钱包:阿里公司百度钱包:百度公司
支付安全吗?
都是比较安全.都是大公司的产品.而且这个和金钱之前挂钩;
支付难不难?
支付不难.因为是第三方平台的东西.
支付集成大概需要多长时间?(如果之前做过)
支付宝:5-10分钟银联:5-10分钟微信:10-20分钟
支付流程_从生活出发
1. 选择商品--&goodName,goodId,price,count2. 选择支付方式--&payType:1,支付宝;2,银联;3:微信3. 处理支付结果--&支付成功(购物流程),支付失败(重试,放弃)
支付流程_从程序角度出发
选择商品,组装支付数据--&拼接请求的jsonString把支付数据post到后台server--&发送一个请求request后台server(支付宝的服务)生成支付串码---&处理第二步的reponse
在客户端使用第三方平台的api调用插件完成支付--&调用第三方平台jar包里面的方法(集成过程),这一步才用到支付宝sdk
处理支付结果--&利用没有平台特有的通知机制处理支付结果
自己总结一下
支付串码是啥?
支付方法需要的支付参数
支付流程_简明说法
发起支付请求拿到支付串码调用api支付处理支付结果
同步返回:支付后通知我们自己的apk异步通知:支付后通知我们的server
demo运行问题:需要ALIPAYPartnerID,ALIPAYSellerID,ALIPAYMD5KEY,ALIPAYPartnerPrivKey,ALIPAYPubKey才可以运行.但是如果直接下载的demo.这些字段都是"",无法看到效果,这些数据的获得.是用公司运行去做;支付宝demo的流程和实际开发不一致.实际开发.生成支付串码的过程应该交给服务器.因为sign需要支付宝的privatekey,如果放到apk里面是会泄露privatekey的,所以最后简化之后的支付宝集成就几行代码;RSA:RSA是一种公钥加密算法。能够抵抗到目前为止已知的绝大多数密码攻击,已被ISO推荐为公钥数据加密标准。主要用于公钥加密私钥解密、私钥签名公钥验签。支付宝公钥:开发者请求支付宝并获得返回时,开发者用于验签使用的公钥
我们自己要和支付宝签约(商户签约).--&运营秘钥配置--&协助运营完成秘钥的配置(公钥互换),可能程序员会参与集成支付宝--&必须是程序员去做.
MainActivity
public&class&MainActivity&extendsActivity {
&&&&privateButton btn_
&&&&&* 支付宝通过hanlder机制发送支付结果出来,这个过程我们理解为"同步返回".因为只要支付宝支付成功.客户端就可以通过handler收到消息
&&&&privateHandler handler =&newHandler() {
&&&&&&&&publicvoid&handleMessage(android.os.Message msg) {/*
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Result result = new Result((String) msg.obj);
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&switch (msg.what) {
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&case RQF_PAY:
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&case RQF_LOGIN: {
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(ExternalPartner.this, result.getResult(), Toast.LENGTH_SHORT).show();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&default:
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&*/
&&&&&&&&};
&&&&@Override
&&&&protectedvoid&onCreate(Bundle savedInstanceState) {
&&&&&&&&super.onCreate(savedInstanceState);
&&&&&&&&setContentView(R.layout.activity_main);
&&&&&&&&initView();
&&&&&&&&initListener();
&&&&privatevoid&initView() {
&&&&&&&&btn_zfb = (Button) findViewById(R.id.btn1);
&&&&privatevoid&initListener() {
&&&&&&&&/**
&&&&&&&&&* 支付宝支付
&&&&&&&&&*/
&&&&&&&&btn_zfb.setOnClickListener(newOnClickListener() {
&&&&&&&&&&&&@Override
&&&&&&&&&&&&publicvoid&onClick(View v) {
&&&&&&&&&&&&&&&&//1. 选择商品,把**支付数据**post到后台server--&发送一个请求
&&&&&&&&&&&&&&&&finalString goodInfoJsonString =&"{\"goodInfos\":[{\"goodCounts\":\"1\",\"goodExtInfo\":{},\"goodIDs\":\"965\",\"goodType\":\"1\"}],\"loginFlag\":\"0\",\"mobile\":\"\",\"orderId\":\"0\",\"otherInfo\":{\"agentID\":\"0-maizuo\",\"channelID\":\"31\",\"clientID\":\"31\"},\"payDatas\":{\"discountInfo\":{\"activeID\":\"0\",\"discountID\":\"0\",\"discountPrice\":\"\"},\"payInfo\":[{\"bankType\":\"7\",\"payCount\":\"3800\",\"payTicketCount\":\"1\",\"payType\":\"1\"}],\"payPass\":\"\",\"returnUrl\":\"\",\"totalPrice\":\"3800\"},\"processPath\":\"1\",\"sessionKey\":\"chfrlczgtomqsiurzzyo\",\"userID\":\"\"}";
&&&&&&&&&&&&&&&&//2.把支付数据post到后台server--&发送一个请求
&&&&&&&&&&&&&&&&newThread(new&Runnable() {
&&&&&&&&&&&&&&&&&&&&@Override
&&&&&&&&&&&&&&&&&&&&publicvoid&run() {
&&&&&&&&&&&&&&&&&&&&&&&&// TODO
&&&&&&&&&&&&&&&&&&&&&&&&try{
&&&&&&&&&&&&&&&&&&&&&&&&&&&&DefaultHttpClient httpClient =new&DefaultHttpClient();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&HttpPost post =new&HttpPost(
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&"");
&&&&&&&&&&&&&&&&&&&&&&&&&&&&post.addHeader("Content-Type","application/json");
&&&&&&&&&&&&&&&&&&&&&&&&&&&&post.setEntity(newStringEntity(goodInfoJsonString));
&&&&&&&&&&&&&&&&&&&&&&&&&&&&HttpResponse response = httpClient.execute(post);
&&&&&&&&&&&&&&&&&&&&&&&&&&&&if(response.getStatusLine().getStatusCode() ==&200)
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&HttpEntity entity = response.getEntity();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&String result = EntityUtils.toString(entity);
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&System.out.println(result);//--&bean--&getAlipayVerifyKey();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&//3.在客户端使用第三方平台的api调用插件完成支付
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&//获取Alipay对象,构造参数为当前Activity和Handler实例对象
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&//mHandler就是一会处理我们支付结果的hanlder
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&AliPay alipay =new&AliPay(MainActivity.this,
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&//调用pay方法,将订单信息传入
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&String orderInfo ="_input_charset=\"UTF-8\"&body=\"卖座网电子影票\"&it_b_pay=\"1h\"&notify_url=\"http%3A%2F%%2FmobileBack.htm\"&out_trade_no=\"092428\"&partner=\"1920\"&payment_type=\"1\"&seller_id=\"1920\"&service=\"mobile.securitypay.pay\"&subject=\"海岸影城(2D通兑票1张)\"&total_fee=\"38.00\"&sign=\"KDhXG0I8T1VZCgg3tfmYbnhF91I6marCQ0yWgmIe1ZGJ9z6MHFwwV7O156%2FkTecKikrIwRnrPNOI%0Ac8h6bUPRX9DIoHF3Yamj1NCi%2B5j0e16uRy5VtyhLFPx608stqjLlaepBsRZYPblyikuts67W9IJ%2B%0AyNrrG8cZ6ltgulZTFH4%3D\"&sign_type=\"RSA\"";//支付串码
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&String payResult = alipay.pay(orderInfo);
&&&&&&&&&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&&&&&&&&&}catch&(Exception e) {
&&&&&&&&&&&&&&&&&&&&&&&&&&&&e.printStackTrace();
&&&&&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&}).start();
&&&&&&&&&&&&}
&&&&&&&&});
&&&&// “00” – 银联正式环境
&&&&// “01” – 银联测试环境,该环境中不发生真实交易
&&&&String serverMode ="00";
&&&&&* 银联支付
&&&&publicvoid&uupay(View v) {
&&&&&&&&//通过支付请求.拿到支付串码
&&&&&&&&String tn ="";
&&&&&&&&//发起支付请求
&&&&&&&&intret = UPPayAssistEx.startPay(MainActivity.this,null,&null,
tn, serverMode);
&&&&&&&&if(ret == UPPayAssistEx.PLUGIN_NOT_FOUND) {
&&&&&&&&&&&&//安装Asset中提供的UPPayPlugin.apk
&&&&&&&&&&&&// 此处可根据实际情况,添加相应的处理逻辑
&&&&&&&&&&&&UPPayAssistEx.installUPPayPlugin(this);
&&&&&* uupay处理支付结果
&&&&protectedvoid&onActivityResult(intrequestCode,&intresultCode,
Intent data) {
&&&&&&&&if(data ==&null) {
&&&&&&&&&&&&return;
&&&&&&&&String str = data.getExtras().getString("pay_result");
&&&&&&&&String msg ="";
&&&&&&&&/*
&&&&&&&&&* 支付控件返回字符串:success、fail、cancel 分别代表支付成功,支付失败,支付取消
&&&&&&&&&*/
&&&&&&&&if(str.equalsIgnoreCase("success")) {
&&&&&&&&&&&&msg ="支付成功!";
&&&&&&&&}else&if(str.equalsIgnoreCase("fail"))
&&&&&&&&&&&&msg ="支付失败!";
&&&&&&&&}else&if(str.equalsIgnoreCase("cancel"))
&&&&&&&&&&&&msg ="用户取消了支付";
&&&&&&&&//下面就是进行用户提示
&&&&&&&&Toast.makeText(getApplicationContext(), msg,0).show();
RSA密钥生成命令
生成RSA私钥
openssl&genrsa -out rsa_private_key.pem 1024
生成RSA公钥
openssl&rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem
将RSA私钥转换成PKCS8格式
openssl&pkcs8 -topk8 -inform PEM -in rsa_private_key.pem -outform PEM -nocrypt
注意:“&”符号后面的才是需要输入的命令。
E:\支付\支付宝\支付宝钱包支付接口开发包2.0标准版()\DEMO\openssl\bin\1目录下有俩个文件
开发者将私钥保留,将公钥提交给支付宝网关,用于信息加密及解密。
demo运行问题:只需要tnno就可以银联提供了测试环境和正式环境,而且还有测试账号
//通过支付请求.拿到支付串码
String tn = "<span style="color:#548";
//发起支付请求
int ret = UPPayAssistEx.startPay(MainActivity.this, null, null, tn, serverMode);
if (ret == UPPayAssistEx.PLUGIN_NOT_FOUND) {
//安装Asset中提供的UPPayPlugin.apk
// 此处可根据实际情况,添加相应的处理逻辑
UPPayAssistEx.installUPPayPlugin(this);
处理支付结果:在onactivityForResult中处理
&&@Override
protectedvoid&onActivityResult(intrequestCode,&intresultCode,
Intent data) {
&&&&initData();
&&&&if(data ==&null) {
&&&&&&&&return;
&&&&String uupayResult = data.getExtras().getString("pay_result");
&&&&Logger.i(TAG,"pay_result:"&+ uupayResult);
&&&&if(uupayResult !=&null&& !"".equals(uupayResult))
&&&&&&&&Logger.i(TAG,"pay_result:"&+ uupayResult);
&&&&&&&&Message msg =new&Message();
&&&&&&&&if(uupayResult.equalsIgnoreCase("success")) {
&&&&&&&&&&&&msg.what = UUPAYSUCCESS;
&&&&&&&&}else&if(uupayResult.equalsIgnoreCase("fail"))
&&&&&&&&&&&&msg.what = UUPAYFAIL;
&&&&&&&&/*else if (uupayResult.equalsIgnoreCase("cancel")) {
&&&&&&&&&&&&msg = "用户取消了支付";
&&&&&&&&}*/
&&&&&&&&handler.sendMessage(msg);
&&&&super.onActivityResult(requestCode, resultCode, data);
一、获取 access_token二、生成预支付订单三、调起微信支付四、接收支付返回结果
private&void&sendPayReq(WXPayData info) {
&&&&api = WXAPIFactory.createWXAPI(this, info.getAppid());
&&&&PayReq req =new&PayReq();
&&&&req.appId = info.getAppid();
&&&&req.partnerId = info.getPartnerid();
&&&&req.prepayId = info.getPrepayid();//预支付id
&&&&req.nonceStr = info.getNoncestr();//32位内的随机串,防重发
&&&&req.timeStamp = String.valueOf(info.getTimestamp());//时间戳,为 1970 年 1 月 1 日 00:00 到请求发起时间的秒数
&&&&req.packageValue = info.getPackage1();
&&&&req.sign = info.getApp_signature();
&&&&// 在支付之前,如果应用没有注册到微信,应该先调用IWXMsg.registerApp将应用注册到微信
&&&&api.sendReq(req);
处理支付结果:在WXPayEntryActivity.java
errCode = resp.errC
Logger.i(TAG,&"微信支付结果:"&+ String.valueOf(resp.errCode));
if&(resp.getType() == MAND_PAY_BY_WX) {
&&&&/*AlertDialog.Builder builder = new AlertDialog.Builder(this);
&&&&builder.setTitle(R.string.app_tip);
&&&&builder.setMessage(getString(R.string.pay_result_callback_msg, String.valueOf(resp.errCode)));
&&&&builder.show();*/
Message msg =&new&Message();
if&(errCode ==&0) {
&&&&msg.what = PayActivity.WEIXINPAYSUCCESS;
&&&&msg.what = PayActivity.WEIXINPAYFAIL;
PayActivity.instance.handler.sendMessage(msg);
数字签名+";"+包名; 输入“安全码”。安全码的组成规则为:签名证书的sha1值+“;”+packagename(即:数字签名+分号+包名),例如: BB:0D:AC:74:D3:21:E1:43:67:71:9B:62:91:AF:A1:66:6E:44:5D:75;com.baidumap.dem
作用:保证app唯一性
现在的支付宝demo主代码:PayDemoActivity
特别注意,这里的签名逻辑需要放在服务端,切勿将私钥泄露在代码中!,所剩代码就是上面的,把方法换成现在的即可
public&class&PayDemoActivity&extendsFragmentActivity {
&&&&// 商户PID
&&&&publicstatic&final&String PARTNER =&"8845";
&&&&// 商户收款账号
&&&&publicstatic&final&String SELLER =&"6173";
&&&&// 商户私钥,pkcs8格式
&&&&publicstatic&final&String RSA_PRIVATE ="MIICdwIBADANBgkqhkiG9w0BAQEFAASCAmEwggJdAgEAAoGBALTam792ATycFFDXWg6VEQofa3lT4qWkmcyXLnbSZVHV/brDdDNfeHMJWwvsvuJYNxEDZOYL/AA7/WuBLI+KklXhFUnu/NjQWmXzndiQI15Mfq+2TDh1Cf9H7ypUHah8RrcTwaM9H1/SWP7f2o2QOucB2Y/bI4Faq3ISwONXztTvAgMBAAECgYEAjK4cRwOhFKeIehX6XKuB9LDaJielfxoZ9PaI0y74V38w/q15X1jdVgaqBw2ismjSdO6B9xzNatU/XPe/VO0CxHFZ3/5Qhc/b724MsTxGyVC8TMI/oHMgAlVE3cR4/fwj0fhsYUYbSy9yCTqyinpdLZcNkUpMBJaeaM4jQJZvaSECQQDm7TrKPyJ1mgkKZADco+/HzcX1OnLvGtjFnSxD4LUShFfpYW5bWthy+869Jt9iIbOVDkvrfANMKhOuk0sEany/AkEAyH2SUFJUA1r+csi6WDf694npi6gtY0MhcNgGmoVr3g1daWf3cbx81VUE9y4ffqH91mdxWlVMVsCQetNYywdD0QJAAKQsA5/FQrpYyBSbBAHYip+BqzqsUwmqDHJxSwb2ucRwUg+ZNNu9uiQE4PWYrTcWvpU5lL/VaoK7Z0K1dJ+vFQJBAKV78F7X9XxniQqZYCYc3sufS+P4Rq5d5KZNyPWWFvjLs0SjifyZBbjYWibkLR7K+sgTzd4v9bjNbPPUqr+6GWECQAk6JYzWuS8D7ns/JEbI1fuUzm2U8/Q2R60dq7EFtbw+Po1dxZzUJ+V5JhW9exvhrr7lVII/0aB8nv/LUE+2XCo=";
&&&&// 支付宝公钥
&&&&publicstatic&final&String RSA_PUBLIC =&"MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQDDI6d306Q8fIfCOaTXyiUeJHkrIvYISRcc73s3vF1ZT7XN8RNPwJxo8pWaJMmvyTn9N4HQ632qJBVHf8sxHi/fEsraprwCtzvzQETrNRwVxLO5jVmRGi60j8Ue1efIlzPXV9je9mkjzOmdssymZkh2QhUrCmZYI/FCEa3/cNMW0QIDAQAB";
&&&&privatestatic&final&int&SDK_PAY_FLAG
&&&&privatestatic&final&int&SDK_CHECK_FLAG
&&&&privateHandler mHandler =&newHandler() {
&&&&&&&&publicvoid&handleMessage(Message msg) {
&&&&&&&&&&&&switch(msg.what) {
&&&&&&&&&&&&caseSDK_PAY_FLAG: {
&&&&&&&&&&&&&&&&PayResult payResult =new&PayResult((String) msg.obj);
&&&&&&&&&&&&&&&&/**
&&&&&&&&&&&&&&&&&* 同步返回的结果必须放置到服务端进行验证(验证的规则请看
&&&&&&&&&&&&&&&&&* detail.htm?spm=0.0.0.0.xdvAU6&treeId=59&articleId=103665&
&&&&&&&&&&&&&&&&&* docType=1) 建议商户依赖异步通知
&&&&&&&&&&&&&&&&&*/
&&&&&&&&&&&&&&&&String resultInfo = payResult.getResult();// 同步返回需要验证的信息
&&&&&&&&&&&&&&&&String resultStatus = payResult.getResultStatus();
&&&&&&&&&&&&&&&&// 判断resultStatus 为“9000”则代表支付成功,具体状态码代表含义可参考接口文档
&&&&&&&&&&&&&&&&if(TextUtils.equals(resultStatus,&"9000")) {
&&&&&&&&&&&&&&&&&&&&Toast.makeText(PayDemoActivity.this,"支付成功",
&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.LENGTH_SHORT).show();
&&&&&&&&&&&&&&&&}else&{
&&&&&&&&&&&&&&&&&&&&// 判断resultStatus 为非"9000"则代表可能支付失败
&&&&&&&&&&&&&&&&&&&&// "8000"代表支付结果因为支付渠道原因或者系统原因还在等待支付结果确认,最终交易是否成功以服务端异步通知为准(小概率状态)
&&&&&&&&&&&&&&&&&&&&if(TextUtils.equals(resultStatus,&"8000"))
&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(PayDemoActivity.this,"支付结果确认中",
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.LENGTH_SHORT).show();
&&&&&&&&&&&&&&&&&&&&}else&{
&&&&&&&&&&&&&&&&&&&&&&&&// 其他值就可以判断为支付失败,包括用户主动取消支付,或者系统返回的错误
&&&&&&&&&&&&&&&&&&&&&&&&Toast.makeText(PayDemoActivity.this,"支付失败",
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&Toast.LENGTH_SHORT).show();
&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&}
&&&&&&&&&&&&caseSDK_CHECK_FLAG: {
&&&&&&&&&&&&&&&&Toast.makeText(PayDemoActivity.this,"检查结果为:"&+
&&&&&&&&&&&&&&&&&&&&&&&&Toast.LENGTH_SHORT).show();
&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&}
&&&&&&&&&&&&default:
&&&&&&&&&&&&&&&&break;
&&&&&&&&&&&&}
&&&&&&&&};
&&&&@Override
&&&&protectedvoid&onCreate(Bundle savedInstanceState) {
&&&&&&&&super.onCreate(savedInstanceState);
&&&&&&&&setContentView(R.layout.pay_main);
&&&&&* call alipay sdk pay. 调用SDK支付
&&&&publicvoid&pay(View v) {
&&&&&&&&if(TextUtils.isEmpty(PARTNER) || TextUtils.isEmpty(RSA_PRIVATE)
&&&&&&&&&&&&&&&&|| TextUtils.isEmpty(SELLER)) {
&&&&&&&&&&&&newAlertDialog.Builder(this)
&&&&&&&&&&&&&&&&&&&&.setTitle("警告")
&&&&&&&&&&&&&&&&&&&&.setMessage("需要配置PARTNER | RSA_PRIVATE| SELLER")
&&&&&&&&&&&&&&&&&&&&.setPositiveButton("确定",
&&&&&&&&&&&&&&&&&&&&&&&&&&&&newDialogInterface.OnClickListener() {
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&publicvoid&onClick(
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&DialogInterface dialoginterface,int&i) {
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&//
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&finish();
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&}
&&&&&&&&&&&&&&&&&&&&&&&&&&&&}).show();
&&&&&&&&&&&&return;
&&&&&&&&String orderInfo = getOrderInfo("测试的商品","该测试商品的详细描述",&"0.01");
&&&&&&&&/**
&&&&&&&&&* 特别注意,这里的签名逻辑需要放在服务端,切勿将私钥泄露在代码中!
&&&&&&&&&*/
&&&&&&&&String sign = sign(orderInfo);
&&&&&&&&try{
&&&&&&&&&&&&/**
&&&&&&&&&&&&&* 仅需对sign 做URL编码
&&&&&&&&&&&&&*/
&&&&&&&&&&&&sign = URLEncoder.encode(sign,"UTF-8");
&&&&&&&&}catch&(UnsupportedEncodingException e) {
&&&&&&&&&&&&e.printStackTrace();
&&&&&&&&/**
&&&&&&&&&* 完整的符合支付宝参数规范的订单信息
&&&&&&&&&*/
&&&&&&&&finalString payInfo = orderInfo +&"&sign=\""+ sign +&"\"&"
&&&&&&&&&&&&&&&&+ getSignType();
&&&&&&&&System.out.println("payInfo==========="+ payInfo);
&&&&&&&&Runnable payRunnable =new&Runnable() {
&&&&&&&&&&&&@Override
&&&&&&&&&&&&publicvoid&run() {
&&&&&&&&&&&&&&&&// 构造PayTask 对象
&&&&&&&&&&&&&&&&PayTask alipay =new&PayTask(PayDemoActivity.this);
&&&&&&&&&&&&&&&&// 调用支付接口,获取支付结果
&&&&&&&&&&&&&&&&String result = alipay.pay(payInfo,true);
&&&&&&&&&&&&&&&&Message msg =new&Message();
&&&&&&&&&&&&&&&&msg.what = SDK_PAY_FLAG;
&&&&&&&&&&&&&&&&msg.obj =
&&&&&&&&&&&&&&&&mHandler.sendMessage(msg);
&&&&&&&&&&&&}
&&&&&&&&};
&&&&&&&&// 必须异步调用
&&&&&&&&Thread payThread =new&Thread(payRunnable);
&&&&&&&&payThread.start();
&&&&&* check whether the device has authentication alipay account.
&&&&&* 查询终端设备是否存在支付宝认证账户
&&&&publicvoid&check(View v) {
&&&&&&&&Runnable checkRunnable =new&Runnable() {
&&&&&&&&&&&&@Override
&&&&&&&&&&&&publicvoid&run() {
&&&&&&&&&&&&&&&&// 构造PayTask 对象
&&&&&&&&&&&&&&&&PayTask payTask =new&PayTask(PayDemoActivity.this);
&&&&&&&&&&&&&&&&// 调用查询接口,获取查询结果
&&&&&&&&&&&&&&&&booleanisExist = payTask.checkAccountIfExist();
&&&&&&&&&&&&&&&&Message msg =new&Message();
&&&&&&&&&&&&&&&&msg.what = SDK_CHECK_FLAG;
&&&&&&&&&&&&&&&&msg.obj = isE
&&&&&&&&&&&&&&&&mHandler.sendMessage(msg);
&&&&&&&&&&&&}
&&&&&&&&};
&&&&&&&&Thread checkThread =new&Thread(checkRunnable);
&&&&&&&&checkThread.start();
&&&&&* get the sdk version. 获取SDK版本号
&&&&publicvoid&getSDKVersion() {
&&&&&&&&PayTask payTask =new&PayTask(this);
&&&&&&&&String version = payTask.getVersion();
&&&&&&&&Toast.makeText(this, version, Toast.LENGTH_SHORT).show();
&&&&&* 原生的H5(手机网页版支付切natvie支付) 【对应页面网页支付按钮】
&&&&&* @param v
&&&&publicvoid&h5Pay(View v) {
&&&&&&&&Intent intent =new&Intent(this,
H5PayDemoActivity.class);
&&&&&&&&Bundle extras =new&Bundle();
&&&&&&&&/**
&&&&&&&&&* url是测试的网站,在app内部打开页面是基于webview打开的,demo中的webview是H5PayDemoActivity,
&&&&&&&&&* demo中拦截url进行支付的逻辑是在H5PayDemoActivity中shouldOverrideUrlLoading方法实现,
&&&&&&&&&* 商户可以根据自己的需求来实现
&&&&&&&&&*/
&&&&&&&&String url ="";
&&&&&&&&// url可以是一号店或者美团等第三方的购物wap站点,在该网站的支付过程中,支付宝sdk完成拦截支付
&&&&&&&&extras.putString("url", url);
&&&&&&&&intent.putExtras(extras);
&&&&&&&&startActivity(intent);
&&&&&* create the order info. 创建订单信息
&&&&privateString getOrderInfo(String subject, String body, String price) {
&&&&&&&&// 签约合作者身份ID
&&&&&&&&String orderInfo ="partner="&+&"\""&+
PARTNER +&"\"";
&&&&&&&&// 签约卖家支付宝账号
&&&&&&&&orderInfo +="&seller_id="&+&"\""&+
SELLER +&"\"";
&&&&&&&&// 商户网站唯一订单号
&&&&&&&&orderInfo +="&out_trade_no="&+&"\""&+
getOutTradeNo() +"\"";
&&&&&&&&// 商品名称
&&&&&&&&orderInfo +="&subject="&+&"\""&+
subject +&"\"";
&&&&&&&&// 商品详情
&&&&&&&&orderInfo +="&body="&+&"\""&+
body +&"\"";
&&&&&&&&// 商品金额
&&&&&&&&orderInfo +="&total_fee="&+&"\""&+
price +&"\"";
&&&&&&&&// 服务器异步通知页面路径
&&&&&&&&orderInfo +="&notify_url="&+"\""&+&""
&&&&&&&&&&&&&&&&+"\"";
&&&&&&&&// 服务接口名称, 固定值
&&&&&&&&orderInfo +="&service=\"mobile.securitypay.pay\"";
&&&&&&&&// 支付类型, 固定值
&&&&&&&&orderInfo +="&payment_type=\"1\"";
&&&&&&&&// 参数编码, 固定值
&&&&&&&&orderInfo +="&_input_charset=\"utf-8\"";
&&&&&&&&// 设置未付款交易的超时时间
&&&&&&&&// 默认30分钟,一旦超时,该笔交易就会自动被关闭。
&&&&&&&&// 取值范围:1m~15d。
&&&&&&&&// m-分钟,h-小时,d-天,1c-当天(无论交易何时创建,都在0点关闭)。
&&&&&&&&// 该参数数值不接受小数点,如1.5h,可转换为90m。
&&&&&&&&orderInfo +="&it_b_pay=\"30m\"";
&&&&&&&&// extern_token为经过快登授权获取到的alipay_open_id,带上此参数用户将使用授权的账户进行支付
&&&&&&&&// orderInfo += "&extern_token=" + "\"" + extern_token + "\"";
&&&&&&&&// 支付宝处理完请求后,当前页面跳转到商户指定页面的路径,可空
&&&&&&&&orderInfo +="&return_url=\"\"";
&&&&&&&&// 调用银行卡支付,需配置此参数,参与签名, 固定值 (需要签约《无线银行卡快捷支付》才能使用)
&&&&&&&&// orderInfo += "&paymethod=\"expressGateway\"";
&&&&&&&&returnorderI
&&&&&* get the out_trade_no for an order. 生成商户订单号,该值在商户端应保持唯一(可自定义格式规范)
&&&&privateString getOutTradeNo() {
&&&&&&&&SimpleDateFormat format =new&SimpleDateFormat("MMddHHmmss",
&&&&&&&&&&&&&&&&Locale.getDefault());
&&&&&&&&Date date =new&Date();
&&&&&&&&String key = format.format(date);
&&&&&&&&Random r =new&Random();
&&&&&&&&key = key + r.nextInt();
&&&&&&&&key = key.substring(0,15);
&&&&&&&&return
&&&&&* sign the order info. 对订单信息进行签名,即加密
&&&&&* @param content
&&&&&*&&&&&&&&&&& 待签名订单信息
&&&&privateString sign(String content) {
&&&&&&&&returnSignUtils.sign(content, RSA_PRIVATE);
&&&&&* get the sign type we use. 获取签名方式
&&&&privateString getSignType() {
&&&&&&&&return"sign_type=\"RSA\"";
参考知识库
馆藏&24259
TA的最新馆藏[转]&
喜欢该文的人也喜欢

我要回帖

更多关于 银联在线支付账户验证 的文章

 

随机推荐