微信支付
时间:2022-04-25
本文章向大家介绍微信支付,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
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,对应的支付界面
- 11g备库无法开启ADG的原因分析 (r7笔记第62天)
- JDBC基础入门(3)
- Python多元线性回归-sklearn.linear_model,并对其预测结果评估
- python 聚类分析实战案例:K-means算法(原理源码)
- JAVA面试题解惑——final、finally和finalize的区别
- Java内存管理
- python基础知识——内置数据结构(字典)
- mysql、mongodb、python(dataframe).聚合函数的形式,以及报错解决方案
- JavaScript计算水仙花数【可自定义范围】
- JSP简单入门(1)
- mongodb取出json,利用python转成dataframe(dict-to-dataframe)
- JSP简单入门(2)
- JSP简单入门(3)
- 物化视图相关的性能改进 (r7笔记第58天)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- R语言使用随机技术差分进化算法优化的Nelson
- R语言用神经网络改进Nelson-Siegel模型拟合收益率曲线分析
- R语言和QuantLib中Nelson-Siegel模型收益曲线建模分析
- 用R语言用Nelson Siegel和线性插值模型对债券价格和收益率建模
- R语言LME4混合效应模型研究教师的受欢迎程度
- R语言Black Scholes和Cox-Ross-Rubinstein期权定价模型案例
- R语言中的风险价值模型度量指标TVaR与VaR
- R语言用线性回归模型预测空气质量臭氧数据
- R语言线性模型臭氧预测: 加权泊松回归,普通最小二乘,加权负二项式模型
- R语言中回归和分类模型选择的性能指标
- R语言 线性混合效应模型实战案例
- R语言中敏感性和特异性、召回率和精确度作为选型标准的华夫图案例
- R语言中的多类别问题的绩效衡量:F1-score 和广义AUC
- Dart语言基础Map、List、Set操作合辑
- 2.2.2 类反射场景与使用 -《SSM深入解析与项目实战》