android微信支付

转自:http://www.2cto.com/kf/201409/330136.html

准备:

1,导入微信的libs包libammsdk.jar;

2,测试时使用weixinDemo中的debug_keystore;

3,需要注意应用要通过审核,并且几个Key值正确,一下为微信支付Demo中的值:

?


1

2

3

4

5

6

7

8

9

10

//微信公众平台id;

privateString
app_wx_appid=WxConstants.app_wx_appid;

//微信开放平台和商户约定的密钥

privateString
app_wx_secret_key=
"db426a9829e4b49a0dcac7b4162da6b6";

//微信公众平台商户模块和商户约定的密钥

privateString
app_wx_parent_key=
"8934e7d15453e97507ef794cf7b0519d";

//微信公众平台商户模块和商户约定的支付密钥

privateString
app_wx_pay_key=
"L8LrMqqeGRxST5reouB0K66CaYAWpqhAVsq7ggKkxHCOastWksvuX1uvmvQclxaHoYd3ElNBrNO2DHnnzgfVG9Qs473M3DTOZug5er46FhuGofumV8H2FVR9qkjSlC5K";

//
商家向财付通申请的商家id */

privateString
app_tx_parent_key =
"1900000109";

==========================================

根据微信支付Demo,微信支付分为三步:

第一步,获取accessToken,accessToken值第二步要用;

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

privateclass

GetAccessTokenTask
extendsAsyncTask<void,void,=""wxgetaccesstokenresult="">
{

        @Override

        protectedWxGetAccessTokenResult
doInBackground(Void... params) {

            WxGetAccessTokenResult
result = getAccessToken();

            returnresult;

        }

        @Override

        protectedvoid

onPostExecute(WxGetAccessTokenResult result) {

            if(result.localRetCode
== WxLocalRetCode.ERR_OK) {

                GetPrepayIdTask
getPrepayId =
newGetPrepayIdTask();

                getPrepayId.execute(result);

            }

        }

     

    }</void,>

解析服务器响应

?


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

privateWxGetAccessTokenResult
getAccessToken() {

        WxGetAccessTokenResult
result =
newWxGetAccessTokenResult();

        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;

            returnresult;

        }

        String
content =
newString(buf);

        result.parseFrom(content);

        returnresult;

    }

第二步,根据第一步的accesstoken值,将 组装的商品参数Post给微信服务器

?


1

2

3

4

5

6

7

8

9

10

11

12

13

privateclass

