當前位置:首頁 » 安卓系統 » 微信支付android開發

微信支付android開發

發布時間: 2025-03-15 05:29:35

① android開發集成微信的時候,分享功能後能回調WXEntryActivity,但是支付功能支付成功後不回調

你好,支付成功回調的是 WXPayEntryActivity,在onResp
方法裡面進行判斷是否支付成功!記得在AndroidManifest裡面配置一下!

② 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>
\

③ Android 微信H5支付,無法拉起微信支付頁面

最近我其中一個項目需要接入微信支付,實現方式是在WebView里利用Url拉起微信支付頁面,但是實際操作的時候卻發現始終無法拉起支付頁面,最後排查了一段時間,發現原來是因為一個很簡單的問題出錯了,於是解決問題以後特意想把這個問題記錄下來分享,也便於以後自己解決同類問題。

可以看到,這里return 返回的是false,問題出在這里。這時我又在想,為什麼會這樣?

查閱資料以後我發現shouldOverrideUrlLoading的返回值的意義為:

那麼這種情況下,返回值應該改為 false或者super .shouldOverrideUrlLoading(view, url); ,因為微信支付調用 https://wx.tenpay.com/cgi-bin/mmpayweb-bin/checkmweb 這個開頭的url後,會重定向到 weixin://wap/pay 開頭的url,然後調用微信客戶端支付,如果用true,則WebView不會自動重定向到 weixin://wap/pay 開頭的url,需要程序員自行處理,這種情況下自然是無法吊起支付的。

熱點內容
linux調試匯編 發布:2025-03-15 08:38:09 瀏覽:106
手機上編寫c語言 發布:2025-03-15 08:17:53 瀏覽:754
上傳迅雷下載速度 發布:2025-03-15 08:07:50 瀏覽:554
好看解壓書 發布:2025-03-15 08:04:18 瀏覽:672
文字頁游源碼 發布:2025-03-15 08:02:29 瀏覽:315
怎麼看自己微信密碼 發布:2025-03-15 07:53:58 瀏覽:791
androidchecked 發布:2025-03-15 07:50:22 瀏覽:551
百度carplay怎麼連接安卓手機 發布:2025-03-15 07:49:39 瀏覽:24
捕捉圖片上傳 發布:2025-03-15 07:49:01 瀏覽:796
手機內核升級編譯 發布:2025-03-15 07:43:22 瀏覽:237