如何解决自定义微信登录扫码样式的问题-创新互联

这篇文章主要介绍了如何解决自定义微信登录扫码样式的问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

创新互联是一家专业从事成都网站建设、网站建设、网页设计的品牌网络公司。如今是成都地区具影响力的网站设计公司,作为专业的成都网站建设公司,创新互联依托强大的技术实力、以及多年的网站运营经验,为您提供专业的成都网站建设、营销型网站建设及网站设计开发服务!

PC微信扫码登录

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

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

当一切准备妥当之后,网页上的二维码初始默认是这个样子。
如何解决自定义微信登录扫码样式的问题
特别大不说(默认二维码大小280x280),还有微信登录的title,下方也有扫码登录的提示。
幸运的是,微信留了一个api给我们自定义样式的机会,在之前实例化一个二维码的时候,实例对象中href属性,允许设置样式。

 var obj = new WxLogin({
                        id:"login_container", 
                        appid: "", 
                        scope: "", 
                        redirect_uri: "",
                        state: "",
                        style: "",
                        href: "../qrcode.css"//就是这个属性
                       });

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

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

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

var fs = require('fs');

// function to encode file data to base64 encoded string
function base64_encode(file) {
    // read binary data
    var bitmap = fs.readFileSync(file);
    // convert binary data to base64 encoded string
    return 'data:text/css;base64,'+new Buffer(bitmap).toString('base64');
}

console.log(base64_encode('./qrcode.css'))

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

 var obj = new WxLogin({
                        id:"login_container", 
                        appid: "", 
                        scope: "", 
                        redirect_uri: "",
                        state: "",
                        style: "",
                                           href:"data:text/css;base64,LmltcG93ZXJCb3ggLnFyY29kZSB7d2lkdGg6IDIwMHB4O30NCi5pbXBvd2VyQm94IC50aXRsZSB7ZGlzcGxheTogbm9uZTt9DQouaW1wb3dlckJveCAuaW5mbyB7d2lkdGg6IDIwMHB4O30NCi5zdGF0dXNfaWNvbiB7ZGlzcGxheTpub25lf
Q0KLmltcG93ZXJCb3ggLnN0YXR1cyB7dGV4dC1hbGlnbjogY2VudGVyO30="//data-url
                       });

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

感谢你能够认真阅读完这篇文章,希望小编分享的“如何解决自定义微信登录扫码样式的问题”这篇文章对大家有帮助,同时也希望大家多多支持创新互联网站建设公司,,关注创新互联行业资讯频道,更多相关知识等着你来学习!

当前名称:如何解决自定义微信登录扫码样式的问题-创新互联
本文网址:https://www.cdcxhl.com/article4/ehgie.html

成都网站建设公司_创新互联,为您提供搜索引擎优化定制开发Google软件开发品牌网站设计网站设计公司

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都app开发公司