vue公众号微信支付实现代码

话不多说直接上代码
样式代码

    <div
      style="position: fixed;bottom:0;color:white;font-size:0.3rem;width:105%;height:1rem;text-align:center;line-height:1rem;background:red;margin-left:-2.5%;"
      @click="GroupDetails_path_go"
    >
      微信支付¥{
   {
    shopInfoRes_list.grouponPrice }}
    </div>
      	<div class="popup" v-show="cancellationoforder">您已取消支付</div>

js代码

       GroupDetails_path_go() {
   
      let data = {
   
        uid: localStorage.getItem("Tuid"),
        grouponId: this.id,
         activityId: this.activityId
      };
      this.$http.post("/api/mcGroupBuy/joinGroupon", data).then(res => {
   
        console
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的示例代码,演示如何使用Vue和Spring Boot实现微信支付: 前端Vue代码: ```vue <template> <div> <button @click="pay">微信支付</button> </div> </template> <script> import axios from 'axios' export default { methods: { pay() { axios.post('/api/wechat/pay').then(response => { const data = response.data WeixinJSBridge.invoke( 'getBrandWCPayRequest', { 'appId': data.appId, //公众号名称,由商户传入 'timeStamp': data.timeStamp, //时间戳,自1970年以来的秒数 'nonceStr': data.nonceStr, //随机串 'package': data.packageValue, 'signType': data.signType, //微信签名方式: 'paySign': data.paySign //微信签名 }, function (res) { if (res.err_msg == 'get_brand_wcpay_request:ok') { alert('支付成功') } else if (res.err_msg == 'get_brand_wcpay_request:cancel') { alert('取消支付') } else { alert('支付失败') } } ) }) } } } </script> ``` 后端Spring Boot代码: ```java @RestController @RequestMapping("/api/wechat") public class WechatController { @Autowired private WechatPayService wechatPayService; @PostMapping("/pay") public Map<String, String> pay() throws Exception { return wechatPayService.unifiedOrder(); } } @Service public class WechatPayServiceImpl implements WechatPayService { @Autowired private WechatPayConfig wechatPayConfig; @Override public Map<String, String> unifiedOrder() throws Exception { //生成微信支付参数 Map<String, String> parameters = new HashMap<>(); parameters.put("appid", wechatPayConfig.getAppId()); parameters.put("mch_id", wechatPayConfig.getMchId()); parameters.put("nonce_str", UUID.randomUUID().toString().replace("-", "")); parameters.put("body", "测试商品"); parameters.put("out_trade_no", UUID.randomUUID().toString().replace("-", "")); parameters.put("total_fee", "1"); parameters.put("spbill_create_ip", "127.0.0.1"); parameters.put("notify_url", wechatPayConfig.getNotifyUrl()); parameters.put("trade_type", "JSAPI"); parameters.put("openid", "openid"); String sign = WechatPayUtil.generateSignature(parameters, wechatPayConfig.getKey()); parameters.put("sign", sign); //调用微信支付统一下单API String xml = WechatPayUtil.mapToXml(parameters); String result = HttpUtil.post(wechatPayConfig.getUnifiedOrderUrl(), xml); Map<String, String> resultMap = WechatPayUtil.xmlToMap(result); //生成前端需要的支付参数 Map<String, String> payParameters = new HashMap<>(); payParameters.put("appId", wechatPayConfig.getAppId()); payParameters.put("timeStamp", String.valueOf(System.currentTimeMillis() / 1000)); payParameters.put("nonceStr", UUID.randomUUID().toString().replace("-", "")); payParameters.put("packageValue", "prepay_id=" + resultMap.get("prepay_id")); payParameters.put("signType", "MD5"); String paySign = WechatPayUtil.generateSignature(payParameters, wechatPayConfig.getKey()); payParameters.put("paySign", paySign); return payParameters; } } @Configuration @ConfigurationProperties(prefix = "wechat.pay") public class WechatPayConfig { private String appId; //公众账号ID private String mchId; //商户号 private String key; //商户密钥 private String unifiedOrderUrl; //统一下单地址 private String notifyUrl; //支付结果通知地址 //省略getter和setter方法 } ``` 以上代码示例中,前端Vue代码中使用axios发送POST请求到后端的`/api/wechat/pay`接口,后端Spring Boot代码中生成微信支付参数,调用微信支付统一下单API,然后将生成的前端需要的支付参数返回给前端。前端再将支付参数传给微信客户端进行支付。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值