支付宝快捷支付教程:

1. 开发前准备:

1.下载集成开发包

下载地址: https://b.alipay.com/order/productDetail.htm?productId=2013080604609654

这个开发包包含了开发的详细指导,包括私钥公钥生成,接口文档,服务端开发例子,客户端开发例子等诸多说明。详细如图所示:

2. 申请支付宝快捷支付服务

申请地址: https://b.alipay.com/order/productDetail.htm?productId=2013080604609654

我们要使用支付宝的快捷支付功能,必须先去支付宝进行申请,与支付宝达成合约之后,它会为我们(商家)分配一个PID(partnerID)和安全检验码,其中PID有用到,安全检验码则未用到。详细如图所示:

3. 生成私钥,交换公钥

生成私钥公钥步骤:
打开下载下来文件夹,进入到openssl文件夹下的bin目录(F:\download\WS_SECURE_PAY_SDK\openssl\bin),双击openssl.exe将会打开dos命令窗口,依次执行3个命令:
①,执行:openssl genrsa  -out rsa_private_key.pem 1024
②再执行: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
执行完之后,将会生成rsa_private_key.pem文件和rsa_public_key.pem文件,用记事本打开这两个文件,这就是我们客户端生成的私钥和公钥,
私钥我们自己保留,公钥则需要去与支付宝互换; 为什么要互换公钥,那是因为
商户在使用RSA签名方式的支付宝接口时,真正会用到的密钥是商户私钥与支付宝公钥。商户上传公钥给支付宝,支付宝把公钥给商户,是公钥互换的操作。
这就使得商户使用自己的私钥做签名时,支付宝端会根据商户上传的公钥做验证签名。同理,当支付宝返回数据给我们时,我们也可以用他之前换给我们的公钥进行签名验证。

2. 开发环境的搭建:

在下载下来的开发教程中,有两个项目alipay_lib和alipay_sdk_demo,后者是我们做开发需要更改的demo例子,前者是快捷支付所依赖的LibraryProject。
打开eclipse,导入工程alipay_lib,并勾选asLibrary;再导入alipay_sdk_demo工程,在alipay_sdk_demo项目中加入alipay.jar(放在libs目录下),然后将之前导入的alipay_lib工程作为library引进来。

3. 具体代码开发:

我们先看看项目的布局,图工程1.png;

其中Base64.java是一个Base64加密的算法,RSA.java是RSA加密算法,我们都不用管也不要改。我们需要更改的就是Keys.java和ExternalPartner.java里面的代码,
keys.java里面都是些我们需要的变量的定义,ExternalPartner.java则是具体逻辑的实现类。
其实使用支付宝的快捷支付接口很简单,就是按照它定义好的接口准备参数,调用Alipay.pay(String param)即可,
Alipay 接口主要为商户提供快捷登录、订单支付等功能 。至于怎么准备参数,我们接着往下看。

