代码拉取完成,页面将自动刷新
同步操作将从 springrain/gowe 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
package gowe
import (
"bytes"
"encoding/xml"
"fmt"
"github.com/beevik/etree"
)
//WxPayNotifyPay 支付结果通知
func WxPayNotifyPay(wxPayConfig IWxPayConfig, requestBody []byte, handler func(wxPayNotifyPayBody WxPayNotifyPayBody) error) (rspBody string, err error) {
// 验证Sign
if err = wxPayDoVerifySign(wxPayConfig, requestBody, false); err != nil {
return
}
// 解析参数
var body WxPayNotifyPayBody
if err = wxPayNotifyParseParams(requestBody, &body); err != nil {
return
}
// 调用外部处理
if err = handler(body); err != nil {
return
}
// 返回处理结果
rspModel := wxPayNotifyResponseModel{
ReturnCode: responseSuccess,
ReturnMsg: responseMessageOk,
}
rspBody = rspModel.toXMLString()
return
}
//wxPayNotifyResponseModel 微信通知的结果返回值
type wxPayNotifyResponseModel struct {
ReturnCode string // SUCCESS/FAIL
ReturnMsg string // 返回信息,如非空,为错误原因,或OK
}
func (m *wxPayNotifyResponseModel) toXMLString() string {
buffer := new(bytes.Buffer)
buffer.WriteString("<xml>")
buffer.WriteString(fmt.Sprintf("<return_code><![CDATA[%s]]></return_code>", m.ReturnCode))
buffer.WriteString(fmt.Sprintf("<return_msg><![CDATA[%s]]></return_msg>", m.ReturnMsg))
buffer.WriteString("</xml>")
return buffer.String()
}
//WxPayNotifyPayBody 支付结果通知的参数
type WxPayNotifyPayBody struct {
WxResponseModel
// 当return_code为SUCCESS时
WxPayPartnerResponseModel
DeviceInfo string `xml:"device_info"` // 微信支付分配的终端设备号
IsSubscribe string `xml:"is_subscribe"` // 用户是否关注公众账号(机构商户不返回)
SubIsSubscribe string `xml:"sub_is_subscribe"` // (服务商模式) 用户是否关注子公众账号(机构商户不返回)
OpenId string `xml:"openid"` // 用户在商户appid下的唯一标识
SubOpenId string `xml:"sub_openid"` // (服务商模式) 用户在子商户appid下的唯一标识
TradeType string `xml:"trade_type"` // 交易类型
BankType string `xml:"bank_type"` // 银行类型,采用字符串类型的银行标识,银行类型见附表
TotalFee int `xml:"total_fee"` // 订单总金额,单位为分
FeeType string `xml:"fee_type"` // 货币类型,符合ISO 4217标准的三位字母代码,默认人民币:CNY,其他值列表详见货币类型
CashFee int `xml:"cash_fee"` // 现金支付金额订单现金支付金额,详见支付金额
CashFeeType string `xml:"cash_fee_type"` // 货币类型,符合ISO 4217标准的三位字母代码,默认人民币:CNY,其他值列表详见货币类型
SettlementTotalFee int `xml:"settlement_total_fee"` // 应结订单金额=订单金额-非充值代金券金额,应结订单金额<=订单金额.
CouponFee int `xml:"coupon_fee"` // 代金券或立减优惠金额<=订单总金额,订单总金额-代金券或立减优惠金额=现金支付金额,详见支付金额
CouponCount int `xml:"coupon_count"` // 代金券或立减优惠使用数量
TransactionId string `xml:"transaction_id"` // 微信支付订单号
OutTradeNo string `xml:"out_trade_no"` // 商户系统内部订单号,要求32个字符内,只能是数字、大小写字母_-|*@ ,且在同一个商户号下唯一.
Attach string `xml:"attach"` // 商家数据包,原样返回
TimeEnd string `xml:"time_end"` // 支付完成时间,格式为yyyyMMddHHmmss,如2009年12月25日9点10分10秒表示为20091225091010.其他详见时间规则
// 使用coupon_count的序号生成的优惠券项
Coupons []WxPayCouponResponseModel `xml:"-"`
}
//wxPayNotifyParseParams 支付结果通知-解析XML参数
func wxPayNotifyParseParams(xmlStr []byte, body *WxPayNotifyPayBody) (err error) {
if err = xml.Unmarshal(xmlStr, &body); err != nil {
return
}
// 解析CouponCount的对应项
if body.CouponCount > 0 {
doc := etree.NewDocument()
if err = doc.ReadFromBytes(xmlStr); err != nil {
return
}
root := doc.SelectElement("xml")
for i := 0; i < body.CouponCount; i++ {
m := wxPayNewCouponResponseModel(root, "coupon_id_%d", "coupon_type_%d", "coupon_fee_%d", i)
body.Coupons = append(body.Coupons, m)
}
}
return
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。