如何查询微信支付记录交易记录上面显示的商品名是VIP服务的是什么呀?

golang微信支付服务端
- Go语言中文网 - Golang中文社区
<meta name="author" content="polaris ">
golang微信支付服务端
xyzhaopeng
· 5318 次点击 ·
开始浏览 & &
一般来说,使用golang主要还是写服务端。所以本文主要讲golang在处理微信移动支付的服务端时的统一下单接口和支付回调接口,以及查询接口。
微信支付流程
下图是微信官网的支付流程描述:
图中红色部分就是微信支付中,我们的系统包括app,后台需要参与的流程。
其中需要后台也就是Server需要参与的流程有三个:
1. 统一下单并返回客户端
2. 异步通知结果回调处理
3. 调用微信支付查询接口
微信所有的接口都是以http RESTFul的API来提供,所以对于server而言其实就是call这些接口并处理返回值。
golang的服务端实现
1,调用统一下单接口
首先需要呼叫: 这是微信的api,呼叫之后微信会返回我们一个prepay_id。调用的结果以微信正确的返回给我们prepay id为准。
按照微信文档说明,这个接口的参数没有,我们传入的参数需要以xml的形式来写入http request的body部分传给微信。
type UnifyOrderReq struct {
string `xml:&#34;appid&#34;`
string `xml:&#34;body&#34;`
string `xml:&#34;mch_id&#34;`
string `xml:&#34;nonce_str&#34;`
Notify_url
string `xml:&#34;notify_url&#34;`
Trade_type
string `xml:&#34;trade_type&#34;`
Spbill_create_ip string `xml:&#34;spbill_create_ip&#34;`
`xml:&#34;total_fee&#34;`
Out_trade_no
string `xml:&#34;out_trade_no&#34;`
string `xml:&#34;sign&#34;`
func wxpayCalcSign(mReq map[string]interface{}, key string) (sign string) {
fmt.Println(&#34;微信支付签名计算, API KEY:&#34;, key)
sorted_keys := make([]string, 0)
for k, _ := range mReq {
sorted_keys = append(sorted_keys, k)
sort.Strings(sorted_keys)
var signStrings string
for _, k := range sorted_keys {
fmt.Printf(&#34;k=%v, v=%v\n&#34;, k, mReq[k])
value := fmt.Sprintf(&#34;%v&#34;, mReq[k])
if value != &#34;&#34; {
signStrings = signStrings + k + &#34;=&#34; + value + &#34;&&#34;
if key != &#34;&#34; {
signStrings = signStrings + &#34;key=&#34; + key
md5Ctx := md5.New()
md5Ctx.Write([]byte(signStrings))
cipherStr := md5Ctx.Sum(nil)
upperSign := strings.ToUpper(hex.EncodeToString(cipherStr))
return upperSign
//请求UnifiedOrder的代码
var yourReq UnifyOrderReq
yourReq.Appid = &#34;app_id&#34; //微信开放平台我们创建出来的app的app id
yourReq.Body = &#34;商品名&#34;
yourReq.Mch_id = &#34;商户编号&#34;
yourReq.Nonce_str = &#34;your nonce&#34;
yourReq.Notify_url = &#34;/wxpayNotify&#34;
yourReq.Trade_type = &#34;APP&#34;
yourReq.Spbill_create_ip = &#34;xxx.xxx.xxx.xxx&#34;
yourReq.Total_fee = 10 //单位是分,这里是1毛钱
yourReq.Out_trade_no = &#34;后台系统单号&#34;
var m map[string]interface{}
m = make(map[string]interface{}, 0)
m[&#34;appid&#34;] = yourReq.Appid
m[&#34;body&#34;] = yourReq.Body
m[&#34;mch_id&#34;] = yourReq.Mch_id
m[&#34;notify_url&#34;] = yourReq.Notify_url
m[&#34;trade_type&#34;] = yourReq.Trade_type
m[&#34;spbill_create_ip&#34;] = yourReq.Spbill_create_ip
m[&#34;total_fee&#34;] = yourReq.Total_fee
m[&#34;out_trade_no&#34;] = yourReq.Out_trade_no
m[&#34;nonce_str&#34;] = yourReq.Nonce_str
yourReq.Sign = wxpayCalcSign(m, &#34;wxpay_api_key&#34;) //这个是计算wxpay签名的函数上面已贴出
bytes_req, err := xml.Marshal(yourReq)
if err != nil {
fmt.Println(&#34;以xml形式编码发送错误, 原因:&#34;, err)
str_req := string(bytes_req)
//wxpay的unifiedorder接口需要http body中xmldoc的根节点是&xml&&/xml&这种,所以这里需要replace一下
str_req = strings.Replace(str_req, &#34;XUnifyOrderReq&#34;, &#34;xml&#34;, -1)
bytes_req = []byte(str_req)
//发送unified order请求.
req, err := http.NewRequest(&#34;POST&#34;, unify_order_req, bytes.NewReader(bytes_req))
if err != nil {
fmt.Println(&#34;New Http Request发生错误,原因:&#34;, err)
req.Header.Set(&#34;Accept&#34;, &#34;application/xml&#34;)
//这里的http header的设置是必须设置的.
req.Header.Set(&#34;Content-Type&#34;, &#34;application/charset=utf-8&#34;)
c := http.Client{}
resp, _err := c.Do(req)
if _err != nil {
fmt.Println(&#34;请求微信支付统一下单接口发送错误, 原因:&#34;, _err)
//到这里统一下单接口就已经执行完成了
2,微信回调函数的处理
3,客户端查询订单请求响应
5318 次点击 &?& 2 赞 &
请尽量让自己的回复能够对别人有帮助
支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
支持 @ 本站用户;支持表情(输入 : 提示),见
记住登录状态
一般来说,使用golang主要还是写服务端。所以本文主要讲golang在处理微信移动支付的服务端时的统一下单接口和支付回调接口,以及查询接口。
微信支付流程
下图是微信官网的支付流程描述:
图中红色部分就是微信支付中,我们的系统包括app,后台需要参与的流程。
其中需要后台也就是Server需要参与的流程有三个:
1. 统一下单并返回客户端
2. 异步通知结果回调处理
3. 调用微信支付查询接口
微信所有的接口都是以http RESTFul的API来提供,所以对于server而言其实就是call这些接口并处理返回值。
golang的服务端实现
1,调用统一下单接口
首先需要呼叫: 这是微信的api,呼叫之后微信会返回我们一个prepay_id。调用的结果以微信正确的返回给我们prepay id为准。
按照微信文档说明,这个接口的参数没有,我们传入的参数需要以xml的形式来写入http request的body部分传给微信。
type UnifyOrderReq struct {
string `xml:&#34;appid&#34;`
string `xml:&#34;body&#34;`
string `xml:&#34;mch_id&#34;`
string `xml:&#34;nonce_str&#34;`
Notify_url
string `xml:&#34;notify_url&#34;`
Trade_type
string `xml:&#34;trade_type&#34;`
Spbill_create_ip string `xml:&#34;spbill_create_ip&#34;`
`xml:&#34;total_fee&#34;`
Out_trade_no
string `xml:&#34;out_trade_no&#34;`
string `xml:&#34;sign&#34;`
func wxpayCalcSign(mReq map[string]interface{}, key string) (sign string) {
fmt.Println(&#34;微信支付签名计算, API KEY:&#34;, key)
sorted_keys := make([]string, 0)
for k, _ := range mReq {
sorted_keys = append(sorted_keys, k)
sort.Strings(sorted_keys)
var signStrings string
for _, k := range sorted_keys {
fmt.Printf(&#34;k=%v, v=%v\n&#34;, k, mReq[k])
value := fmt.Sprintf(&#34;%v&#34;, mReq[k])
if value != &#34;&#34; {
signStrings = signStrings + k + &#34;=&#34; + value + &#34;&&#34;
if key != &#34;&#34; {
signStrings = signStrings + &#34;key=&#34; + key
md5Ctx := md5.New()
md5Ctx.Write([]byte(signStrings))
cipherStr := md5Ctx.Sum(nil)
upperSign := strings.ToUpper(hex.EncodeToString(cipherStr))
return upperSign
//请求UnifiedOrder的代码
var yourReq UnifyOrderReq
yourReq.Appid = &#34;app_id&#34; //微信开放平台我们创建出来的app的app id
yourReq.Body = &#34;商品名&#34;
yourReq.Mch_id = &#34;商户编号&#34;
yourReq.Nonce_str = &#34;your nonce&#34;
yourReq.Notify_url = &#34;/wxpayNotify&#34;
yourReq.Trade_type = &#34;APP&#34;
yourReq.Spbill_create_ip = &#34;xxx.xxx.xxx.xxx&#34;
yourReq.Total_fee = 10 //单位是分,这里是1毛钱
yourReq.Out_trade_no = &#34;后台系统单号&#34;
var m map[string]interface{}
m = make(map[string]interface{}, 0)
m[&#34;appid&#34;] = yourReq.Appid
m[&#34;body&#34;] = yourReq.Body
m[&#34;mch_id&#34;] = yourReq.Mch_id
m[&#34;notify_url&#34;] = yourReq.Notify_url
m[&#34;trade_type&#34;] = yourReq.Trade_type
m[&#34;spbill_create_ip&#34;] = yourReq.Spbill_create_ip
m[&#34;total_fee&#34;] = yourReq.Total_fee
m[&#34;out_trade_no&#34;] = yourReq.Out_trade_no
m[&#34;nonce_str&#34;] = yourReq.Nonce_str
yourReq.Sign = wxpayCalcSign(m, &#34;wxpay_api_key&#34;) //这个是计算wxpay签名的函数上面已贴出
bytes_req, err := xml.Marshal(yourReq)
if err != nil {
fmt.Println(&#34;以xml形式编码发送错误, 原因:&#34;, err)
str_req := string(bytes_req)
//wxpay的unifiedorder接口需要http body中xmldoc的根节点是&xml&&/xml&这种,所以这里需要replace一下
str_req = strings.Replace(str_req, &#34;XUnifyOrderReq&#34;, &#34;xml&#34;, -1)
bytes_req = []byte(str_req)
//发送unified order请求.
req, err := http.NewRequest(&#34;POST&#34;, unify_order_req, bytes.NewReader(bytes_req))
if err != nil {
fmt.Println(&#34;New Http Request发生错误,原因:&#34;, err)
req.Header.Set(&#34;Accept&#34;, &#34;application/xml&#34;)
//这里的http header的设置是必须设置的.
req.Header.Set(&#34;Content-Type&#34;, &#34;application/charset=utf-8&#34;)
c := http.Client{}
resp, _err := c.Do(req)
if _err != nil {
fmt.Println(&#34;请求微信支付统一下单接口发送错误, 原因:&#34;, _err)
//到这里统一下单接口就已经执行完成了
2,微信回调函数的处理
3,客户端查询订单请求响应
&最高记录 1364
&2012- Go语言中文网,中国 Golang 社区,致力于构建完善的 Golang 中文社区,Go语言爱好者的学习家园。
Powered by
&o&服务器由
赞助 &·&CDN 由
VERSION: V3.0.0&·&3.924016ms&·&为了更好的体验,本站推荐使用 Chrome 或 Firefox 浏览器
登录和大家一起探讨吧
记住登录状态
还不是会员微信支付商品标题出现乱码问题
最后在做微信支付的时候发现到支付页面有时候商品标题会出现乱码问题,想了很久,后来找到原因,微信默认的是用GBK格式,至少最早的是这样的,后来更新文档发现,又好像有能支持UTF-8格式的了,但是我之前一直用的是默认的GBK格式,由于我的代码全是UTF-8格式,所以我试着将微信支付的package的编码格式改成UTF-8格式,果然好了,所以当你微信支付碰到有乱码问题,换成UTF-8试试。
有什么问题可加下面群:,直接问我。
已投稿到:
以上网友发言只代表其个人观点,不代表新浪网的观点或立场。20612人阅读
java web(18)
Java(22)
1、请求的时候获取不到prepayid。
原因:setParameter(&total_fee&, &1&); //商品金额,以分为单位 &
total_fee里面的参数是否有小数点,或者测试的时候修改为了0.01;
需检查:total_fee传入的参数是否为整数;
2、请求支付跳转到微信支付时,商品描述为乱码:
原因:.setParameter(&input_charset&, &GBK&); //字符编码&
修改编码为UTF-8 ,
另外如果使用了微信支付的demo的方法,需将TenpayUtil中的getCharacterEncoding放回编码修改为utf-8
&&相关文章推荐
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:453874次
积分:2674
积分:2674
排名:第13863名
原创:66篇
评论:174条
(1)(1)(3)(2)(6)(1)(1)(2)(5)(6)(6)(7)(4)(5)(1)(1)(2)(1)(1)(2)(1)(1)(1)(3)(2)(1)(1)(2)(2)(2)

我要回帖

更多关于 微信支付记录导出 的文章

 

随机推荐