客户端要生成一个订单需要如下参数
service ="mobile.securitypay.pay"//接口名称,是一个固定值,不可控
partner ="2088101568358171" //合作者身份ID,即我们申请得到的PID,以2088开头的16位纯数字,不可空
_input_charset ="utf-8"//参数编码字符集,商户网站使用的编码格式,固定为utf-8,不可空
out_trade_no ="0819145412-6177"//商户网站唯一订单号,注意,这个是客户端传给支付宝的,只需要保证在商户网站的唯一性即可,不可误以为是支付宝交易单号,不可空
subject ="阿迪达斯"//商品名称,可以是商品的标题/ 交易标题/ 订单标题/ 订单关键字等。该参数最长为128 个汉字。不可空
payment_type ="1"//支付类型,默认值为:1(商品购买)。不可空
seller_id ="xiaoming@qq.com"//卖家支付宝账号,可以是邮箱或手机号码格式或其对应的支付宝唯一用户号(以 2088开头的纯16位数字)。 不可空 
total_fee ="100"//订单总金额单位为RMB-Yuan 。取值范围为[0.01,100000000.00] ,精确到小数点后两位。不可空
body ="阿迪达斯上衣"//商品详情,对一笔交易的具体描述信息。不可空
sign_type ="RSA"//签名方式,目前仅支持 RSA。 不可空
sign ="lBBK%2F0w5LOajrMrji7DUgEqNjIhQbidR13GovA5r3TgIbNqv231yC1NksLdw%2Ba3JnfHXoXuet6XNNHtn7VE%2BeCoRO1O%2BR1KugLrQEZMtG5jmJIe2pbjm%2F3kb%2FuGkpG%2BwYQYI51%2BhA3YBbvZHVQBYveBqK%2Bh8mUyb7GM1HxWs9k4%3D"//签名,字符串不能包含回车换行,空格等特殊字符串。不可空
appenv ="system=android^version=3.0.1.2"//标识客户端来源,参数值内容约定为 appenv=”system=客户端平台名^version=业务系统版本”,可空 
notify_url ="http://notify.msp.hk/notify.htm"//服务器异步通知的商户页面路径,路径需要URL encode,可空。
app_id ="external"//客户端号,用来标识是客户端,可空 
it_b_pay ="30m"//未付款交易的超时时间,一旦超时,该笔交易就会自动被关闭。取值范围:1m~15d 。m-分钟,h- 小时,d- 天,1c-当天(无论交易何时创建,都在0 点关闭)。 该参数数值不接受小数点,如1.5h ,可转换为90m 。 可空
show_url ="http://m.taobao.id12345/detail"商品展示地址,可空
extern_token ="1b258b84ed2faf3e88b4d979ed9fd4db"//授权令牌,开放平台返回的包含账户信息的token (授权令牌,商户在一定时间内对支付宝某些服务的访问权限)。 可空

重点说下待签名字符串,签名字符串;
支付接口 待签名字符串 ,字符串都是以key="value"中间用&分隔形式组成,即下面这个样子:
service="mobile.securitypay.pay"&partner="2088101568338364"&_input_charset="utf-8"&notify_url="http://notify.msp.hk/notify.htm"&seller_id="alipay-test01@alipay.com"&out_trade_no="0819145412-6177"&subject="《暗黑破坏神 3:凯恩之书》"&body=""阿迪达斯上衣"&payment_type="1"&total_fee="0.01"
签名字符串 就是:待签名字符串&sign="签名字符串"&sign_type="RSA",sign的value是待签名字符串用私钥加密后的字符串,例子如下:
service="mobile.securitypay.pay"&partner="2088101568338364"&_input_charset="utf-8"&notify_url="http://notify.msp.hk/notify.htm"&seller_id="alipay-test01@alipay.com"&out_trade_no="0819145412-6177"&subject="《暗黑破坏神 3:凯恩之书》"&body=""阿迪达斯上衣"&payment_type="1"&total_fee="0.01"&sign="hkFZr+zE9499nuqDNLZEF7W75RFFPsly876QuRSeN8WMaUgcdR00IKy5ZyBJ4eldhoJ/2zghqrD4E2G2mNjs3aE+HCLiBXrPDNdLKCZgSOIqmv46TfPTEqopYfhs+o5fZzXxt34fwdrzN4mX6S13cr3UwmEV4L3Ffir/02RBVtU="&sign_type="RSA"

支付订单调用的Alipay.pay(String param)中的param就是上面的签名字符串。请求正确的话,界面就会跳转到支付界面,如图支付.png

