A. 安卓手機怎麼開啟微信支付
1、在微信中或許您找不到微信支付的通道,沒有任何可綁定銀行卡的入口。其實,當您第一次進行支付時會提供給您綁定銀行卡的入口,綁定後,就可以在其他公眾帳號中完成微信支付。
2、現在我們來完成首次支付操作以綁定銀行卡。在微信主界面切換到「我」界面,然後點擊列表項中的「表情商店」選項,如圖所示。
3、在新界面中選擇一套表情進行購買操作,如「飯團和他的朋友們」,點擊右邊的價格按鈕購買此套表情(不是真的購買,只是為了演示給大家如何綁定銀行卡)。
4、點擊「付款」按鈕開始使用微信支付,支付時需要綁定銀行卡。請輸入持卡人銀行卡號碼,然後點擊「下一步」按鈕。
5、輸入銀行卡類型、銀行預留持卡人姓名、身份證、手機號等個人信息。稍後會收到簡訊驗證碼,微信會自動獲取簡訊驗證碼,點擊「下一步」按鈕即可。
6、下面的操作需要設置微信安全支付6位數字密碼,需要用戶自行執行,就不累述了,相信您已經知道如何綁定銀行卡了!記得不要執行到最後,不然真的購買6元表情了。
7、綁定銀行卡快捷支付後,下次在公眾帳號、掃二維碼、App中進行微信支付時就不需要再次綁定,只需輸入支付密碼即可完成支付。您可以在「我 -> 個人頭像 -> 個人信息 -> 我的銀行卡」下管理已綁定的銀行卡或添加新的銀行卡。
B. 微信支付不成功,閃一下窗口就提示交易取消了返回到首頁
一、文件損壞造成微信閃退遇到這個問題反復重新安裝微信是解決不了問題,需要先清空微信數據然後重新安裝才可以。按菜單鍵,找到系統設置->應用程序(部分手機名稱不一樣),在列表中找到微信圖標,點擊彈出程序信息界面,點擊清空數據即可。
二、SD卡空間不足造成閃退很多游戲或軟體在SD卡空間不足的情況下會出現閃退。按菜單鍵,找到系統設置->存儲(部分手機名稱不一樣),如果可用空間小於1M時,就應該刪除或清理一些應用。
C. android微信支付demo怎麼開通零錢支付
准備:
1,導入微信的libs包libammsdk.jar;
2,測試時使用weixinDemo中的debug_keystore;
3,需要注意應用要通過審核,並且幾個Key值正確,一下為微信支付Demo中的值:
?
1
2
3
4
5
6
7
8
9
10
//微信公眾平台id;
private
String app_wx_appid=WxConstants.app_wx_appid;
//微信開放平台和商戶約定的密鑰
private
String app_wx_secret_key="";
//微信公眾平台商戶模塊和商戶約定的密鑰
private
String app_wx_parent_key="";
//微信公眾平台商戶模塊和商戶約定的支付密鑰
private
String app_wx_pay_key="";
//
商家向財付通申請的商家id */
private
String app_tx_parent_key = "1900000109";
==========================================
根據微信支付Demo,微信支付分為三步:
第一步,獲取accessToken,accessToken值第二步要用;
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private
class
GetAccessTokenTask extends
AsyncTask<void,
void,=""
wxgetaccesstokenresult="">
{
@Override
protected
WxGetAccessTokenResult doInBackground(Void... params) {
WxGetAccessTokenResult
result = getAccessToken();
return
result;
}
@Override
protected
void
onPostExecute(WxGetAccessTokenResult result) {
if
(result.localRetCode == WxLocalRetCode.ERR_OK) {
GetPrepayIdTask
getPrepayId = new
GetPrepayIdTask();
getPrepayId.execute(result);
}
}}</void,>
解析伺服器響應
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
private
WxGetAccessTokenResult getAccessToken() {
WxGetAccessTokenResult
result = new
WxGetAccessTokenResult();
String
url = String.format(api_get_access_token,
"client_credential",
app_wx_appid,
app_wx_secret_key);
byte[]
buf = WeixinUtil.httpGet(url);
if
(buf == null
|| buf.length == 0)
{
result.localRetCode
= WxLocalRetCode.ERR_HTTP;
return
result;
}
String
content = new
String(buf);
result.parseFrom(content);
return
result;
}
第二步,根據第一步的accesstoken值,將 組裝的商品參數Post給微信伺服器
?
1
2
3
4
5
6
7
8
9
10
11
12
13
private
class
GetPrepayIdTask extends
AsyncTask<wxgetaccesstokenresult, void,=""
wxgetprepayidresult="">
{
@Override
protected
WxGetPrepayIdResult doInBackground(WxGetAccessTokenResult... params) {
WxGetPrepayIdResult
result = getPrepayId(params[0]);
return
result;
}
@Override
protected
void
onPostExecute(WxGetPrepayIdResult result) {
if
(result.localRetCode == WxLocalRetCode.ERR_OK) {
sendPayReq(result);
}
}
}</wxgetaccesstokenresult,>
組裝參數
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
private
WxGetPrepayIdResult getPrepayId(WxGetAccessTokenResult accessTokenResult) {
String
url = String.format(api_get_preorder_id,accessTokenResult.accessToken);
String
entity = appSign.getWxPrepayAppSign();WxGetPrepayIdResult
result = new
WxGetPrepayIdResult();byte[]
buf = WeixinUtil.httpPost(url, entity);
if
(buf == null
|| buf.length == 0)
{
result.localRetCode
= WxLocalRetCode.ERR_HTTP;
return
result;
}String
content = new
String(buf);
result.parseFrom(content);
return
result;
}
Post給伺服器
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<span
style="white-space:pre">
</span>private
void
sendPayReq(WxGetPrepayIdResult result) {PayReq
req = new
PayReq();
req.appId
= app_wx_appid;
req.partnerId
= app_tx_parent_key;
req.prepayId
= result.prepayId;
req.nonceStr
= appSign.getNoncestr();
req.timeStamp
= appSign.getTimestamp();
req.packageValue
= "Sign="
+ appSign.getPackageSign();List<namevaluepair>
signParams = new
LinkedList<namevaluepair>();
signParams.add(new
BasicNameValuePair("appid",
req.appId));
signParams.add(new
BasicNameValuePair("appkey",
app_wx_pay_key));
signParams.add(new
BasicNameValuePair("noncestr",
req.nonceStr));
signParams.add(new
BasicNameValuePair("package",
req.packageValue));
signParams.add(new
BasicNameValuePair("partnerid",
req.partnerId));
signParams.add(new
BasicNameValuePair("prepayid",
req.prepayId));
signParams.add(new
BasicNameValuePair("timestamp",
req.timeStamp));
req.sign
= WeixinUtil.genSign(signParams);wxRequest.sendReq(req);
}</namevaluepair></namevaluepair>
?
1
?
1
第三步:在項目下新建一個包wxapi,建立一個類名為WXPayEntryActivity作為接受微信的支付結果,不過最終結果以伺服器的返回為准notify_url:
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
package
net.sourceforge.simcpux.wxapi;
public
class
WXPayEntryActivity extends
Activity implements
IWXAPIEventHandler{<pre name="code"
class="java"><span
style="white-space:pre">
</span>@Override
public
void
onResp(BaseResp resp) {
Log.d(TAG,
"onPayFinish,
errCode = "
+ resp.errCode);if
(resp.getType() == ConstantsAPI.COMMAND_PAY_BY_WX) {
AlertDialog.Builder
builder = new
AlertDialog.Builder(this);
builder.setTitle("支付結果");
builder.setMessage("支付結果"+String.valueOf(resp.errCode));
builder.show();
}
}</pre>}
<p></p>
<pre
class="brush:java;"></pre>
==========================================
<p></p>
<p>暫時沒想到其他想說的,先看個效果</p>
<p>1,包結構,需要注意的就是接收微信返回結果的那個類名;</p>
<p><img
src="http://www.2cto.com/uploadfile/Collfiles/20140901/201409010901522.png"
alt="\"
style="display:
inline; width: 239px; height: 238px;"></p>
<p>2,組裝數據,規則在文檔中有說明<喎�"http://www.2cto.com/kf/ware/vc/"
target="_blank"
class="keylink">vcD4KPHByZSBjbGFzcz0="brush:java;">//package_
欄位生成方法
//package生成方法:
//A)對所有傳入參數按照欄位名的ASCII
碼從小到大排序(字典序)後,使用URL 鍵值對的格式(即key1=value1&key2=value2…)拼接成字元串string1;
//B)
在string1 最後拼接上key=partnerKey 得到stringSignTemp 字元串, 並對 stringSignTemp進行md5 運算,再將得到的字元串所有字元轉換為大寫,得到sign值signValue。
//C)對string1
中的所有鍵值對中的value 進行urlencode 轉碼,按照a 步驟重新拼接成字元串,得到string2。對於js 前端程序,一定要使用函數encodeURIComponent 進行urlencode編碼(注意!進行urlencode時要將空格轉化為%20而不是+)。
//D)將sign=signValue
拼接到string1 後面得到最終的package 字元串。//app_signature生成方法:
//A)參與簽名的欄位包括:appid、appkey、noncestr、package、timestamp以及
traceid
//B)對所有待簽名參數按照欄位名的ASCII
碼從小到大排序(字典序)後,使用URL 鍵值對的格式(即key1=value1&key2=value2…)拼接成字元串string1。 注意:所有參數名均為小寫字元
//C)對string1
作簽名演算法,欄位名和欄位值都採用原始值,不進行URL 轉義。具體簽名演算法為SHA1</p>
\
D. Android接入微信支付之-1錯誤碼踩坑之旅
微信支付文檔寫的真的棒啊!少林功夫真的好啊!
永遠猜不到-1錯誤碼是啥問題。
順便介紹下簽名文件:
debug.keystore:
在Android Stio中系統默認內置了一個簽名文件debug.keystore,用於我們在debug下的默認App簽名。
release.keystore:
由用戶自己生成
獲取簽名信息:
打開電腦終端,輸入以下命令:
可以看到簽名信息的MD5、sha1、sha256值。微信支付需要的就是MD5的去冒號小寫版。例如本機:。
也可以在Android Studio底部tools window中的terminal中敲命令
清單文件AndroidManifest.xml中WXPayEntryActivity的聲明配置:
errCode -1:簽名錯誤,所說的簽名就是第三個sign。當然還有APPID未通過,和APPID注冊的和返回的不一樣,這個是「微信開放平台」里的東西。
E. 微信支付開發 返回-1
如果是APP使用正常中,突然返回-1,可能是被微信風控了,這個很難申訴,而且這個找客服是查不到的。微信沒有具體返回碼的錯誤都是返回-1。
F. android怎麼實現微信支付
APP想要接入微信支付,請先獲取開發平台帳號,並且獲取開發者資質認證。這資質認證可在開發平台申請,並提交相關資料。認證通過後,提交APP以獲取AppID才能繼續申請。
隨後登錄開放平台,在管理中心中選擇所需的APP,點擊右側的申請開通,提交所需材料。審核通過後,可通過發送到開戶郵箱中的商戶賬號和密碼登錄商戶平台進行驗證,最後在線簽署協議,並根據附件中的開發文檔啟動設計和開發。
G. Unity-Android集成微信支付出現返回-1問題
前段時間出去玩了一段時間,回公司得知一個驚天消息——微信支付出問題了!!!這個問題比較奇怪,說是部分機型可以支付成功,部分機型如小米、三星無法調起支付,返回-1。
眾所周知返回-1的話代表了各種各樣的錯誤(坑),所以只好從頭開始排查,首先排查 WXPayEntryActivity.java 這個文件是否放在了 .wxapi包 下,及 manifest里的注冊是否為.wxapi.WXPayEntryActivity ,確定無誤後檢查後台返回的參數是否有誤
至此如果都正確,可以開始著手檢查在後台里的參數設置是否正確
這里需要注意的是應用簽名和應用包名,因為出問題的包不是由我打包的,我懷疑問題在於應用簽名對不上,最後發現果然如此。打包的同事使用了另一個keystore文件進行打包,導致應用簽名與後台填寫的不一致,於是重新生成了簽名更新後台設置,問題解決。
至於為什麼部分機型可以正常支付,而部分機型無法調起,我參照有些coder遇到的問題「微信支付只能成功調起一次」
因為成功支付的機型為公司測試機,而不成功的機型是用戶機,猜測因為公司測試機里曾經調試過微信支付,有正確的包名和簽名的緩存,微信在調起時直接讀取緩存值,驗證正確後直接調起,而當緩存值出錯時微信才會再次去讀取新的包名和簽名重新驗證,因此出現了部分機型可支付的問題。也因為這個原因, 修改完簽名後再次調試,第一次返回的還是-1,但再次點擊就可以成功調起,此後也沒有再返回-1。 個人猜測,如有錯誤歡迎指出討論。
微信支付的坑實在是太多了,還有OC編寫的iOS的IAP也有很多藏起來的坑,一直想把Unity內調用Java集成的微信、支付寶支付,使用OC集成的iOS內購詳細過程寫上來,但是一直犯懶。。這段時間一定要寫好,給自己做個記錄,也給大家作為一個參考。
H. android 微信支付問題,老是返回-1
你好,這個需要對接的,首先需要開通微信支付功能,然後對接到微信支付平台就可以了。 親,我的回答你滿意嗎?滿意的話給個採納吧!或者你可以選擇繼續向我追問哦。
I. android開發微信支付集成客戶端二次簽名怎麼做
1.客戶端代碼得到用戶購買的商品信息,將之傳給自己公司app伺服器,參數包含但不限於以下:
params.put("appid", appID);// 微信appid,選擇性上傳,伺服器寫死亦可
params.put("money", money);// 支付金額,單位:分
params.put("name", goodsName);// 商品名稱
params.put("currencytype", "CNY");// 支付幣種,只能填CNY,代表人民幣12341234
備註:以上是參數欄位是我們公司伺服器定義,給伺服器用以獲取預支付訂單號prePayId用。
備注2:詳細欄位請參考:https://pay.weixin.qq.com/wiki/doc/api/app/app.php?chapter=9_1
2.app伺服器調用微信「統一下單」介面,得到prePayId訂單號並返回prePayId給手機客戶端;
3.手機客戶端使用prePayId及商品信息調起微信客戶端進行支付;
3.1用戶操作:輸入密碼進行支付;返回鍵取消支付;網路無連接支付失敗等;
4.微信客戶端回調支付結果給咱們的APP客戶端;
5.微信伺服器非同步通知咱們公司app伺服器支付結果(伺服器的工作,與客戶端無關)
這個其實很簡單的,demo文檔寫得很詳細,直接上代碼吧:
/**
* 獲取sign簽名
*
* @return
*/
private String genPayReq() {
// 獲取參數的值
PayReq request = new PayReq();
request.appId = ConstantsMember.APP_ID;
request.partnerId = ConstantsMember.MCHID;
request.prepayId = mPrepayId;
request.packageValue = "Sign=WXPay";
request.nonceStr = DataUtil.getGuid();
request.timeStamp = DataUtil.getTimeStamp();
// 把參數的值傳進去SortedMap集合裡面
SortedMap<Object, Object> parameters = new TreeMap<Object, Object>();
// {appid=wx34df375d7dae8c90, noncestr=,
// package=Sign=WXPay, partnerid=1349967601,
// prepayid=, timestamp=1468031760}
parameters.put("appid", request.appId);
parameters.put("noncestr", request.nonceStr);
parameters.put("package", request.packageValue);
parameters.put("partnerid", request.partnerId);
parameters.put("prepayid", request.prepayId);
parameters.put("timestamp", request.timeStamp);
String characterEncoding = "UTF-8";
String mySign = createSign(characterEncoding, parameters);
System.out.println("我的簽名是:" + mySign);
return mySign;
}
/**
* 微信支付簽名演算法sign
*
* @param characterEncoding
* @param parameters
* @return
*/
public static String createSign(String characterEncoding,
SortedMap<Object, Object> parameters) {
StringBuffer sb = new StringBuffer();
Set es = parameters.entrySet();// 所有參與傳參的參數按照accsii排序(升序)
Iterator it = es.iterator();
while (it.hasNext()) {
@SuppressWarnings("rawtypes")
Map.Entry entry = (Map.Entry) it.next();
String k = (String) entry.getKey();
Object v = entry.getValue();
if (null != v && !"".equals(v) && !"sign".equals(k)
&& !"key".equals(k)) {
sb.append(k + "=" + v + "&");
}
}
sb.append("key=" + ConstantsMember.KEY); //KEY是商戶秘鑰
String sign = MD5Util.MD5Encode(sb.toString(), characterEncoding)
.toUpperCase();
return sign; //
//
}