当前位置: 首页 > news >正文

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;
private String app_wx_appid=WxConstants.app_wx_appid;
//微信开放平台和商户约定的密钥
private String app_wx_secret_key= "db426a9829e4b49a0dcac7b4162da6b6" ;
//微信公众平台商户模块和商户约定的密钥
private String app_wx_parent_key= "8934e7d15453e97507ef794cf7b0519d" ;
//微信公众平台商户模块和商户约定的支付密钥
private String app_wx_pay_key= "L8LrMqqeGRxST5reouB0K66CaYAWpqhAVsq7ggKkxHCOastWksvuX1uvmvQclxaHoYd3ElNBrNO2DHnnzgfVG9Qs473M3DTOZug5er46FhuGofumV8H2FVR9qkjSlC5K" ;
// 商家向财付通申请的商家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>
\
3,对应的支付界面

\


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

相关文章:

  • 13 款惊艳的 Node.js 框架——第1部分
  • shell学习笔记2---awk字符串处理(原创)
  • 各主流浏览器的区别
  • java获取真实ip地址
  • 简单查询(1)
  • 详解Zoosk千万用户实时通信背后的开源技术[转]
  • 【转】jvm 内存模型及内存调优
  • UESTC 75 The Queen's New Necklaces
  • 冯·若依曼体系结构
  • MySQL学习总结(二)数据库以及表的基本操作
  • 关于Android中设置闹钟的相对比较完善的解决方案
  • Swift 中的尾递归和蹦床
  • 关于学习了《构建之法》的若干存在疑惑的问题
  • spring 整合 struts
  • open-falcon+grafana出图
  • 【从零开始安装kubernetes-1.7.3】2.flannel、docker以及Harbor的配置以及作用
  • 2019.2.20 c++ 知识梳理
  • Android Volley源码解析
  • ES6语法详解(一)
  • JAVA并发编程--1.基础概念
  • js面向对象
  • node.js
  • oldjun 检测网站的经验
  • Promise面试题,控制异步流程
  • Three.js 再探 - 写一个跳一跳极简版游戏
  • Vue实战(四)登录/注册页的实现
  • 阿里研究院入选中国企业智库系统影响力榜
  • 大整数乘法-表格法
  • 第十八天-企业应用架构模式-基本模式
  • 老板让我十分钟上手nx-admin
  • 智能合约开发环境搭建及Hello World合约
  • Hibernate主键生成策略及选择
  • Linux权限管理(week1_day5)--技术流ken
  • mysql 慢查询分析工具:pt-query-digest 在mac 上的安装使用 ...
  • Unity3D - 异步加载游戏场景与异步加载游戏资源进度条 ...
  • # 再次尝试 连接失败_无线WiFi无法连接到网络怎么办【解决方法】
  • #define用法
  • #pragma预处理命令
  • #stm32驱动外设模块总结w5500模块
  • #Z2294. 打印树的直径
  • (16)UiBot:智能化软件机器人(以头歌抓取课程数据为例)
  • (MIT博士)林达华老师-概率模型与计算机视觉”
  • (附源码)springboot 基于HTML5的个人网页的网站设计与实现 毕业设计 031623
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (附源码)计算机毕业设计SSM基于java的云顶博客系统
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (数位dp) 算法竞赛入门到进阶 书本题集
  • (转)Java socket中关闭IO流后,发生什么事?(以关闭输出流为例) .
  • (转)jdk与jre的区别
  • (转)memcache、redis缓存
  • (转)Windows2003安全设置/维护
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .NET 反射 Reflect
  • .Net 路由处理厉害了
  • .net 重复调用webservice_Java RMI 远程调用详解,优劣势说明