[java] view plaincopy
  1. /*
  2. * Copyright (C) 2010 The MobileSecurePay Project
  3. * All right reserved.
  4. * author: shiqun.shi@alipay.com
  5. *
  6. *  提示:如何获取安全校验码和合作身份者id
  7. *  1.用您的签约支付宝账号登录支付宝网站(www.alipay.com)
  8. *  2.点击“商家服务”(https://b.alipay.com/order/myorder.htm)
  9. *  3.点击“查询合作者身份(pid)”、“查询安全校验码(key)”
  10. */
  11. package com.alipay.android.msp.demo;
  12. //
  13. // 请参考 Android平台安全支付服务(msp)应用开发接口(4.2 RSA算法签名)部分,并使用压缩包中的openssl RSA密钥生成工具,生成一套RSA公私钥。
  14. // 这里签名时,只需要使用生成的RSA私钥。
  15. // Note: 为安全起见,使用RSA私钥进行签名的操作过程,应该尽量放到商家服务器端去进行。
  16. public final class Keys {
  17. // 合作身份者id,以2088开头的16位纯数字,==支付宝给申请移动支付的商家的一个ID,签约的支付宝账号对应的支付宝唯一用户号==
  18. public static final String DEFAULT_PARTNER = "2088812345675113";
  19. // 收款支付宝账号==卖家的支付宝账号,可以是邮箱,电话号码或上面的2088开头的那个ID==
  20. public static final String DEFAULT_SELLER = "xiaoming@qq.com";
  21. //交易订单号
  22. public static final String TRADE_NO = "032014012345676884";
  23. //异步通知的地址
  24. public static final String notify_url = "http://152.110.113:4275/manager/pay/alipay/notify";
  25. // 商户私钥,自助生成,客户端自己通过下载下来的文件WS_SECURE_PAY_SDK\openssl\bin\spenssl。exe生成私钥和公钥
  26. /**
  27. * RSA密钥使用逻辑:
  28. * 商户在使用RSA签名方式的支付宝接口时,真正会用到的密钥是商户私钥与支付
  29. * 宝公钥。商户上传公钥给支付宝,支付宝把公钥给商户,是公钥互换的操作。这就 使得商户使用自己的私钥做签名时,支付宝端会根据商户上传的公钥做验证签名。
  30. * 商户使用支付宝公钥做验证签名时,同理,也是因为支付宝用支付宝私钥做了签名。
  31. */
  32. public static final String PRIVATE = "签约支付宝商户有效的私钥字符串,可惜我没有0.0";
  33. // 商户公钥,是用我们自己生成的公钥跟支付宝交换的公钥。
  34. public static final String PUBLIC = "MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQCnxj/9qwVfgoUh/y2W89L6BkRAFljhNhgPdyPuBV64bfQNN1PjbCzkIM6qRdKBoLPXmKKMiFYnkd6rAoprih3/PrQEB/VsW8OoM8fxn67UDYuyBTqA23MML9q1+ilIZwBC2AQ2UBVOrFXfFl75p6/B5KsiNG9zpgmLCUYuLkxpLQIDAQAB";
  35. }
