最近在做android~,恩,就说这么多吧
1,准备工作
当然了,假设你已经有了pid(partner)和商户账户(seller),并且开通了手机网页支付功能。
下载的包里面,打开【手机网页即时到账接口】文件夹,看到里面的可以看看里面的pdf文档,【手机网页支付接入与使用规则.pdf】这个文档有教你怎么在支付宝开通相关的东西,这里我提一下,记得把公钥上传,然后私钥生成出来
这个包,对于android,虽然没有需要的lib,但是文档的相关参数说明也是必须的。
看文档,可以知道,网页支付需要两步,第一步是获取授权令牌,第二步根据这个令牌进行交易。
那么在第一步的时候,我们要根据文档提供的url获取令牌,这个时候我们要发起http请求,获得返回的内容,解析出来授权令牌,再去发请求,得到支付宝的支付网页,显示即可
我的做法是,第一步用http请求,第二步是webview加载链接
2,代码相关
假设你已经有了android工程,打开下载的包里面的demo【WS_WAP_PAYWAP-JAVA-UTF-8】在src目录下找到sign这个package然后把RSA.java拿出来,放到你的android工程里,因为我只用了RSA加密所以这里只拿了这一个,如果你需要其他加密方法,那就拿其他的……
还没完,再到util包里面打开AlipaySubmit.java类,找到:
/**
* 解析远程模拟提交后返回的信息,获得token
* @param text 要解析的字符串
* @return 解析结果
* @throws Exception
*/
public static String getRequestToken(String text) throws Exception {
String request_token = "";
//以“&”字符切割字符串
String[] strSplitText = text.split("&");
//把切割后的字符串数组变成变量与数值组合的字典数组
Map paraText = new HashMap();
for (int i = 0; i < strSplitText.length; i++) {
//获得第一个=字符的位置
int nPos = strSplitText[i].indexOf("=");
//获得字符串长度
int nLen = strSplitText[i].length();
//获得变量名
String strKey = strSplitText[i].substring(0, nPos);
//获得数值
String strValue = strSplitText[i].substring(nPos+1,nLen);
//放入MAP类中
paraText.put(strKey, strValue);
}
if (paraText.get("res_data") != null) {
String res_data = paraText.get("res_data");
//解析加密部分字符串(RSA与MD5区别仅此一句)
if(AlipayConfig.sign_type.equals("0001")) {
res_data = RSA.decrypt(res_data, AlipayConfig.private_key, AlipayConfig.input_charset);
}
//token从res_data中解析出来(也就是说res_data中已经包含token的内容)
Document document = DocumentHelper.parseText(res_data);
request_token = document.selectSingleNode( "//direct_trade_create_res/reques