关于微信h5支付实例

流程

  1. 配置请求参数
  2. 请求下单接口
  3. h5支付时,获取下单返回的mweb_url路径
  4. 前端获取接口返回的url,请求此路径(手机访问前端界面,pc访问报错:商家格式配置错误)

适用场景

h5网站内,调用微信支付。

前端实例

	<script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
		<script type="text/javascript">

 function pay() {
   
	$.ajax({
   
                async: false,
                cache: false,
                type: 'POST',
                url: "https://ztcapi.yzsheng.com/Try/WeChatIndex", //请求的action路径
                success: function (data) {
    
alert(data.item);       
                window.location.href = data.item;
        },
error: function(XMLHttpRequest, textStatus, errorThrown) {
   
             console.log(XMLHttpRequest.status);
             console.log(XMLHttpRequest.readyState);
             console.log(textStatus);
        }
                
            });
        };
		</script>

后端C#实例

using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Net;
using System.Security.Cryptography;
using System.Text;
using System.Web;
using System.Xml.Linq;

namespace WebApplication1.Common.PayHelper
{
   
    /// <summary>
    /// H5微信支付封装
    /// </summary>
    public static class H5PayHepler
    {
   
        static string _pre_order_url = "https://api.mch.weixin.qq.com";//请求域名

        static string _appid = "";//公众账号ID
        static string _mch_id = "";//商户号
        static string _partnerKey = "";//商家私钥,在微信支付中设置


        /// <summary>
        /// H5微信支付
        /// </summary>
        /// <returns></returns>
        #region 微信支付
        public static string WeChatIndex()
        {
   
            #region 下单
            var _attach = "支付测试";
            var _body = "H5支付测试";
            var _nonce_str = CreateNonce_str(); //随机字符串
            var _notify_url = ""; //回调地址
            var _out_trade_no = Guid.NewGuid().ToString("N"); //订单号
            var _spbill_create_ip = GetWebClientIp(); //终端ip
            var _total_fee = 0.01;//元为单位
            var _scene_info = $@"{
   {""h5_info"": {
   {""type"":""Wap"",""wap_url"": ""{_notify_url}"",""wap_name"": ""{_body}""}}}}"; //场景参数
            var _time_start = DateTime.Now.ToString("yyyyMMddHHmmss"); //请求开始时间
            var _time_expire = DateTime.Now.AddHours(1).ToString("yyyyMMddHHmmss"); //请求结束时间
            var _trade_type = "MWEB"; //请求类型
            var pre_order_httpResult = UnifiedOrder(_appid, _attach, _body, _mch_id, _nonce_str, _notify_url, _out_trade_no, _spbill_create_ip, _total_fee,
    _trade_type, _scene_info, _time_start, _time_expire); //下单
            var pre_order_resultStr = XElement.Parse(pre_order_httpResult);
            var pre_order_result_code = pre_order_resultStr.Element("return_code").Value;
            var pre_order_result_msg = pre_order_resultStr.Element("return_msg").Value
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用 `com.github.wechatpay-apiv3` 库处理微信 H5 支付的 Java 代码示例: ```java import com.github.wechatpay.apiv3.WxPayApiV3; import com.github.wechatpay.apiv3.WxPayApiV3Config; import com.github.wechatpay.apiv3.model.notify.WxPayOrderNotifyResult; import com.github.wechatpay.apiv3.model.notify.WxPayOrderNotifyResult.NotifyResponse; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; public class WeChatH5NotifyHandler { private static final String WECHAT_API_CERT_SERIAL_NUMBER = "YOUR_WECHAT_API_CERT_SERIAL_NUMBER"; private static final String WECHAT_API_CERTIFICATE_PATH = "path/to/your/wechat/api/certificate.pem"; public void handleNotify(HttpServletRequest request, HttpServletResponse response) throws IOException { try { // 创建微信支付 API 配置 WxPayApiV3Config config = new WxPayApiV3Config.Builder() .appId("your_app_id") .merchantId("your_merchant_id") .privateKeySerialNumber(WECHAT_API_CERT_SERIAL_NUMBER) .privateKeyPath(WECHAT_API_CERTIFICATE_PATH) .build(); // 创建微信支付 API 实例 WxPayApiV3 wxPayApiV3 = new WxPayApiV3(config); // 解析异步通知数据 WxPayOrderNotifyResult notifyResult = wxPayApiV3.parseOrderNotifyResult(request); // 验证签名 if (wxPayApiV3.verifySignature(notifyResult)) { // 签名验证成功 // 处理支付成功的逻辑 // ... // 返回成功响应给微信服务器 response.setStatus(HttpServletResponse.SC_OK); response.getWriter().write("SUCCESS"); } else { // 签名验证失败,返回失败响应给微信服务器 response.setStatus(HttpServletResponse.SC_BAD_REQUEST); response.getWriter().write("FAIL"); } } catch (Exception e) { e.printStackTrace(); // 返回失败响应给微信服务器 response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR); response.getWriter().write("FAIL"); } } } ``` 在上述代码中,我们创建了一个名为 `WeChatH5NotifyHandler` 的类,其中的 `handleNotify` 方法用于处理微信 H5 支付的异步通知。该方法接收 `HttpServletRequest` 和 `HttpServletResponse` 对象作为参数,从请求中获取异步通知的数据,并进行相应的处理逻辑。 在 `handleNotify` 方法中,我们首先创建了一个 `WxPayApiV3Config` 对象,用于配置微信支付 API 的相关参数。其中,我们需要提供应用 ID(`appId`)、商户号(`merchantId`)、微信支付 API 证书的序列号(`privateKeySerialNumber`)以及证书的路径(`privateKeyPath`)。您需要将这些参数替换为您自己的值。 然后,我们使用 `WxPayApiV3` 实例来解析异步通知数据,并验证签名。如果签名验证成功,则表示支付成功,可以进行相应的处理逻辑,并返回成功响应给微信服务器。如果签名验证失败,则返回失败响应给微信服务器。 请注意,以上示例代码仅供参考,具体的实现可能因应用的需求而有所不同。您需要根据实际情况进行修改和完善。另外,在真实的项目中,请确保您已正确配置和保护微信支付 API 证书的私钥。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值