pay.vue 13.1 KB
<template>
  <div>
    <div class="car-wrap">
      <div class="carBG carBlue">
        <p class="carNumber">{{carNumber}}</p>
        <p class="payFee">{{(orderFee/100).toFixed(2)}}元</p>
      </div>
    </div>

    <ul class="fee-wrap">
      <li>
        <span>停车场</span>
        <span>{{ parkName }}</span>
      </li>
      <li>
        <span>入场时间</span>
        <span>{{ inparktime }}</span>
      </li>
      <li>
        <span>出场时间</span>
        <span>{{ outtime }}</span>
      </li>

      <li>
        <span>停车时长</span>
        <span>{{ $utils.dateFormat(staytime) }}</span>
      </li>

      <li>
        <span>总金额</span>
        <span>{{(due/100).toFixed(2)}} 元</span>
      </li>

      <li>
        <span>优惠金额</span>
        <span>{{(discountFee/100).toFixed(2)}} 元</span>
      </li>


      <li>
        <span>待缴金额</span>
        <span>{{(orderFee/100).toFixed(2)}} 元</span>
      </li>

    </ul>
    <div style="padding: 20px 18px">
      <div class="toPay" @click="toPay">{{clientBrowser}}支付</div>
    </div>

    <div v-if="appOrderTimeout.length>0">
      <p class="tip">
        温馨提示:
      </p>
      <p style="color: #666;padding: 0 18px;">
        {{appOrderTimeout}}
      </p>
    </div>


  </div>
</template>

<script>

