织梦后台login.php不显示验证码,织梦dedecms后台验证码不显示或不正确的三种原因及解决方法...

"本文介绍了当PHP验证码出现只显示背景不显示字母的情况时,如何通过检查字体文件和修改代码来解决。具体解决方法包括确认字体文件存在、修正路径中的反斜杠,并提供了取消后台登录验证码的步骤,涉及对login.php文件的修改和datasafeinc_safe_config.php文件的配置调整。"
摘要由CSDN通过智能技术生成

验证码只显示背景不显示字母:

这种情况验证码只显示背景 不显示字母,解决办法:

打开验证码生成文件 Include/vdimgck.php 找到

for($i=0;$i

{

$bc = mt_rand(0, 1);

$rndstring[$i] = strtoupper($rndstring[$i]);

$c_fontColor = $fontColor[mt_rand(0,4)];

$y_pos = $i==0 ? 4 : $i*($font_size+2);

$c = mt_rand(0, 15);

@imagettftext($im, $font_size, $c, $y_pos, 19, $c_fontColor, $font_file, $rndstring[$i]);

$lastc = $rndstring[$i];

}

Imagettftext()函数没有成功的执行导致了验证码只显示背景,不显示字母,解决方法如下:

1、确认include/data/fonts/ 里面存在字体文件,默认为ggbi.ttf

2、在for($i=0;$i

即把字体文件路径中反斜杠替换成斜杠 因为我们知道反斜杠有转译字符的功能,

系统错误的把反斜杠当作转义用了,导致$font_file也就不是一个路径,所以Imagettftext()函数总是返回错误,

加上$font_file= str_replace("\\","/",$font_file);即可解决。

取消后台登录验证码分为两步:

打开dede目录下的 login.php 找到:if($validate==” || $validate != $svali)

替换为:if( false )

然后,在模板dede/templets/login.htm里去掉以下验证码的具体HTML代码:

验证码:

  

取消验证码:

在后台的 [验证码安全设置] 里,说修改后的保存实际上是修改了data\safe\inc_safe_config.php 这个文件,这是个配置文件。

比如:$safe_gdopen = ’1,2,3,5,6,7′; 这个就是系统哪些地方开启验证码。与[验证码安全设置]界面是一对一的关系。

所以,如果当我们管理后台想关闭验证码(如果验证码无法正确输入,不支持GB库)的时候,只需要打开data\safe\inc_safe_config.php

将$safe_gdopen = ’1,2,3,5,6,7′; 中的6,7删除即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值