从命令行使用 wget 调试网页错误

时间:2022-05-13 12:40:46

从命令行使用 wget 调试网页错误

调试 Web 服务器的一种方法是使用 wget 命令行程序。

有时在管理一个网站时,事情会被搞得一团糟。你可能会删除一些陈旧的内容,用重定向到其他页面来代替。后来,在做了其他改动后,你发现一些网页变得完全无法访问了。你可能会在浏览器中看到一个错误:“该页面没有正确重定向”,并建议你检查你的 cookie。

从命令行使用 wget 调试网页错误

Redirect loop example in Firefox

调试这种情况的一个方法是使用 wget 命令行程序,使用 -S 选项来显示所有的服务器响应。当使用 wget 进行调试时,我也喜欢使用 -O 选项将输出保存到一些临时文件中,以备以后需要查看其内容。

  1. $ wget -O /tmp/test.html -S http://10.0.0.11/announce/
  2. --2021-08-24 17:09:49-- http://10.0.0.11/announce/
  3. Connecting to 10.0.0.11:80... connected.
  4.  
  5. HTTP request sent, awaiting response...
  6.  
  7. HTTP/1.1 302 Found
  8. Date: Tue, 24 Aug 2021 22:09:49 GMT
  9. Server: Apache/2.4.48 (Fedora)
  10. X-Powered-By: PHP/7.4.21
  11. Location: http://10.0.0.11/assets/
  12. Content-Length: 0
  13. Keep-Alive: timeout=5, max=100
  14. Connection: Keep-Alive
  15. Content-Type: text/html; charset=UTF-8
  16. Location: http://10.0.0.11/assets/ [following]
  17. --2021-08-24 17:09:49-- http://10.0.0.11/assets/
  18. Reusing existing connection to 10.0.0.11:80.
  19.  
  20. HTTP request sent, awaiting response...
  21.  
  22. HTTP/1.1 302 Found
  23. Date: Tue, 24 Aug 2021 22:09:49 GMT
  24. Server: Apache/2.4.48 (Fedora)
  25. X-Powered-By: PHP/7.4.21
  26. Location: http://10.0.0.11/announce/
  27. Content-Length: 0
  28. Keep-Alive: timeout=5, max=99
  29. Connection: Keep-Alive
  30. Content-Type: text/html; charset=UTF-8
  31. Location: http://10.0.0.11/announce/ [following]
  32. --2021-08-24 17:09:49-- http://10.0.0.11/announce/
  33. Reusing existing connection to 10.0.0.11:80.
  34. .
  35. .
  36. .
  37. 20 redirections exceeded.

我在这个输出中省略了很多重复的内容。通过阅读服务器的响应,你可以看到 http://10.0.0.11/announce/ 立即重定向到 http://10.0.0.11/assets/,然后又重定向到 http://10.0.0.11/announce/。以此类推。这是一个无休止的循环,wget 将在 20 次重定向后退出。但有了这些调试信息,你可以修复重定向,避免循环。

原文链接:https://linux.cn/article-13795-1.html