firebug多次发送请求-----排查bug流程实例
来源:互联网 发布:2015年12月非农数据 编辑:程序博客网 时间:2024/06/09 15:46
在做某个小任务的时候,做了两个小页面,一个提交,一个判断接收
提交页: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" onclick="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); //选择 cookieSetCookie("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一次,就会发送一次请求
那么问题就这样解决了。
所以,解决问题的思路有时候显得特别重要,一些错误肯定是有迹可循的,关键在于你知不知道,你知道了之后会不会用来排错。以后排错就得这样一步一步来。不过火狐这货。。。。。。哎。。。
- firebug多次发送请求-----排查bug流程实例
- bug排查流程总结
- 程序的bug排查流程总结
- Android 发送http请求实例
- http发送服务请求实例
- java发送http请求实例
- AJAX 多次发送异步请求的 XmlHttpRequest 对象的设置
- volley 发送两次或者多次请求问题,解决方案
- 防止用户多次点击按钮,导致发送多次请求或者其他问题。
- 请求地址 - 多次请求
- 网络请求 多次请求
- Nodejs 发送HTTP POST请求实例
- jsp页面发送ajax请求实例
- C# Http 发送Post请求实例
- Nodejs 发送HTTP POST请求实例
- java发送https post请求实例
- jquery ajax发送请求实例模板
- java发送https post请求实例
- java--异常处理机制
- 计划在CSDN学院推出系列视频课程《源码分析教程5部曲》
- madvr视频渲染器 v0.90免费版
- hdoj Human Gene Functions 1080 (DP) 字符串匹配求最大和
- 批量添加samba用户
- firebug多次发送请求-----排查bug流程实例
- JSP MVC模式
- dB、dbm、dbw、W 相互关系
- Python 包工具之间的关系
- 网络最经典命令行
- android 让一个控件按钮居于底部的几种方法
- leetcode125---Valid Palindrome(回文字符串)
- 使用Git命令把本地项目上传到Github托管
- Hive 1.2.1 UI(HWI)配置