[java] view plaincopy
  1. package com.alipay.android.msp.demo;
  2. import java.io.IOException;
  3. import java.io.UnsupportedEncodingException;
  4. import java.net.URLEncoder;
  5. import java.text.SimpleDateFormat;
  6. import java.util.ArrayList;
  7. import java.util.Date;
  8. import org.xmlpull.v1.XmlPullParser;
  9. import org.xmlpull.v1.XmlPullParserException;
  10. import android.app.Activity;
  11. import android.content.res.XmlResourceParser;
  12. import android.os.Bundle;
  13. import android.os.Handler;
  14. import android.os.Message;
  15. import android.text.TextUtils;
  16. import android.util.Log;
  17. import android.view.LayoutInflater;
  18. import android.view.Menu;
  19. import android.view.MenuItem;
  20. import android.view.View;
  21. import android.view.View.OnClickListener;
  22. import android.view.ViewGroup;
  23. import android.widget.AdapterView;
  24. import android.widget.AdapterView.OnItemClickListener;
  25. import android.widget.BaseAdapter;
  26. import android.widget.Button;
  27. import android.widget.EditText;
  28. import android.widget.ListView;
  29. import android.widget.TextView;
  30. import android.widget.Toast;
  31. import com.alipay.android.app.sdk.AliPay;
  32. public class ExternalPartner extends Activity implements OnItemClickListener,
  33. OnClickListener {
  34. public static final String TAG = "alipay-sdk";
  35. private static final int RQF_PAY = 1;
  36. private static final int RQF_LOGIN = 2;
  37. private EditText mUserId;
  38. private Button mLogon;
  39. @Override
  40. public void onCreate(Bundle savedInstanceState) {
  41. super.onCreate(savedInstanceState);
  42. setContentView(R.layout.external_partner);
  43. initProducts();
  44. initListView();
  45. }
  46. /*
  47. * (non-Javadoc)
  48. *
  49. * @see android.app.Activity#onCreateOptionsMenu(android.view.Menu)
  50. */
  51. @Override
  52. public boolean onCreateOptionsMenu(Menu menu) {
  53. menu.add(Menu.NONE, Menu.FIRST, 1, "快速登录");
  54. return true;
  55. }
  56. /*
  57. * (non-Javadoc)
  58. *
  59. * @see android.app.Activity#onOptionsItemSelected(android.view.MenuItem)
  60. */
  61. @Override
  62. public boolean onOptionsItemSelected(MenuItem item) {
  63. switch (item.getItemId()) {
  64. case Menu.FIRST:
  65. setContentView(R.layout.trustlogin);
  66. mUserId = (EditText) findViewById(R.id.user_id);
  67. mLogon = (Button) findViewById(R.id.get_token);
  68. mLogon.setOnClickListener(this);
  69. break;
  70. }
  71. return false;
  72. }
  73. /**
  74. * 初始化产品列表
  75. */
  76. private void initProducts() {
  77. if (sProducts != null)
  78. return;
  79. XmlResourceParser parser = getResources().getXml(R.xml.products);
  80. ArrayList<Product> products = new ArrayList<Product>();
  81. Product product = null;
  82. try {
  83. int eventType = parser.getEventType();
  84. while (eventType != XmlPullParser.END_DOCUMENT) {
  85. if (eventType == XmlPullParser.START_TAG
  86. && parser.getName().equalsIgnoreCase("product")) {
  87. product = new Product();
  88. product.subject = parser.getAttributeValue(0);
  89. product.body = parser.getAttributeValue(1);
  90. product.price = parser.getAttributeValue(2);
  91. products.add(product);
  92. }
  93. eventType = parser.next();
  94. }
  95. sProducts = new Product[products.size()];
  96. products.toArray(sProducts);
  97. } catch (XmlPullParserException e) {
  98. e.printStackTrace();
  99. } catch (IOException e) {
  100. e.printStackTrace();
  101. }
  102. }
  103. @Override
  104. public void onItemClick(AdapterView<?> arg0, View arg1, int position,
  105. long arg3) {
  106. try {
  107. Log.i("ExternalPartner", "onItemClick");
  108. String info = getNewOrderInfo(position);
  109. // String sign = Rsa.sign(info, Keys.PRIVATE);//获取sign字符串
  110. String sign = "";
  111. sign = URLEncoder.encode(sign);// 由于我无法申请到支付宝的快捷支付服务,所以无法获取有效的私钥公钥,只能根据项目中获取的参数适当的进行调整,到最后,调整来调整去发现,调整的参数必须与原数据保持高度的一致。可能是支付宝那端也是将订单信息中的sign字段进行解密,然后比对参数是否一致
  112. sign = "DSt%2BKjh7gTCk%2BB04tr7eRNE6H4FXI617zTBTan8jO8kTB9oNaHeBMwN8jTRXhYsUhUH%2FtHu57L7mELm8agWwEMKkeFwS9GmTWDHWTkv2d9vgdEKTQoUwFF76UJxkJVQmRY9Fi%2FEIfv2CRwJR9kuNhnKb6eZYrfdCdAfvdzncQXI%3D";
  113. info += "&sign=\"" + sign + "\"&sign_type=\"RSA\"";
  114. Log.i("ExternalPartner", "start pay");
  115. // start the pay.
  116. Log.i(TAG, "info = " + info);
  117. //从公司获取的支付参数
  118. // info =
  119. // "partner=\"2088812345675113\"&out_trade_no=\"032011234511576884\"&subject=\"阿迪达斯三叶草_2014-07-17\"&body=\"上衣\"&total_fee=\"0.01\"¬ify_url=\"http%3A%2F%2F110.123.152%3A4085%2Fmanager%2Fpay%2Falipay%2Fnotify\"&service=\"mobile.securitypay.pay\"&_input_charset=\"utf-8\"&payment_type=\"1\"&seller_id=\"xiaoming@qq.com\"&it_b_pay=\"13m\"&sign=\"DSt%2BKjh7gTCk%2BB04tr7eRNE6H4FXI617zTBTan8jO8kTB9oNaHeBMwN8jTRXhYsUhUH%2FtHu57L7mELm8agWwEMKkeFwS9GmTWDHWTkv2d9vgdEKTQoUwFF76UJxkJVQmRY9Fi%2FEIfv2CRwJR9kuNhnKb6eZYrfdCdAfvdzncQXI%3D\"&sign_type=\"RSA\"";
  120. final String orderInfo = info;
  121. new Thread() {
  122. public void run() {
  123. AliPay alipay = new AliPay(ExternalPartner.this, mHandler);
  124. // 设置为沙箱模式,不设置默认为线上环境
  125. // alipay.setSandBox(true);
  126. String result = alipay.pay(orderInfo);
  127. Log.i(TAG, "result = " + result);
  128. Message msg = new Message();
  129. msg.what = RQF_PAY;
  130. msg.obj = result;
  131. mHandler.sendMessage(msg);
  132. }
  133. }.start();
  134. } catch (Exception ex) {
  135. ex.printStackTrace();
  136. Toast.makeText(ExternalPartner.this, R.string.remote_call_failed,
  137. Toast.LENGTH_SHORT).show();
  138. }
  139. }
  140. /**
  141. * 支付接口待签名字符串,字符串都是以key="value"中间用&分隔形式组成 ==订单信息未加密前的字符串==
  142. */
  143. private String getNewOrderInfo(int position) {
  144. StringBuilder sb = new StringBuilder();
  145. sb.append("partner=\"");// 支付宝合作商户ID
  146. sb.append(Keys.DEFAULT_PARTNER);
  147. sb.append("\"&out_trade_no=\"");// 订单号
  148. sb.append(getOutTradeNo());
  149. sb.append("\"&subject=\"");// 订单主题
  150. sb.append(sProducts[position].subject);
  151. sb.append("\"&body=\"");// 订单内容
  152. sb.append(sProducts[position].body);
  153. sb.append("\"&total_fee=\"");// 订单价格
  154. sb.append(sProducts[position].price.replace("一口价:", ""));
  155. sb.append("\"¬ify_url=\"");// 异步通知到哪儿(url指定)
  156. sb.append(URLEncoder.encode(Keys.notify_url));// URl需要进行编码
  157. sb.append("\"&service=\"mobile.securitypay.pay");// 调用的SDK服务接口,是个固定值
  158. sb.append("\"&_input_charset=\"utf-8");// 指定字符集,固定值UTF-8,支付宝只支持这,不知道GBK
  159. // sb.append("\"&return_url=\"");//不知道干嘛的
  160. // sb.append(URLEncoder.encode("http://m.alipay.com"));
  161. sb.append("\"&payment_type=\"1");// 字符类型,1表示购买商品;或许还有其它的类型,我暂时不知道
  162. sb.append("\"&seller_id=\"");// 卖家支付宝账号,需与申请快捷支付的支付宝账号一致
  163. sb.append(Keys.DEFAULT_SELLER);
  164. // 如果show_url值为空,可不传
  165. // sb.append("\"&show_url=\"");//商品展示地址
  166. sb.append("\"&it_b_pay=\"13m");// 支付超时时间,超过设置时间自动取消
  167. sb.append("\"");
  168. return new String(sb);
  169. }
  170. /**
  171. * tradeNo 由商户端产生的唯一订单号,并不是支付宝的交易单号
  172. * @return
  173. */
  174. private String getOutTradeNo() {
  175. // SimpleDateFormat format = new SimpleDateFormat("MMddHHmmss");
  176. // Date date = new Date();
  177. // String key = format.format(date);
  178. //
  179. // java.util.Random r = new java.util.Random();
  180. // key += r.nextInt();
  181. // key = key.substring(0, 15);
  182. // Log.d(TAG, "outTradeNo: " + key);
  183. // return key;
  184. return "032014071711576884";
  185. }
  186. private void initListView() {
  187. ListView lv = (ListView) findViewById(R.id.list_view);
  188. lv.setAdapter(new ExternalPartnerAdapter());
  189. lv.setOnItemClickListener(this);
  190. }
  191. private void doLogin() {
  192. final String orderInfo = getUserInfo();
  193. new Thread() {
  194. public void run() {
  195. String result = new AliPay(ExternalPartner.this, mHandler)
  196. .pay(orderInfo);
  197. Log.i(TAG, "result = " + result);
  198. Message msg = new Message();
  199. msg.what = RQF_LOGIN;
  200. msg.obj = result;
  201. mHandler.sendMessage(msg);
  202. }
  203. }.start();
  204. }
  205. private String getUserInfo() {
  206. String userId = mUserId.getText().toString();
  207. return trustLogin(Keys.DEFAULT_PARTNER, userId);
  208. }
  209. private String trustLogin(String partnerId, String appUserId) {
  210. StringBuilder sb = new StringBuilder();
  211. sb.append("app_name=\"mc\"&biz_type=\"trust_login\"&partner=\"");
  212. sb.append(partnerId);
  213. Log.d("TAG", "UserID = " + appUserId);
  214. if (!TextUtils.isEmpty(appUserId)) {
  215. appUserId = appUserId.replace("\"", "");
  216. sb.append("\"&app_id=\"");
  217. sb.append(appUserId);
  218. }
  219. sb.append("\"");
  220. String info = sb.toString();
  221. // 请求信息签名
  222. String sign = Rsa.sign(info, Keys.PRIVATE);
  223. try {
  224. sign = URLEncoder.encode(sign, "UTF-8");
  225. } catch (UnsupportedEncodingException e) {
  226. e.printStackTrace();
  227. }
  228. info += "&sign=\"" + sign + "\"&sign_type=\"RSA\"";
  229. return info;
  230. }
  231. @Override
  232. public void onClick(View v) {
  233. if (v instanceof Button) {
  234. switch (v.getId()) {
  235. case R.id.get_token:
  236. doLogin();
  237. break;
  238. }
  239. }
  240. }
  241. private class ExternalPartnerAdapter extends BaseAdapter {
  242. @Override
  243. public int getCount() {
  244. return sProducts.length;
  245. }
  246. @Override
  247. public Object getItem(int arg0) {
  248. return sProducts[arg0];
  249. }
  250. @Override
  251. public long getItemId(int position) {
  252. return position;
  253. }
  254. @Override
  255. public View getView(int position, View convertView, ViewGroup parent) {
  256. if (convertView == null) {
  257. LayoutInflater factory = LayoutInflater
  258. .from(ExternalPartner.this);
  259. convertView = factory.inflate(R.layout.product_item, null);
  260. }
  261. Product product = (Product) getItem(position);
  262. TextView tv = (TextView) convertView.findViewById(R.id.subject);
  263. tv.setText(product.subject);
  264. tv = (TextView) convertView.findViewById(R.id.body);
  265. tv.setText(product.body);
  266. tv = (TextView) convertView.findViewById(R.id.price);
  267. tv.setText(product.price);
  268. return convertView;
  269. }
  270. }
  271. Handler mHandler = new Handler() {
  272. public void handleMessage(android.os.Message msg) {
  273. Result result = new Result((String) msg.obj);
  274. switch (msg.what) {
  275. case RQF_PAY:
  276. case RQF_LOGIN: {
  277. Toast.makeText(ExternalPartner.this, result.getResult(),
  278. Toast.LENGTH_SHORT).show();
  279. }
  280. break;
  281. default:
  282. break;
  283. }
  284. };
  285. };
  286. public static class Product {
  287. public String subject;
  288. public String body;
  289. public String price;
  290. }
  291. public static Product[] sProducts;
  292. }