GetPrepayIdTask
extendsAsyncTask<wxgetaccesstokenresult,
void,=""wxgetprepayidresult="">
{

        @Override

        protectedWxGetPrepayIdResult
doInBackground(WxGetAccessTokenResult... params) {

            WxGetPrepayIdResult
result = getPrepayId(params[
0]);

            returnresult;

        }

        @Override

        protectedvoid

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

privateWxGetPrepayIdResult
getPrepayId(WxGetAccessTokenResult accessTokenResult) {

        String
url = String.format(api_get_preorder_id,accessTokenResult.accessToken);

        String
entity = appSign.getWxPrepayAppSign();

         

        WxGetPrepayIdResult
result =
newWxGetPrepayIdResult();

         

        byte[]
buf = WeixinUtil.httpPost(url, entity);

        if(buf
==
null||
buf.length ==
0)
{

            result.localRetCode
= WxLocalRetCode.ERR_HTTP;

            returnresult;

        }

         

        String
content =
newString(buf);

        result.parseFrom(content);

        returnresult;

    }

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>
privatevoid

sendPayReq(WxGetPrepayIdResult result) {

         

        PayReq
req =
newPayReq();

        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 =
newLinkedList<namevaluepair>();

        signParams.add(newBasicNameValuePair("appid",
req.appId));

        signParams.add(newBasicNameValuePair("appkey",
app_wx_pay_key));

        signParams.add(newBasicNameValuePair("noncestr",
req.nonceStr));

        signParams.add(newBasicNameValuePair("package",
req.packageValue));

        signParams.add(newBasicNameValuePair("partnerid",
req.partnerId));

        signParams.add(newBasicNameValuePair("prepayid",
req.prepayId));

        signParams.add(newBasicNameValuePair("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

packagenet.sourceforge.simcpux.wxapi;

publicclass

WXPayEntryActivity
extendsActivity
implementsIWXAPIEventHandler{<pre
name=
"code"class="java"><span
style=
"white-space:pre">
</span>
@Override

    publicvoid

onResp(BaseResp resp) {

        Log.d(TAG,"onPayFinish,
errCode = "

+ resp.errCode);

 

        if(resp.getType()
== ConstantsAPI.COMMAND_PAY_BY_WX) {

            AlertDialog.Builder
builder =
newAlertDialog.Builder(this);

            builder.setTitle("支付结果");

            builder.setMessage("支付结果"+String.valueOf(resp.errCode));

            builder.show();

        }

    }</pre>}

<p></p>

<preclass="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>


3,对应的支付界面

转载:http://blog.csdn.net/chaoyu168/article/details/49423529

时间: 2024-09-21 20:42:58

android微信支付的相关文章

android微信支付问题总结

首先我们先看一个android微信支付时遇到的一个错误提示: onPayFinish, errCode = -1  当你参数签名都没有问题的时候,出现这个提示,请按照如下操作: 在你的项目测试android微信的组件(微信分享.微信支付等)的时候,一定要用你自己的keystore签名出来测试,如果用debug.keystore肯定是不成功的! 本文部分内容转自:http://blog.csdn.net/baidu_17508977/article/details/44517283 1,在微信开放

Android微信支付3.0版本

问题描述 Android微信支付3.0版本 根据开发文档以及网上给的demo总是调不通,apk也是打包签名了的!客户端自己实现第一次签名和第二次签名总是支付结果总是-1,我也是无能为力了!求大神指点 解决方案 android微信支付android 微信支付android微信支付 解决方案二: http://download.csdn.net/detail/baidu_17508977/8521101 解决方案三: 可以看下 Ping++ Android 支付接口:https://www.ping

android微信支付源码分享_Android

本文为大家分享了android微信支付源码,供大家参考,具体内容如下 参数配置 public static final String APP_ID ; /** 在微信开放平台注册app,微信给分配的id **/ public static final String MCH_ID; /** 申请开通微信支付,成功后微信会给你发一封邮件,给你分配一个商户平台账号,在资料里有商户ID **/ public static final String API_KEY; /** 在微信发给你的那封邮件里,给你

设备数量限制-Android微信支付对设备数量有限制?

问题描述 Android微信支付对设备数量有限制? 情况是这样:我在自己的app里接入了微信支付功能(但app还未正式上线),现在拿多台设备测试微信支付时,发现,只有一台是可以弹出微信支付界面的.把这台的app删掉后.用另一台支付,另一台也是可以支付的,其余的都不行.(归纳一下就是,同时只能有一台设备用微信支付).求遇到过这类问题的大神指导 解决方案 问题解决了,确实是我代码有问题,少了一句 api.registerApp(APP_ID); //把App注册到微信. 不过,依然很感谢您的帮助.

android微信支付的服务端该怎么写,官网demo看半天都看不明白,有没有手把手教程,要服务端的

问题描述 android微信支付的服务端该怎么写,官网demo看半天都看不明白,有没有手把手教程,要服务端的 android微信支付的服务端该怎么写,官网demo看半天都看不明白,有没有手把手教程,要服务端的 解决方案 微信开发者文档里面写了恩 解决方案二: 我之前微信支付服务端是用demo中的asp写的如果有需要,可以联系我QQ360206731 解决方案三: --同样困惑中,找资料了看不太懂哪

android微信支付总是返回-1的问题

问题描述 android微信支付总是返回-1的问题 目前问题是清空微信数据和再次签名是可以支付的,但后面就不可以支付了,这是什么原因呢? sign的值是我自己拼接的,我后台log打印的看到每次支付的sign也是不一样的. 支付返回-1是什么原因呢? 官方说错误返回码有4开头的四位数字 ,我怎么没看见? 解决方案 每次支付的sign也是不一样的 是的,sign是根据你其它参数算出来的,你的sign错了,当然返回错误. 官方文档列出的可能错误原因:签名错误.未注册APPID.项目设置APPID不正确

Android 微信支付总看到签名 这是什么? 要调用微信支付一定要有签名吗?

问题描述 Android 微信支付总看到签名 这是什么? 要调用微信支付一定要有签名吗? Android 微信支付总看到签名 这是什么? 要调用 签名是自己搞签名还是官方签名代码复制过来 解决方案 每个应用都有,不用你自己去写 解决方案二: 就是应用的签名,可以用微信提供的软件获取手机上应用的签名 解决方案三: 微信支付---签名

解决方案-android 微信支付怎么让官方给的Demo跑起来?

问题描述 android 微信支付怎么让官方给的Demo跑起来? 最近做项目,需要用到微信支付,看了官方的文档,也把官方给的Demo下载下来了,运行时可以生成prepare_id,请求参数,但点击调起微信支付按钮时返回了-1,不能成功调起微信支付的界面出来,这是怎么回事呢?(Demo里Constants类里的参数是用的微信Demo里的,不是自己项目里的哈!) 网上看了下解决方案,说的是用demo工程目录下的keystore ![图片说明](http://img.ask.csdn.net/uplo

Android微信支付获取二次签名Sign的方法_Android

本文实例为大家分享了Android微信支付获取二次签名Sign的方法,供大家参考,具体内容如下 /** * 获取sign签名 * * @return */ private String genPayReq() { // 获取参数的值 PayReq request = new PayReq(); request.appId = ConstantsMember.APP_ID; request.partnerId = ConstantsMember.MCHID; request.prepayId =

Android微信支付开发问题_Android

并不是所有的BAT的API都是非常好用的,微信支付就有不少的缺陷,总结一下微信支付实现中出现的问题   坑点一:   PayReq的参数 sign的生成   PayReq对象有个参数为packageValue 而sign生成时要用到packageValue,但是对应的Key是package,这里的key容易弄错 复制代码 代码如下: List<NameValuePair> signParams = new LinkedList<NameValuePair>();         s