firebug多次发送请求-----排查bug流程实例

在做某个小任务的时候,做了两个小页面,一个提交,一个判断接收

提交页:index1.php

<!DOCTYPE html>
<html>
<head>
	<title></title>
	
</head>
<body>
<form action="http://172.16.233.128/task/index2.php" method="post">
	<input type="text" name="verify">请输入验证码
	<img id="checkpic" οnclick="document.getElementById('checkpic').src='verify.php?tm='+Math.random()" src='./verify.php' />
	<input type="submit" value="提交">
</form>
</body>
</html>
判断接收页:index2.php

<?php 
$verify =$_COOKIE["verification"];
echo $verify.'</hr>';
echo $_POST['verify'];
if(!empty($_POST)){

	if($_POST['verify'] == $verify){
		print_r($_POST);
	}else{
		echo "验证码不正确";
	}

}else{
	echo '没有post数据,验证码是:'.$verify;
}

 ?>
 

验证码verify.php:

<?php
 
session_start();
function random($len) {
    $srcstr = "1a2s3d4f5g6hj8k9qwertyupzxcvbnm";
    mt_srand();
    $strs = "";
    for ($i = 0; $i < $len; $i++) {
        $strs .= $srcstr[mt_rand(0, 30)];
    }
    return $strs;
}
 
//随机生成的字符串
$str = random(4);
 
//验证码图片的宽度
$width  = 50;     
 
//验证码图片的高度
$height = 25;    
 
//声明需要创建的图层的图片格式
@ header("Content-Type:image/png");
 
//创建一个图层
$im = imagecreate($width, $height);
 
//背景色
$back = imagecolorallocate($im, 0xFF, 0xFF, 0xFF);
 
//模糊点颜色
$pix  = imagecolorallocate($im, 187, 230, 247);
 
//字体色
$font = imagecolorallocate($im, 41, 163, 238);
 
//绘模糊作用的点
mt_srand();
for ($i = 0; $i < 1000; $i++) {
    imagesetpixel($im, mt_rand(0, $width), mt_rand(0, $height), $pix);
}
 
//输出字符
imagestring($im, 5, 7, 5, $str, $font);
 
//输出矩形
imagerectangle($im, 0, 0, $width -1, $height -1, $font);
 
//输出图片
imagepng($im);
 
imagedestroy($im);
 
// $str = md5($str);
 
//选择 cookie
SetCookie("verification", $str, time() + 3600, "/");
 
//选择 Session
// $_SESSION["verification"] = $str;
?>


出的问题就是呢:在firefox浏览器中,比如说刷新了index1.php页面,图片验证码显示为x5km,


查看firebug里面的响应头中也是x5km,


然后再次刷新页面,图片验证码显示为kmas,查看firebug里面的响应头中也是kmas,但是!!!请求头中并不是x5km!!   


那么问题来了,按原理来说请求头中的verify就应该是x5km,那么现在不是x5km的话,可能就是发送了不只一次请求,那么首先,要去查看一下nginx的日志里面是否有显示请求信息,那么请看:

verify.php发送了一次请求,

verify.php居然发送了两次请求

那么为什么有时候发送一次,有时候会发送两次请求呢??可能是文件出了问题?那么去看看文件,verify.php,发现并没有什么问题,那么文件没有问题的话,是不是跟浏览器有关系呢?再打开chrom,看一下,发现不管在chrom中怎么刷新,每次都只发送一次请求。


那么,那可能就是浏览器的问题。那么,火狐干了什么会发送两次请求呢?再切换到火狐浏览器,刷新页面,查看nginx行为日志里面有没有什么变化,发现!!每次把鼠标一放到firebug上,火狐就会重新发送一次请求  

当鼠标移到firebug中查看那张图片,发现和上面图片中的不一样了,说明火狐又发送了请求。那把firebug关掉呢:

全部只发送一次!!!

那么结果就是,刷新页面火狐发送一次请求,鼠标移到firebug又发送一次请求

总共两次,而且每把鼠标移到firebug一次,就会发送一次请求

那么问题就这样解决了。

所以,解决问题的思路有时候显得特别重要,一些错误肯定是有迹可循的,关键在于你知不知道,你知道了之后会不会用来排错。以后排错就得这样一步一步来。不过火狐这货。。。。。。哎。。。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值