let Base64 = require("js-base64").Base64;
import { aliPay, getOpenId, vxPayQuery, bankH5Pay } from "@/api/orderPay/orderPay";
export default {
  name: "dynCodePay",
  data() {
    return {
      carWrapBG: 0,
      carNumber: "",  // 车牌
      parkName: "", // 停车场名称
      inparktime: "", // 入场时间
      outtime: "", // 出场时间
      staytime: "", // 停车时长
      orderFee: "", // 需要支付的费用
      due: "", //  总金额
      discountFee: "", // 优惠金额
      arrearageActFee: 0,
      arrearageDiscFee: 0,
      arrearageActFee: 0,
      clientBrowser: "", // 客户端
      paySrcType: 101, //支付的类型   101 是本次   103是历史欠费
      orderId: "",  //支付的订单
      webAppCode: "", // 微信code
      appOrderTimeout: "" // 超时描述
    };
  },
  created() {
    // this.carWrapBG = this.$route.query.carColor //车牌颜色
    this.carNumber = this.$route.query.plateno;
    this.parkName = this.$route.query.parkName;
    this.inparktime = this.$route.query.inparktime;
    this.outtime = this.$route.query.outtime;
    this.staytime = this.$route.query.staytime;
    this.orderFee = this.$route.query.orderFee;
    this.due = this.$route.query.due;
    this.discountFee = this.$route.query.discountFee;
    // this.arrearageTotalFee = this.$route.query.arrearageTotalFee // 应收
    // this.arrearageDiscFee = this.$route.query.arrearageDiscFee // 优惠
    // this.arrearageActFee = this.$route.query.arrearageActFee // 实收
    this.clientBrowser = this.$utils.clientBrowser(); //支付方式
    // this.paySrcType = this.$route.query.codeType // 实收
    this.orderId = this.$route.query.orderId;
    // console.log(this.orderId)
    // this.appOrderTimeout = this.$route.query.appOrderTimeout
    if (this.clientBrowser == "微信") {
      this.webAppCode = this.getCode();
    }
  },
  methods: {
    getCode() {
      var appID = this.$utils.myVxAppId;
      // alert(appID)
      var code = this.getUrlParam("code");
      var local = window.location.href;
      if (code == null || code === "") {
        window.location.href = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appID + "&redirect_uri=" + encodeURIComponent(local) + "&response_type=code&scope=snsapi_base&state=1#wechat_redirect";
      } else {
        return code;
      }
    },
    getUrlParam(name) {
      var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)");
      var r = window.location.search.substr(1).match(reg);
      if (r != null) return unescape(r[2]);
      return null;
    },
    toPay() {
      let me = this;
      let _order = [];
      console.log(this.orderId);
      if (this.paySrcType == 103) {
        this.orderId = JSON.parse(this.orderId);
        this.orderId.forEach(item => {
          _order.push({
            orderId: item
          });
        });
        this.orderId = [];
        this.orderId = _order;
      }
      if (this.clientBrowser == "支付宝") { // 支付宝支付
        var aliParams = {};
        aliParams.orderId = this.orderId;
        // aliParams.carNumber = this.carNumber;
        aliParams.payType = 1;// 1:支付宝 2:微信 3:银联 10:H5   4微信公众号
        aliParams.terminalSource = 7;//请求端来源 1: 任你停 2:pda 3:微信公共号 7:H5扫码 10页面支付
        aliParams.paySrcType = this.paySrcType;//101停车支付
        // aliParams.orgId = this.$utils.myOrgId,
        //   aliParams.backType = 2,
        //   aliParams.recordArreaInfos = JSON.stringify(this.orderId);
        console.log(aliParams);
        aliPay(aliParams).then(response => {
          console.log(response);
          if (response.code == 0) {//进场
            document.write(response.data);//打开支付表单
          } else {//其他情况如【该卡号场内已存在】
            console.log(response.message);
          }
        });
      }
      if (this.clientBrowser == "立即") { // 农行支付
        var bankabcParams = {};
        bankabcParams.orderId = this.orderId;
        bankabcParams.carNumber = this.carNumber;
        bankabcParams.payType = 34;// 1:支付宝 2:微信 3:银联 10:H5   4微信公众号
        bankabcParams.terminalSource = 7;//请求端来源 1: 任你停 2:pda 3:微信公共号 7:H5扫码 10页面支付
        bankabcParams.paySrcType = this.paySrcType;//101停车支付
        bankabcParams.orgId = this.$utils.myOrgId;
        bankabcParams.backType = 2;
        bankabcParams.PaymentLinkType = 1;
        bankabcParams.recordArreaInfos = JSON.stringify(this.orderId);
        console.log(bankabcParams);
        bankH5Pay(bankabcParams).then(response => {
          console.log(response);
          if (response.code == "0") {
            let res = response.data.PaymentURL;
            let _token = res.split("TOKEN=")[1];
            let OrderNo = response.data.OrderNo;
            localStorage.setItem("OrderNum", OrderNo);
            if (window.navigator.userAgent.indexOf("Bankabc/Portal") > -1) {
              // alert('当前页面在新容器');
              AlipayJSBridge.call("startApp", {
                appId: "30603024", // 固定值
                param: {
                  type: "3", // 3: 掌银内H5页面,
                  tokenId: _token, //商户传过来的tokenId
                  paySystem: "", //商户传过来的paySystem, 没有则传空字符串
                  payType: "1111", //商户传过来的payType,没有则传'1111'
                  webviewURL: "https://wxgzh.renniting.cn/wechatwuxi/Chifeng/TEST/sweeping_payment/codepay/index.html#/payResult", //商户传过来的回跳地址
                  remark: "其他参数", //扩展备用
                  showProgress: "NO",
                  backBehavior: "back"
                }
              }, function(result) {
              });
            } else {
              // alert('当前页面在旧容器');
              // 旧支付方式
              window.location.href = "https://www.abchina.com/luascript/mobilePayLua/" + encodeURI("{\"return\":{\"tokenID\":\"" + _token + "\",\"backURL\":\"https://wxgzh.renniting.cn/wechatwuxi/Chifeng/TEST/sweeping_payment/codepay/index.html#/payResult\",\"payType\":\"\"}}");
            }
          } else {
            me.$msgbox("提示", "支付失败");
          }
          // console.log(_token)
          // let _data = 'method=invokePayFromBrowser&tokenID='+_token
          // let cryData = CryptoJS.encrypt(_data, 'G9w0BAQEFAAOCAQ8AMIIBCgKCAQEAvM3', 'EkpTEA3FbZFGGq8Y')
          //
          // let baseCRY = Base64.encode(cryData)
          // console.log(baseCRY)
          // window.location.href='bankabc:' + encodeURIComponent('{"method":"invokePayFromBrowser","param":'+baseCRY+'}')
          // // 即为加密后的数据。其中paramsEncode是需要加密的数据、
          // // keyStr是加密时使用的key,与服务端一致、hash是偏移量,是一个随机生成的16位字符串。
        });
      }
      if (this.clientBrowser == "微信") { // 微信支付
        //第一步获取openid
        var codeParams = {
          code: this.webAppCode,
          appId: this.$utils.myVxAppId
        };
        getOpenId(codeParams).then(res => {
          if (res.code == 0) {
            me.vxPay(res.data, this.orderId);
          } else if (res.code == 40163) { //code been used, hints[重复code问题]
            me.$msgbox("提示", "请重新扫码");
            console.log(res.message);
          } else {
            me.$msgbox("提示", "请重新扫码");
          }
        });
      }
    },
    vxPay(openIdData, orderIdData) {
      let vm = this;
      var wxParams = {};
      wxParams.orderId = orderIdData;
      // wxParams.backType = 2,
      //   wxParams.orgId = this.$utils.myOrgId,
      wxParams.payType = 4;// 1:支付宝 2:微信 3:银联 10:H5   4微信公众号
      wxParams.terminalSource = 7;//请求端来源 1: 任你停 2:pda 3:微信公共号 7:H5扫码 10页面支付
      // wxParams.carNumber = this.carNumber;
      // wxParams.paySrcType = this.paySrcType;//101停车支付
      // wxParams.recordArreaInfos = JSON.stringify(orderIdData);
      wxParams.openId = openIdData;
      wxParams.appId = this.$utils.myVxAppId;
      vxPayQuery(wxParams).then(res => {
        if (res.code == 0) { //
          if (res.data) {
            var data = res.data;
            console.log(JSON.stringify(data));
            if (typeof WeixinJSBridge === "undefined") { // 微信浏览器内置对象。参考微信官方文档
              if (document.addEventListener) {
                document.addEventListener("WeixinJSBridgeReady", vm.onBridgeReady(data), false);
              } else if (document.attachEvent) {
                document.attachEvent("WeixinJSBridgeReady", vm.onBridgeReady(data));
                document.attachEvent("onWeixinJSBridgeReady", vm.onBridgeReady(data));
              }
            } else {
              console.log("准备调用微信支付");
              vm.onBridgeReady(data);
            }
          } else {
            vm.$msgbox("提示", "没有找到返回值");
          }
        } else {
          console.log(res.message);
          vm.$msgbox("提示", res.message);
        }
      });
    },
    onBridgeReady(params) {
      let me = this;
      console.log("调用微信支付WeixinJSBridge");
      WeixinJSBridge.invoke(
        "getBrandWCPayRequest", params,
        //
        // 'getBrandWCPayRequest', { // 下面参数内容都是后台返回的
        //   'appId': data.appId, // 公众号名称,由商户传入
        //   'timeStamp': data.timeStamp, // 时间戳
        //   'nonceStr': data.nonceStr, // 随机串
        //   'package': data.package, // 预支付id
        //   'signType': data.signType, // 微信签名方式
        //   'paySign': data.paySign // 微信签名
        // },
        function(res) {
          // 使用以上方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。
          if (res.err_msg === "get_brand_wcpay_request:ok") {
            console.log("成功");
            me.$msgbox("提示", "支付成功");
          } else {
            console.log("失败");
            me.$msgbox("提示", "支付失败");
            me.$router.go(-2);
          }
        }
      );
    }
  },
  filters: {}
};
</script>

