欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

新版Android studio導(dǎo)入微信支付和支付寶官方Demo問題解決大全

 更新時間:2016年07月27日 10:27:07   作者::南塵  
這篇文章主要為大家詳細介紹了新版Android studio導(dǎo)入微信支付和支付寶官方Demo問題的解決大全,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

最近項目要用到支付寶支付和微信支付,本想使用第三方支付框架ping++或者BeeCloud的,但是由于他們的收費問題,讓我望而卻步,而且公司給了相應(yīng)的公鑰、私鑰和APPID等,所以就用下開放平臺的唄。

進去倒騰了半天才發(fā)現(xiàn)一堆問題,Oh,我的天。完全不知所云,百度谷歌了一堆,都沒找到足夠的解決方案。好吧,自己來,這里也就把相關(guān)的東西分享給大家,如果有類似問題的可以考慮使用一下,不足的地方大牛就別噴了。

微信開放平臺有文檔和SDK,大家可以去自己查看下載,火箭:https://open.weixin.qq.com/ 

支付寶官方的Demo和文檔相對簡單些,而且說的更清楚些,火箭:https://open.alipay.com/platform/home.htm

還是先看下運行的Demo圖示:
首先是微信的

再看看支付寶的

點擊支付會跳轉(zhuǎn)到你手機上的支付寶APP,如果手機上沒有下載也是可以用的,不過用的不在一個真正的支付寶APP中

但是這么簡單的東西,樓主的確智商捉急,都弄了半天。

首先是導(dǎo)入微信的Demo,去官方下載了SimpleDemo后,發(fā)現(xiàn)一堆錯誤,好吧,首先是SDK的問題,這個就不多做贅述了。

然后修改后Try Again   oh,no,又來一個什么鬼。 

什么鬼,仔細一看,是drawable里面有不是png的文件命名成了png文件。

好吧,如果你足夠的耐心,那么幾十張圖片,你還是可以直接一張一張的檢查后綴的,看看有不是png作為后綴的,另存一下,或者修改你的文件名使其和后綴名一致。

然而程序員的能力應(yīng)該體現(xiàn)在偷懶的程度上,所以容我偷懶啦。

compileSdkVersion 23
 buildToolsVersion "24.0.0"
 aaptOptions.cruncherEnabled = false
 aaptOptions.useNewCruncher = false

 defaultConfig {
 applicationId "net.sourceforge.simcpux"
 minSdkVersion 4
 targetSdkVersion 23
}

只需要在對應(yīng)的gradle文件中加上兩句話 ,并把值至為false即可。

再次Try again, oh ,no,這次是一大堆錯誤,什么鬼!看一看日志。

哦,原來是因為6.0以后官方隱藏的HttpClient的相關(guān)API,然而大多數(shù)導(dǎo)入的代碼都還用著這個強大的框架,那怎么弄呢?
好的,只需要再在Gradle文件中添加這樣的一句話就好

 android {
 useLibrary 'org.apache.http.legacy'
 }

dependencies {
 compile files('libs/libammsdk.jar')

 android {
 useLibrary 'org.apache.http.legacy'
 }
}

再來看看支付寶的,就簡單多了。我遇到的第一個問題是,沒有指定APPID,公鑰那些東西,好的,這個肯定是得弄得,把自己申請的一系列東西裝進去。
運行一看。 

嘿嘿,有界面,應(yīng)該可以吧,點擊一下支付。

Oh on,直接崩潰

錯也總得有原因哈,看看日志。

空指針異常?進去一看
 sign = URLEncoder.encode(sign, "UTF-8");

是這樣一句話出現(xiàn)了問題,這句話什么問題呢。

/**
 * sign the order info. 對訂單信息進行簽名
 * 
 * @param content
 *  待簽名訂單信息
 */
 private String sign(String content) {
 return SignUtils.sign(content, RSA_PRIVATE);
 }

這個方法的問題,這樣返回的是一個空的。
 再進去一看

public static String sign(String content, String privateKey) {
 try {
  PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec(
   Base64.decode(privateKey));
  KeyFactory keyf = KeyFactory.getInstance(ALGORITHM);
  PrivateKey priKey = keyf.generatePrivate(priPKCS8);

  java.security.Signature signature = java.security.Signature
   .getInstance(SIGN_ALGORITHMS);

  signature.initSign(priKey);
  signature.update(content.getBytes(DEFAULT_CHARSET));

  byte[] signed = signature.sign();

  return Base64.encode(signed);
 } catch (Exception e) {
  e.printStackTrace();
 }

 return null;
 }

是這樣的一串代碼,原來這個方法是把私鑰轉(zhuǎn)換成應(yīng)該有的格式,而我公司給的意見轉(zhuǎn)換好了,好吧。
 那直接返回就成了唄

/**
 * sign the order info. 對訂單信息進行簽名
 * 
 * @param content
 *  待簽名訂單信息
 */
 private String sign(String content) {
// return SignUtils.sign(content, RSA_PRIVATE);
 return RSA_PRIVATE;
}

修改一下,再次運行。Oh yeah,成功!
今天就講這么多,有啥不懂的,還是運用萬能的百度吧!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論