自定义微信登录扫码样式解决办法

小云云
发布: 2017-12-08 14:38:56
原创
4322人浏览过

PC微信扫码登录

近期做一个pc端微信扫码登录的需求,微信扫码有两种方式,一种是新开一个二维码页面,另一种是内嵌入产品网页。本次以内嵌二维码为例,具体怎样在页面中显示一个登陆二维码,文档说的很清楚,就不赘述了。

解决自定义微信二维码样式问题

当一切准备妥当之后,网页上的二维码初始默认是这个样子。
自定义微信登录扫码样式解决办法

特别大不说(默认二维码大小280x280),还有微信登录的title,下方也有扫码登录的提示。
幸运的是,微信留了一个api给我们自定义样式的机会,在之前实例化一个二维码的时候,实例对象中href属性,允许设置样式。

<span style="font-size: 16px;"> var obj = new WxLogin({<br/>                        id:"login_container", <br/>                        appid: "", <br/>                        scope: "", <br/>                        redirect_uri: "",<br/>                        state: "",<br/>                        style: "",<br/>                        href: "../qrcode.css"//就是这个属性<br/>                       });<br/></span>
登录后复制

不幸的是,在href中传入样式文件的地址,会报错。貌似微信为了安全考虑,只允许访问https的资源。于是现在采用第二种解决办法data-url。

通过访问data-url解决样式问题

写一个nodejs,脚本将刚才的css资源转换为data-url。具体代码实现为:

<span style="font-size: 16px;">var fs = require('fs');<br/><br/>// function to encode file data to base64 encoded string<br/>function base64_encode(file) {<br/>    // read binary data<br/>    var bitmap = fs.readFileSync(file);<br/>    // convert binary data to base64 encoded string<br/>    return 'data:text/css;base64,'+new Buffer(bitmap).toString('base64');<br/>}<br/><br/>console.log(base64_encode('./qrcode.css'))<br/></span>
登录后复制

运行node脚本,复制打印出来的data-url,然后赋值给刚才的href。
自定义微信登录扫码样式解决办法

<span   style="max-width:90%"> var obj = new WxLogin({<br/>                        id:"login_container", <br/>                        appid: "", <br/>                        scope: "", <br/>                        redirect_uri: "",<br/>                        state: "",<br/>                        style: "",<br/>                                           href:"data:text/css;base64,LmltcG93ZXJCb3ggLnFyY29kZSB7d2lkdGg6IDIwMHB4O30NCi5pbXBvd2VyQm94IC50aXRsZSB7ZGlzcGxheTogbm9uZTt9DQouaW1wb3dlckJveCAuaW5mbyB7d2lkdGg6IDIwMHB4O30NCi5zdGF0dXNfaWNvbiB7ZGlzcGxheTpub25lf<br/>Q0KLmltcG93ZXJCb3ggLnN0YXR1cyB7dGV4dC1hbGlnbjogY2VudGVyO30="//data-url<br/>                       });<br/></span>
登录后复制

注意这里的MIME类型,一定要返回text/css。
自定义二维码:
自定义微信登录扫码样式解决办法

相关教程:

微信登录的一些新得

php二维码的生产以及下载方法

javascript生成二维码的两种方法

以上就是自定义微信登录扫码样式解决办法的详细内容,更多请关注php中文网其它相关文章!

微信app下载
微信app下载

微信是一款手机通信软件,支持通过手机网络发送语音短信、视频、图片和文字。微信可以单聊及群聊,还能根据地理位置找到附近的人,带给大家全新的移动沟通体验,有需要的小伙伴快来保存下载体验吧!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号