<style scoped lang="scss">
  .car-wrap {
    padding: 7px 7px;
    background: #FFF;
  }

  .carBG {
    width: 100%;
    height: 130px;
  }

  .carBlue {
    background: url("../assets/images/blueBG.png") no-repeat;
    background-size: 100% 100%;
  }

  .carYellow {
    background: url("../assets/images/yellowBG.png") no-repeat;
    background-size: 100% 100%;
  }

  .carGreen {
    background: url("../assets/images/greenBG.png") no-repeat;
    background-size: 100% 100%;
  }

  .carWhite {
    background: url("../assets/images/whiteBG.png") no-repeat;
    background-size: 100% 100%;
  }

  .carBlack {
    background: url("../assets/images/blackBG.png") no-repeat;
    background-size: 100% 100%;
  }

  .carNumber {
    padding: 20px 0 10px;
    font-size: 30px;
    text-align: center;
    color: #fff;
  }

  .payFee {
    font-size: 24px;
    color: #FF7B7B;
    text-align: center;
  }

  .fee-wrap {
    background: #FFF;
    padding: 0 18px;
    > li {
      display: flex;
      justify-content: space-between;
      height: 30px;
      line-height: 30px;
      border-bottom: 1px solid #EAEAEA;
      &:last-child {
        border-bottom: 0;
      }
    }

  }

  .toPay {
    width: 100%;
    height: 44px;
    margin: 0 auto;
    line-height: 44px;
    text-align: center;
    background: linear-gradient(180deg, #3885D9 0%, #4194EF 100%);
    border-radius: 4px;
    border: 1px solid #0D72E2;
    font-size: 20px;
    color: #FFF;
    cursor: pointer;
  }

  .tip {
    padding-left: 40px;
    background: url("../assets/images/tip.png") no-repeat 18px center;
    background-size: 16px 16px;
    color: #666;
  }
</style>