<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
</head> <body>
<?php 
    Header("Content-type: image/PNG"); 
    
    srand((double)microtime()*1000000);//播下一个生成随机数字的种子,以方便下面随机数生成的使用
    
    $im = imagecreate(62,20); //制定图片背景大小
    $black = ImageColorAllocate($im, 0,0,0); //设定三种颜色
    $white = ImageColorAllocate($im, 255,255,255); 
    $gray = ImageColorAllocate($im, 200,200,200); 
    imagefill($im,0,0,$gray); //采用区域填充法,设定(0,0)
    while(($authnum=rand()%100000)<10000);
    //将四位整数验证码绘入图片 
    $_SESSION['yzm']=$authnum;   //把验证码注册到session变量
    
    imagestring($im, 5, 10, 3, $authnum, $black);
    // 用 col 颜色将字符串 s 画到 image 所代表的图像的 x,y 座标处(图像的左上角为 0, 0)。
    //如果 font 是 1,2,3,4 或 5,则使用内置字体
    for($i=0;$i<200;$i++) //加入干扰象素 
    { 
        $randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
        imagesetpixel($im, rand()%70 , rand()%30 , $randcolor); 
    } 
    
    ImagePNG($im); 
    ImageDestroy($im); 
?> 
</body>
</html>
我觉得不是我的配置问题,别的PHP代码都好使,但是就这个不好使啊~

解决方案 »

  1.   

    <?phpsession_start();$rand=dechex(rand(1,15));for ($i = 0; $i < 3 ; $i++) { 
       $rand.=dechex(rand(1,15)); 
    }$_SESSION['checkcode']=$rand;$im = imagecreatetruecolor(62,20); $bg = imagecolorallocate($im,0,0,0); 
    $te = imagecolorallocate($im,255,255,255); 
    $gray = ImageColorAllocate($im, 200,200,200);  
    imagefill($im,0,0,$gray); //采用区域填充法,设定(0,0)for($i=0;$i<200;$i++) {  
      $randcolor = ImageColorallocate($im,rand(0,255),rand(0,255),rand(0,255));
      imagesetpixel($im, rand()%70 , rand()%30 , $randcolor);  
    }  
    imagestring($im,5,10,3,$rand,$te);
    header("content-type:image/png"); 
    ImagePNG($im);  
    ImageDestroy($im);  
    ?>
    前面的那段html不需要,文件格式改成UTF-8无BOM
      

  2.   

    前两天不是问过了嘛?在html文件里调用这个php文件
    <img src="xxxxx.php">
    或者像1楼那样直接输出图片