• 解决PHP生成校验码或者是图像时“图像因其本身有错无法显示”的错误


     解决PHP生成校验码时“图像因其本身有错无法显示”的错误
    今天使用PHP生成校验码功能的实现,发现firefox一直提示“图像.......因其本身有错无法显示”的问题,提示了说“如果浏览器显示“图像XXX因其本身有错无法显示”,可尽量去掉文中空格”,但把代码中所有空格都去掉了还是不能显示检验图片。于是深度google,大部分的解决方案也是将“<?”这句代码前的空格回车一切都删掉以防止有html输出,但这根本解决不了我的问题,后来看到有人在Header("Content-type: image/PNG");这句代码前使用ob_clean()清除输出,结果一试之下果然成功。现将原代码修改后贴到下面,以备不时之需(使用方法参看原帖):
    
        <?php 
        session_start(); 
        session_register("login_check_number");   
        //先成生背景,再把生成的验证码放上去 
        $img_height=70;//先定义图片的长、宽 
        $img_width=25; 
        $authnum=''; 
        //生产验证码字符 
        $ychar="0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z"; 
        $list=explode(",",$ychar); 
        for($i=0;$i<4;$i++){ 
            $randnum=rand(0,35); 
            $authnum.=$list[$randnum]; 
        } 
        //把验证码字符保存到session 
        $_SESSION["login_check_number"] = $authnum;   
         
        $aimg = imagecreate($img_height,$img_width);    //生成图片 
        imagecolorallocate($aimg, 255,255,255);            //图片底色,ImageColorAllocate第1次定义颜色PHP就认为是底色了 
        $black = imagecolorallocate($aimg, 0,0,0);        //定义需要的黑色 
         
        for ($i=1; $i<=100; $i++) { 
            imagestring($aimg,1,mt_rand(1,$img_height),mt_rand(1,$img_width),"@",imagecolorallocate($aimg,mt_rand(200,255),mt_rand(200,255),mt_rand(200,255))); 
        } 
         
        //为了区别于背景,这里的颜色不超过200,上面的不小于200 
        for ($i=0;$i<strlen($authnum);$i++){ 
            imagestring($aimg, mt_rand(3,5),$i*$img_height/4+mt_rand(2,7),mt_rand(1,$img_width/2-2), $authnum[$i],imagecolorallocate($aimg,mt_rand(0,100),mt_rand(0,150),mt_rand(0,200))); 
        } 
        imagerectangle($aimg,0,0,$img_height-1,$img_width-1,$black);//画一个矩形 
        ob_clean();  //关键代码,防止出现'图像因其本身有错无法显示'的问题。
        Header("Content-type: image/PNG"); 
        ImagePNG($aimg);//生成png格式 
        ImageDestroy($aimg); 
        ?> 
  • 相关阅读:
    Java可变参数
    为什么static方法中不可以调用非static方法
    用注解@DelcareParents实现引用增强
    在SpringBoot中用SpringAOP实现日志记录功能
    梳理一下我理解的aop
    包裹iframe的div与iframe存在高度差的问题解决方案
    非跨域情况下iframe 高度自适应的问题解决(一)
    flex布局较之float布局的优点新发现
    webpack4 动态导入文件 dynamic-import 报错的解决方法
    vue chrome 浏览器调试工具devtools插件安装
  • 原文地址:https://www.cnblogs.com/cms100/p/3280701.html
Copyright © 2020-2023  润新知