android 支付宝快捷支付相关推荐

  1. android 支付宝集成错误,Android 支付宝快捷支付集成及ALI64错误的有效解决

    支付宝开放平台採用了RSA安全签名机制,开发人员能够通过支付宝公钥验证消息来源.同一时候可使用自己的私钥对信息进行加密. RSA算法及数字签名机制是支付宝开放平台与开发人员网关安全通信的基础.若开发人 ...

  2. Android 支付宝快捷支付集成及ALI64错误的有效解决

    支付宝开放平台采用了RSA安全签名机制,开发者可以通过支付宝公钥验证消息来源,同时可使用自己的私钥对信息进行加密.RSA算法及数字签名机制是支付宝开放平台与开发者网关安全通信的基础,若开发者不熟悉RS ...

  3. 支付宝快捷支付 快就不安全了吗?

    为什么80%的码农都做不了架构师?>>>    工行关闭四个快捷支付接口 之前四大行下调支付宝快捷支付额度,另外四大行均回应称,设置转账及交易支付限额的出发点和落脚点都是为了客户资金 ...

  4. Android 银行卡快捷支付

    转载请标明出处:http://blog.csdn.net/u014084504/article/details/42487507 上面我们介绍了如何使用支付宝进行支付宝的在线快捷支付,下面 我们就来看 ...

  5. java客户端绑定支付宝_Android客户端集成支付宝快捷支付

    一. 第三方支付开放接口 1. 支付宝 面向用户:  支付宝.微信 面向企业:  连连支付.东方支付 2. 官网 3. 请求参数说明 4. 支付宝集成 1) 安全 哪些参数需要从服务端获取 a) 订单 ...

  6. 第2次作业:支付宝快捷支付模块分析

    有关支付宝快捷支付的分析 1.介绍产品相关信息 1.1我选择的产品是支付宝[1]. 1.2选择支付宝作为产品来分析主要有以下三个原因: 1.2.1  相对于其他的产品,支付宝在我生活中使用的频率会相对 ...

  7. 最新骗局:利用支付宝快捷支付 套取手机验证码转账

    最新骗局:利用支付宝快捷支付 套取手机验证码转账 小心,骗子在你不知情的情况下,也能帮你开通支付宝快捷支付!昨天,市民王先生向媒体反映,骗子通过QQ知道他的银行账号等信息后,又通过花言巧语骗取他的手机 ...

  8. Android 支付宝 移动支付接口 快速配置

    RSA签名 RSA密钥生成命令 生成RSA私钥 openssl>genrsa -out rsa_private_key.pem 1024 生成RSA公钥 openssl>rsa -in r ...

  9. android支付宝接入支付问题ali40247

    前言:继续来研究支付宝接入时候遇到的问题. 问题截图: 解决方案: 这里给大家一个详细分析的链接,可以看这里详细了解支付宝ali40247解决方案 听我说: 1.首先你需要确定的是你接入使用的是sdk ...

  10. 支付宝快捷支付sdk网址

    https://b.alipay.com/order/productDetail.htm?productId=2013080604609654&tabId=4#ps-tabinfo-hash ...

