wordpress如何實現QQ微信釘釘Github手機號登陸

下面由WordPress教程欄目給大家介紹wordpress怎么實現qq微信釘釘github手機號登陸,希望對需要的朋友有所幫助!

wordpress版本:wordpress:4.9.8版本php版本:v7.2.12dockcer鏡像為:wordpress:4.9.8

圖形驗證碼加載不出來

最近利用wordpress建站的時候,用到了wechat-social-login插件實現微信、QQ、釘釘、Github登陸功能時,開啟圖形驗證碼功能后,看到圖形二維碼一直加載不出來,F12看到狀態碼為200,但沒有返回值,報錯this request has no response data available

wordpress如何實現QQ微信釘釘Github手機號登陸

wordpress如何實現QQ微信釘釘Github手機號登陸
打開wordpress日志后,發現debug日志文件中報以下的錯誤。開啟debug日志方法請移步歷史文章如何開啟WordPress調試模式(報錯提示),將日志打印到wp-content目錄下的debug.log中。
wordpress如何實現QQ微信釘釘Github手機號登陸

[08-Feb-2020 07:37:42 UTC] PHP Fatal error:  Uncaught Error: Call to undefined function GregwarCaptchaimagettfbbox() in /var/www/html/wp-content/plugins/wechat-social-login/includes/captcha/CaptchaBuilder.php:327 Stack trace: #0 /var/www/html/wp-content/plugins/wechat-social-login/includes/captcha/CaptchaBuilder.php(440): GregwarCaptchaCaptchaBuilder->writePhrase(Resource id #7, '84sx', '/var/www/html/w...', 150, 40) #1 /var/www/html/wp-content/plugins/wechat-social-login/includes/social/class-xh-social-ajax.php(203): GregwarCaptchaCaptchaBuilder->build() #2 /var/www/html/wp-content/plugins/wechat-social-login/includes/social/class-xh-social-ajax.php(209): XH_Social_Ajax::{closure}() #3 /var/www/html/wp-includes/class-wp-hook.php(286): XH_Social_Ajax::captcha('') #4 /var/www/html/wp-includes/class-wp-hook.php(310): WP_Hook->apply_filters('', Array) #5 /var/www/html/wp-includes/plugin.php(453): WP_Hook->do_action(Array) #6 /var/www/html/wp-admin/admin-ajax.php(99): do_action('wp_ajax_xh_soci...') #7 {main}   thrown in /var/www/html/wp-content/plugins/wechat-social-login/includes/captcha/CaptchaBuilder.php on line 327

網站查詢資料說:圖形驗證碼功能需要安裝GD庫和freetype等依賴,通過phpinfo()查看到詳細信息里:gd擴展沒有freetype:
wordpress如何實現QQ微信釘釘Github手機號登陸

查看phpinfo()的方法

在網站的根目錄下新建一個php-info.php的文件,內容為:

<?php  phpinfo();

保存后,用域名訪問,如https://action.liabio.cn/php-info.php,即可看到。

docker編譯鏡像

Dockerfile文件如下:

FROM wordpress:4.9.8 RUN echo 'deb http://mirrors.163.com/debian/ stretch main contrib non-freendeb http://mirrors.163.com/debian/ stretch-updates main contrib non-freendeb http://mirrors.163.com/debian/ stretch-backports main contrib non-free' > /etc/apt/sources.list RUN apt update  && apt install -y libwebp-dev libjpeg-dev libpng-dev libfreetype6-dev  && docker-php-source extract  && cd /usr/src/php/ext/gd  && docker-php-ext-configure gd --with-webp-dir=/usr/include/webp --with-jpeg-dir=/usr/include --with-png-dir=/usr/include --with-freetype-dir=/usr/include/freetype2  && docker-php-ext-install gd  && php -m | grep gd

執行以下編譯命令:

docker build -t wordpress-freetype:4.9.8 .

結果編譯報錯。

docker編譯鏡像報錯

OCI runtime create failed: container_linux.go:346: starting container process caused "process_linux.go:319: getting the final child's pid from pipe caused "EOF"": unknown

因為我使用的是19.03.5版本的docker,在網上查了資料,大致意思是需要18版本的docker編譯才不會報錯。

果然,18版本的docker編譯沒有報錯:
wordpress如何實現QQ微信釘釘Github手機號登陸

使用集成了freetype的新鏡像

使用新鏡像后,可以看到freetype成功集成。
wordpress如何實現QQ微信釘釘Github手機號登陸
可以看到二維碼已經成功的顯示出來了。
wordpress如何實現QQ微信釘釘Github手機號登陸

? 版權聲明
THE END
喜歡就支持一下吧
點贊8 分享