Live Http headers是Firefox下Http头信息捕获利器,常用于安全测试。但不幸的是Replay功能无法在最近版本的Firefox浏览器(35.0.1)中工作,我决定在插件的官方版本更新之前做一个临时的修复。

我发现在HTTP Headers包含If-Modified-Since能够让replay功能重新工作。

什么是If-Modified-Since?

If-Modified-Since是标准的HTTP请求头标签,在发送HTTP请求时,把浏览器端缓存页面的最后修改时间一起发到服务器去,服务器会把这个时间与服务器上实际文件的最后修改时间进行比较。

If-Modified-Since用于记录页面最后修改时间的HTTP头信息,是由客户端往服务器发送的头,与之相似的是Last-Modified,不同的是Last-Modified是由服务器往客户端发送的 HTTP 头。
如果时间一致,那么返回HTTP状态码304(不返回文件内容),客户端接到之后,就直接把本地缓存文件显示到浏览器中。
如果时间不一致,就返回HTTP状态码200和新的文件内容,客户端接到之后,会丢弃旧文件,把新文件缓存起来,并显示到浏览器中。

如果把

If-Modified-Since: *

添加到Live HTTP Headers中replay功能的默认HTTP头中,就能使replay正常工作了。

修复方法:

在firfox地址栏输入:about:support

进入配置文件夹。

我这里Live HTTP Headers插件的目录在

.\extensions\{8f8fe09b-0bd3-4470-bc1b-8cad42b8203a}

然后再进入chrome目录,找到livehttpheaders.jar

修改livehttpheaders.jar中的文件/content/LiveHTTPReplay.js

原版:

if(!livehttpheaders) var livehttpheaders={};if(!livehttpheaders.replay) livehttpheaders.replay={};livehttpheaders.replay.live = window.arguments[0];livehttpheaders.replay.init = function() {
  var args = window.arguments;

  document.getElementById("livehttpheaders.replay.method").value = args[1];
  document.getElementById("livehttpheaders.replay.url").value = args[2];
  document.getElementById("livehttpheaders.replay.version").value = args[3];
  document.getElementById("livehttpheaders.replay.headers").value = args[4];
  if (args[5] != null) {
    document.getElementById("livehttpheaders.replay.post").value = livehttpheaders.replay.stringToEscape(args[5]);
    document.getElementById("livehttpheaders.replay.sendpost").checked="true";
  }

  livehttpheaders.replay.updatePost();}

修改为:

if(!livehttpheaders) var livehttpheaders={};if(!livehttpheaders.replay) livehttpheaders.replay={};livehttpheaders.replay.live = window.arguments[0];livehttpheaders.replay.init = function() {
  var args = window.arguments;

  document.getElementById("livehttpheaders.replay.method").value = args[1];
  document.getElementById("livehttpheaders.replay.url").value = args[2];
  document.getElementById("livehttpheaders.replay.version").value = args[3];
  document.getElementById("livehttpheaders.replay.headers").value = args[4] + "If-Modified-Since: *\n";
  if (args[5] != null) {
    document.getElementById("livehttpheaders.replay.post").value = livehttpheaders.replay.stringToEscape(args[5]);
    document.getElementById("livehttpheaders.replay.sendpost").checked="true";
  }

  livehttpheaders.replay.updatePost();}

修改完成以后重启firfox,试试replay功能,你会发现它已经能够正常工作了。

Notice:

修改之后把文件要打包成livehttpheaders.jar(不是livehttpheaders.zip)

送上已经修改好的

http://share.weiyun.com/3aa6305c265f8af77c9e0bd664e0775e密码:KdY5

相关链接

http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html

http://www.cnblogs.com/zh2000g/archive/2010/03/22/1692002.html

[作者/k623277335,转载请注明来自FreeBuf黑客与极客(FreeBuf.COM)]

源链接

Hacking more

...