微信支付

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值第二步要用;

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

解析服务器响应

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

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

组装参数

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

第三步:在项目下新建一个包wxapi,建立一个类名为WXPayEntryActivity作为接受微信的支付结果,不过最终结果以服务器的返回为准notify_url:

 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,对应的支付界面

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

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏coder修行路

Go实现短url项目

首先说一下这种业务的应用场景: 把一个长url转换为一个短url网址 主要用于微博,二维码,等有字数限制的场景 主要实现的功能分析: 把长url的地址转换为短u...

46550
来自专栏草根专栏

.NET Core/.NET之Stream简介

之前写了一篇C#装饰模式的文章提到了.NET Core的Stream, 所以这里尽量把Stream介绍全点. (都是书上的内容) .NET Core/.NET的...

43440
来自专栏菩提树下的杨过

RxJava2学习笔记(2)

上一篇已经熟悉了Observable的基本用法,但是如果仅仅只是“生产-消费”的模型,这就体现不出优势了,java有100种办法可以玩这个:) 一、更简单的多线...

54380
来自专栏Alice

demo3同通讯录展示的方式分组排序

按A-Z顺序分组展示 有些项目中会需要这样的需求。形成类似于上述的界面。类似于通讯录里边的排序。实现的效果:所有的数据展示的时候,能够分组展示。顺序按照A-Z的...

24790
来自专栏跟着阿笨一起玩NET

C# Eval在aspx页面中的用法及作用

34620
来自专栏Android 研究

OKHttp源码解析(五)--OKIO简介及FileSystem

okio是由square公司开发的,它补充了java.io和java.nio的不足,以便能够更加方便,快速的访问、存储和处理你的数据。OKHttp底层也是用该库...

31030
来自专栏数据结构与算法

BZOJ1269: [AHOI2006]文本编辑器editor

Descriptio 这些日子,可可不和卡卡一起玩了,原来可可正废寝忘食的想做一个简单而高效的文本编辑器。你能帮助他吗? 为了明确任务目标,可可对“文本编辑器...

30270
来自专栏三好码农的三亩自留地

Java动态代理-实战

说动态代理之前,要先搞明白什么是代理,代理的字面意思已经很容易理解了,我们这里撇开其他的解释,我们只谈设计模式中的代理模式

32420
来自专栏IT综合技术分享

使用Dropwizard搭建一个Hello World

官方例子中main方法写在Application类中,我这里将其提出来了,方便大家理解。

27530
来自专栏jeremy的技术点滴

JVM的Finalization Delay引起的OOM

43880

扫码关注云+社区

领取腾讯云代金券