日期:2014-05-17  浏览次数:20691 次

为什么这段代码调试的时候提示下载???
<!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代码都好使,但是就这个不好使啊~

------解决方案--------------------
PHP code


<?php

session_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文件里调用这个php文件
<img src="xxxxx.php">
或者像1楼那样直接输出图片