本人vue 小白 之前在公司接触vue商城项目,其中包含了微信支付和支付宝支付,由于微信会拦截支付宝支付页面。当时这个问题困惑我蛮久的,所以今天记录一下,方便日后再次遇到方便查询。
废话不多说。
给兄弟们官方的参考:微信公众平台无法使用支付宝收付款的解决方案https://opendocs.alipay.com/open/203/105285/
往下扒拉就有这个了,要是你不想下载官方的demo 我下面其实有我从官方demo中扒来的布局你可以复制我的。

思路是这样的:

  1. 当你在结算页面点击结算按钮时进行跳转传参,把后端返回给你的from表单传递到中转页面。这里参数最好使用加密,我当时使用的是伪加密(base64)。
  2. 跳转到中转页面后进行解密获取表单数据,进行判断浏览器是否为微信浏览器。如果是就显示请在第三方浏览器中打开,如果不是直接提交表单。

这里是结算页面跳转
因为是本地测试所以用的http放到服务器上要改成https然后你对应的文件名也要对应上
我这里ppc是中转页面(名字起得有点随意了。。。)

  paymentPay(orderid, code, referer, channel, openid).then(response => {if (response) {//支付宝支付if (code == 'alipay.wap') {if (response.alipay && response.alipay.html) {this.alipay_html = this.Base64().encode(response.alipay.html)if (this.alipay_html != '') {window.location.href ='http://' +this.getHost(window.location.href) +'/ppc.html?alidata='+this.alipay_html}} }//天工收银微信支付if (type == 'wxpay_jsapi') {if (response.teegon && response.teegon.url) {window.location.href = response.teegon.url}}}},error => {// Indicator.close()Toast(error.errorMsg)})

** 这里是在支付页面用到的伪加密的方法 **

Base64() {
return{// private property  _keyStr : "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",  // public method for encoding  encode : function (input) {  var output = "";  var chr1, chr2, chr3, enc1, enc2, enc3, enc4;  var i = 0;  input = this._utf8_encode(input);  while (i < input.length) {  chr1 = input.charCodeAt(i++);  chr2 = input.charCodeAt(i++);  chr3 = input.charCodeAt(i++);  enc1 = chr1 >> 2;  enc2 = ((chr1 & 3) << 4) | (chr2 >> 4);  enc3 = ((chr2 & 15) << 2) | (chr3 >> 6);  enc4 = chr3 & 63;  if (isNaN(chr2)) {  enc3 = enc4 = 64;  } else if (isNaN(chr3)) {  enc4 = 64;  }  output = output +  this._keyStr.charAt(enc1) + this._keyStr.charAt(enc2) +  this._keyStr.charAt(enc3) + this._keyStr.charAt(enc4);  }  return output;  },// private method for UTF-8 encoding  _utf8_encode : function (string) {  string = string.replace(/\r\n/g,"\n");  var utftext = "";  for (var n = 0; n < string.length; n++) {  var c = string.charCodeAt(n);  if (c < 128) {  utftext += String.fromCharCode(c);  } else if((c > 127) && (c < 2048)) {  utftext += String.fromCharCode((c >> 6) | 192);  utftext += String.fromCharCode((c & 63) | 128);  } else {  utftext += String.fromCharCode((c >> 12) | 224);  utftext += String.fromCharCode(((c >> 6) & 63) | 128);  utftext += String.fromCharCode((c & 63) | 128);  }  }  return utftext;  },}
},

我的中转页面是和vue项目的index页面同级的,当初这么放的原因应该是微信内置浏览器会吧#后面的参数截取,就很坑。我项目路由用的hash模式,没用history模式。

然后在中转页面进行解码
为什么全粘贴过来呢 因为这个是支付宝官方给的中转页面的布局 方便一些不想布局的好兄弟 嘻嘻。
里面有个我自己加的弹窗 不要的兄弟自己删了好吧 我也懒得删了。

<!DOCTYPE html>
<html lang="en"><head><meta content="yes" name="apple-mobile-web-app-capable" /><meta name="viewport"content="width=device-width, height=device-height, initial-scale=1.0, maximum-scale=1.0, user-scalable=no" /><meta charset="utf-8" /><meta name="referrer" content="no-referrer" /><meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" /><meta http-equiv="Pragma" content="no-cache" /><meta http-equiv="Expires" content="0" /><title>支付宝</title><style>*,:before,:after {-webkit-tap-highlight-color: rgba(0, 0, 0, 0);}body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,form,fieldset,legend,input,textarea,p,blockquote,th,td {margin: 0;padding: 0;}table {border-collapse: collapse;border-spacing: 0;}fieldset,img {border: 0;}li {list-style: none;}caption,th {text-align: left;}q:before,q:after {content: '';}input:password {ime-mode: disabled;}:focus {outline: 0;}html,body {-webkit-touch-callout: none;touch-callout: none;-webkit-user-select: none;user-select: none;-webkit-tap-highlight-color: transparent;tap-highlight-color: transparent;height: 100%;margin: 0;padding: 0;text-align: center;font-size: 15px;font-weight: 300;font-family: 'Helvetica Neue', Helvetica, Arial, 'Lucida Grande', sans-serif;}a {text-decoration: none;}body {background: #f4f4f8;}.weixin-tip {display: none;-webkit-box-sizing: border-box;box-sizing: border-box;position: absolute;top: 15px;right: 20px;width: 265px;padding: 55px 0 0;text-align: left;background: url() no-repeat right top;background-size: 45px 68px;}.weixin-tip-img {display: none;padding: 110px 0 0;}.weixin-tip-img::after {display: block;margin: 15px auto;content: ' ';background-size: cover;}.weixin-tip-img.iphone::after {width: 150px;height: 150px;background-image: url();}.weixin-tip-img.android::after {width: 173px;height: 240px;background-image: url();}.box {width: 250px;height: 100px;background: #fff;z-index: 2;position: absolute;left: 50%;top: 50%;transform: translate(-50%, -50%);border-radius: 24px;display: none;}.content {width: 100%;height: 100%;display: flex;justify-content: center;align-items: center;position: relative;flex-direction: column;}.btnmenu {width: 100%;display: flex;flex-direction: row;justify-content: center;position: relative;bottom: -24px;}.success {height: 30px;width: 50%;display: flex;justify-content: center;border-bottom-left-radius: 24px;border: 1px solid #F6F6F8;border-right: none;align-items: center;}.fail {height: 30px;width: 50%;display: flex;justify-content: center;border-bottom-right-radius: 24px;border: 1px solid #F6F6F8;align-items: center;}.men {background: #000000;opacity: 0.5;position: fixed;top: 0;height: 100%;width: 100%;}</style><script src="https://code.jquery.com/jquery-3.4.1.min.js"></script>
</head><body><div><div class="J-weixin-tip weixin-tip" id="wxtip"><div class="weixin-tip-content">请在菜单中选择在浏览器中打开,<br />以完成支付</div></div><div class="J-weixin-tip-img weixin-tip-img" id="wxpic"></div><div v-if="!isWeixin"><div class="payment-form" v-html="paymentForm"></div></div></div><div class='men'></div><div class="box"><div class="content">支付结果<div class="btnmenu"><div class="success">支付成功</div><div class="fail">支付失败</div></div></div></div>
</body></html><script>var paymentForm = ''$(function () {var base = new Base64();paymentForm =base.decode(GetQueryValue());console.log(paymentForm)var ua = navigator.userAgent.toLowerCase()if (ua.indexOf('micromessenger') != -1) {$('#wxtip').css('display', 'block')$('#wxpic').css('display', 'block')if (ua.indexOf('iphone') != -1 ||ua.indexOf('ipad') != -1 ||ua.indexOf('ipod') != -1) {$('#wxpic').attr('class', 'J-weixin-tip-img weixin-tip-img iphone')} else {$('#wxpic').attr('class', 'J-weixin-tip-img weixin-tip-img android')}} else {SubmitPay()}setTimeout(function () {$('.box').css('display', 'block')}, 10000)})$('.success').on('click', function () {window.location.href = window.location.protocol +'//' +window.location.host +'/#/Profile';})$('.fail').on('click', function () {window.location.href = window.location.protocol +'//' +window.location.host +'/#/Profile';})
//进行支付宝表单提交  网上有很多熬function SubmitPay() {setTimeout(() => {const div = document.createElement('div')div.innerHTML = paymentFormdocument.body.appendChild(div)console.log(div);document.forms[0].submit()}, 50)}
//截取第一个等号后面的值  我自己写的因为我只携带了一个参数  所以自己写的截取 写的有点辣鸡,想要多个参数的可以自己改一下。function GetQueryValue() {var loc = decodeURI(window.location.href)var index = loc.indexOf('=')var newUrl = loc.substr(index + 1)return newUrl}//转码function Base64() {// private property  _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=";// public method for decoding  this.decode = function (input) {var output = "";var chr1, chr2, chr3;var enc1, enc2, enc3, enc4;var i = 0;input = input.replace(/[^A-Za-z0-9\+\/\=]/g, "");while (i < input.length) {enc1 = _keyStr.indexOf(input.charAt(i++));enc2 = _keyStr.indexOf(input.charAt(i++));enc3 = _keyStr.indexOf(input.charAt(i++));enc4 = _keyStr.indexOf(input.charAt(i++));chr1 = (enc1 << 2) | (enc2 >> 4);chr2 = ((enc2 & 15) << 4) | (enc3 >> 2);chr3 = ((enc3 & 3) << 6) | enc4;output = output + String.fromCharCode(chr1);if (enc3 != 64) {output = output + String.fromCharCode(chr2);}if (enc4 != 64) {output = output + String.fromCharCode(chr3);}}output = _utf8_decode(output);return output;}// private method for UTF-8 decoding  _utf8_decode = function (utftext) {var string = "";var i = 0;var c = c1 = c2 = 0;while (i < utftext.length) {c = utftext.charCodeAt(i);if (c < 128) {string += String.fromCharCode(c);i++;} else if ((c > 191) && (c < 224)) {c2 = utftext.charCodeAt(i + 1);string += String.fromCharCode(((c & 31) << 6) | (c2 & 63));i += 2;} else {c2 = utftext.charCodeAt(i + 1);c3 = utftext.charCodeAt(i + 2);string += String.fromCharCode(((c & 15) << 12) | ((c2 & 63) << 6) | (c3 & 63));i += 3;}}return string;}}
</script>

下面是微信浏览器中的效果
我用的微信开发者工具测试

在浏览器中打开的效果 也是ok的

好了就记录到这里了。

Vue项目在微信浏览器中使用支付宝支付相关推荐

  1. 微信浏览器中进行支付宝支付

    B端项目使用的是支付宝手机网页支付,微信浏览器中屏蔽了支付宝的功能.上有政策下有对策,支付宝也有应对的办法,下来就来说一说支付宝手机网站支付. 第一步:开发准备工作 登录支付宝平台(需要实名认证的支付 ...

  2. vue支付宝html,vue 解决在微信内置浏览器中调用支付宝支付的情况

    我的思路大概是这样的 1. 验证是否是在微信内置浏览器中调用支付宝 2.给支付页面的url加上调用接口所需的参数(因为在微信里是不能直接调用支付宝的需要调用外部浏览器) 3.在外部浏览器中完成支付跳转 ...

  3. 解决vue项目在ie浏览器中无法显示的问题,兼容低版本浏览器问题

    解决vue项目在ie浏览器中无法显示的问题,兼容低版本浏览器问题 1.在csdn中找到了一下解决方案,但与本项目略有不同 vue项目兼容ie浏览器的问题:在其他浏览器显示都是正常的,在ie11下显示空 ...

  4. html发起微信或支付宝支付,vue实现-微信网页中唤起支付宝支付

    微信浏览器内是无法唤起支付宝的,会提示在浏览器打开,类似下面 image.png 所以在微信公众号的支付宝支付最终是通过手机浏览器唤起的支付宝支付,按照手机网站的支付方式即可. 官方也有demo,官方 ...

  5. vue项目在ie浏览器中不兼容问题的处理

    安装babel-polyfill 插件 npm install --save-dev babel-polyfill 或者 npm install babel-polyfill --save-dev 或 ...

  6. 解决vue项目在ie浏览器中不显示的问题

    安装 "babel-polyfill" npm install babel-polyfill --save-dev 或者 cnpm install babel-polyfill - ...

  7. php 公众号内h5支付宝支付宝支付宝支付宝支付,微信浏览器中支付宝wap支付和微信JSAPI公众号支付...

    手机浏览器只有支付宝wap支付,微信浏览器中出现支付宝wap支付和微信JSAPI公众号支付,其中支付宝wap在线支付没有在新窗口打开(兼容大部分手机),Thinkphp3.2公众号支付 下载资源 下载 ...

  8. 如何在微信h5拉起支付宝支付界面

    微信拉起支付宝支付会有一个中间页面跳转,具体操作步骤如下: 1.中间页引导用户在浏览器中打开去唤起支付宝. 2.浏览器中打开支付宝或app中打开支付宝. 3.唤起成功后,进行支付宝支付:支付成功.支付 ...

  9. 支付宝网站支付在微信浏览器中跳转问题(亲测,附源码)

    文章目录 前言 具体步骤 配置沙箱回调地址,修改代码支付宝网关 准备加密js以及跳转html 源码下载地址 前言 奉上整理好的测试url: 点我调用支付宝 之前的博客中提到了使用支付宝提供的sdk实现 ...

最新文章

  1. 第58件事 借势文案创作实例
  2. figma导出android切图,谁再说Figma没办法导出标注和切图,你把这个插件转发给他...
  3. android视图工具,android studio的HierarchyViewer工具如何知道android屏幕的视图属性
  4. Shell入门(四)之数组
  5. 简单的C语言程序合集-2
  6. 软件测试三种错误的是,软件测试中的三种排错方法(知识篇)
  7. DirectFB简介以及移植[一]【转】
  8. Bzoj1007 [HNOI2008]水平可见直线
  9. X5045的C语言源码,X5045看门狗的单片机源程序和Proteus仿真原理图
  10. Windows工具 - 查看apk信息 - 包名/支持Android版本/支持架构等
  11. 【云原生】Docker高级篇之网络、compose、可视化、监控
  12. 扫描电子显微镜SEM在失效分析中的应用
  13. Confusing conditions about MySQL script
  14. Banner设计技巧总结
  15. cad2020打印样式放在哪个文件夹_deepin使用笔记——Linux配置惠普(HP)打印机
  16. paddlepaddle、paddlehub依赖包下载并离线安装
  17. gammatone 滤波器详解及其MATLAB代码实现
  18. RabbitMQ and Oslo.messaging
  19. 力天创见排队客流统计
  20. Unity3d C# 使用Universal Media Player(ump)插件播放视频的众坑之无法播放视频和VLC播放器依赖的问题

热门文章

  1. 比较全面的C/C++框架和库
  2. 分享崔庆才的一些学习经验和生活感悟
  3. 图层样式和混合模式—制作美国队长盾牌
  4. 小米华为手机自带浏览器上传图片提示:没有应用可执行操作
  5. 天天福利抽奖-JAVA概率抽奖
  6. 各种计算机语言的区别
  7. 毕业生必须知道:干部身份、三方协议、派遣证、人事代理、户口迁移 、编制、工龄、签约、档案 1
  8. 柱形图和折线图在一个坐标轴ECharts
  9. C#实现IVR(基于东进的语音卡)-3
  10. 总结——复杂网络动力学