当前位置:首页 » 安卓系统 » 微信支付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,需要程序员自行处理,这种情况下自然是无法吊起支付的。

热点内容
编译原理视频下载 发布:2025-03-15 10:25:46 浏览:844
ftp用户权限设置linux 发布:2025-03-15 10:19:32 浏览:239
极光大数据库 发布:2025-03-15 10:11:48 浏览:582
智e付忘了登录密码在哪里修改 发布:2025-03-15 10:05:20 浏览:650
手机热点密码忘了怎么办 发布:2025-03-15 09:28:26 浏览:363
缓解压力锻炼方法 发布:2025-03-15 09:23:01 浏览:426
impdp存储过程 发布:2025-03-15 09:20:05 浏览:741
pythoniris 发布:2025-03-15 09:05:27 浏览:190
浪淘沙服务器怎么没有了 发布:2025-03-15 09:05:26 浏览:100
ftprpm安装包下载 发布:2025-03-15 09:03:53 浏览:723