最新文章

  1. JMeter学习-017-java.net.SocketException: Permission denied: connect 解决方案
  2. 2013 ACM/ICPC Asia Regional Chengdu Online We Love MOE Girls 字符串STL 的应用
  3. 利用Servlet实现用户永久登录
  4. java高并发(十二)并发容器J.U.C
  5. 前端学习(753):js没有块级作用域
  6. 开发人员:月薪过万与年薪百万之间的差距
  7. git add 所有修改文件_Git管理修改、撤销和删除文件
  8. PHP 中使用工厂模式
  9. js字符串方法、数组方法整理
  10. 一次性视频内窥镜行业调研报告 - 市场现状分析与发展前景预测(2021-2027年)
  11. flink基本程序架构
  12. 数据挖掘常用聚类算法性能比较
  13. Openlaye:学习笔记之事件
  14. code review平台Rietveld应用指南
  15. 【代码优化】使用enum代替int常量
  16. C语言编译出现首值缪,TP312C-C语言程序设计 武马群.pdf
  17. iphone4屏幕各部分尺寸
  18. 美化传奇NPC对话框添加图片显示实列
  19. 机器学习作业(第十八次课堂作业)
  20. 泼冷水!为什么说机器学习在很多方面被高估了? | 精选

热门文章

  1. 【做小游戏在Godot中遇到的问题第一篇】
  2. 单片机c51语言中 两个位变量类型是什么,51单片机中的数据类型解析
  3. 皮皮高清影视播放器2015官方版
  4. TSL2561 GY2561 模块 MSP430 单片机 程序 STM32 程序 光强传感器 MSP430F5529
  5. 1247:河中跳房子
  6. 一些框架图的色彩搭配
  7. navicat mysql视图_Navicat教你如何做MySQL 视图
  8. Round Roundup
  9. echarts中如何设置geo3D地图背景图片,以及geo3D中如何使用effectScatter属性
  10. 北航2021年复试机试第二题