微信支付实例

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

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

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

//微信公众平台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值第二步要用;

privateclassGetAccessTokenTask extendsAsyncTask<void,void,=""wxgetaccesstokenresult=""> {
        @Override
        protectedWxGetAccessTokenResult doInBackground(Void... params) {
            WxGetAccessTokenResult result = getAccessToken();
            returnresult;
        }
        @Override
        protectedvoidonPostExecute(WxGetAccessTokenResult result) {
            if(result.localRetCode == WxLocalRetCode.ERR_OK) {
                GetPrepayIdTask getPrepayId = newGetPrepayIdTask();
                getPrepayId.execute(result);
            }
        }
     
    }</void,>

解析服务器响应

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给微信服务器

privateclassGetPrepayIdTask extendsAsyncTask<wxgetaccesstokenresult,void,=""wxgetprepayidresult=""> {
        @Override
        protectedWxGetPrepayIdResult doInBackground(WxGetAccessTokenResult... params) {
            WxGetPrepayIdResult result = getPrepayId(params[0]);
            returnresult;
        }
        @Override
        protectedvoidonPostExecute(WxGetPrepayIdResult result) {
            if(result.localRetCode == WxLocalRetCode.ERR_OK) {
                sendPayReq(result);
            }
        }
    }</wxgetaccesstokenresult,>

组装参数

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给服务器

<span style="white-space:pre">  </span>privatevoidsendPayReq(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:

packagenet.sourceforge.simcpux.wxapi;
publicclassWXPayEntryActivity extendsActivityimplementsIWXAPIEventHandler{<pre name="code"class="java"><span style="white-space:pre"> </span>@Override
    publicvoidonResp(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,对应的支付界面

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏青玉伏案

iOS逆向工程之Hopper中的ARM指令

虽然前段时间ARM被日本软银收购了,但是科技是无国界的,所以呢ARM相关知识该学的学。现在看ARM指令集还是倍感亲切的,毕竟大学里开了ARM这门课,并且做了不少...

34970
来自专栏生信宝典

Linux学习-文件排序和FASTA文件操作

环境变量的补充 PATH只是众多环境变量中的一个变量,用于存储可执行文件所在的目录,以便在用户输入命令时可以查询的到。尤其是自己写的脚本或安装的程序,系统不会知...

279100
来自专栏Elasticsearch实验室

Elasitcsearch 底层系列 Lucene 内核解析之 Doc Value

       Elasticsearch 支持行存和列存,行存用于以文档为单位顺序存储多个文档的原始内容,在 Elasitcsearch 底层系列 Lucene...

46650
来自专栏Charlie's Road

<Solidity学习系列四>使用编译器

Solidity存储库的一个构建目标是solc,solidity命令行编译器。 使用solc --help为您提供所有选项的解释。 编译器可以生成各种输出,范围...

16120
来自专栏纯洁的微笑

Guava 源码分析(Cache 原理【二阶段】)

在上文「Guava 源码分析(Cache 原理)」中分析了 Guava Cache 的相关原理。

18710
来自专栏安恒网络空间安全讲武堂

PWNCTF部分复现

根据readData和writedata函数的逻辑发现数组是char [22][12],主要是判断越界的if语句有逻辑漏洞

24920
来自专栏IT杂记

通过Java程序提交通用Mapreduce无法回收类的问题

问题描述 上次发布的博客 通过Java程序提交通用Mapreduce,在实施过程中发现,每次提交一次Mapreduce任务,JVM无法回收过程中产生的MapRe...

31460
来自专栏Golang语言社区

Golang语言 之网络

Go语言标准库里提供的net包,支持基于IP层、TCP/UDP层及更高层面(如HTTP、FTP、SMTP)的网络操作,其中用于IP层的称为Raw Socket。...

37190
来自专栏Java学习网

Java Web Response对象的27个方法及状态码

response表示HttpServletResponse对象,主要将JSP容器处理后的结果传回到客户端。 ? 网络配图 1、void addCookie(...

51170
来自专栏大内老A

IoC+AOP的简单实现

对EnterLib有所了解的人应该知道,其中有一个名叫Policy Injection的AOP框架;而整个EnterLib完全建立在另一个叫作Unity的底层框...

21690

扫码关注云+社区

领取腾讯云代金券