orderPay.vue 12.1 KB
<template>
  <div>
    <div class="car-wrap">
      <div class="carBG" :class="carWrapBG | formateColor">
        <p class="carNumber">{{carNumber}}</p>
        <p class="payFee">{{(arrearageActFee/100).toFixed(2)}}元</p>
      </div>
    </div>

    <ul class="fee-wrap">
      <li>
        <span>待缴金额</span>
        <span>{{(arrearageActFee/100).toFixed(2)}}</span>
      </li>
      <li>
        <span>优惠金额</span>
        <span>{{(arrearageDiscFee/100).toFixed(2)}}</span>
      </li>
      <li>
        <span>应付金额</span>
        <span>{{(arrearageActFee/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>
import CryptoJS from '../utils/AES.js'
let Base64 = require('js-base64').Base64

import { aliPay, getOpenId, vxPayQuery, bankH5Pay } from '@/api/orderPay/orderPay'

export default {
  name: 'orderPay',
  data() {
    return {
      carWrapBG: 0,
      carNumber: '',
      arrearageActFee: 0,
      arrearageDiscFee: 0,
      arrearageActFee: 0,
      clientBrowser: '', // 客户端
      paySrcType: '', //支付的类型   101 是本次   103是历史欠费
      orderId: '',  //支付的订单
      webAppCode: '', // 微信code
      appOrderTimeout: '', // 超时描述
    }
  },
  created() {
    this.carWrapBG = this.$route.query.carColor //车牌颜色
    this.carNumber = this.$route.query.carNumber
    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.paySrcType // 实收
    this.orderId = this.$route.query.ordeID
    console.log(this.orderId)
    this.appOrderTimeout = this.$route.query.appOrderTimeout
    if (this.clientBrowser == "微信") {
      this.webAppCode = this.getCode();
    }

  },
  methods: {
    getCode() {
      var appID = this.$utils.myVxAppId;
      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_userinfo&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);
          }

        })
      }

      console.log(this.clientBrowser)
      if (this.clientBrowser == '农行') { // 农行支付
        var bankabcParams = {};
        bankabcParams.orderId = this.orderId;
        bankabcParams.carNumber = this.carNumber;
        bankabcParams.payType = 1;// 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{
            alert('支付失败')
          }


          // 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问题]
            alert('请重新扫码')
            console.log(res.message);
          } else {
            alert('请重新扫码')
          }
        })

      }

    },
    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 {
            alert("没有找到返回值");
          }
        } else {
          console.log(res.message);
          alert(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('成功')
            alert('支付成功')
          } else {
            console.log('失败')
            alert('支付失败')
            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;
    color: #fff;
    text-align: center;
  }

  .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>