隐藏Apache的版本号

本文介绍了如何在Apache服务器上隐藏Django应用的版本信息,以防止潜在的安全风险。通过使用mod_headers模块的Header命令和ServerTokens配置,可以有效地从响应头中移除或限制透露服务器的具体版本。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在用Django搞一个小玩意,但又担心被别人笑话,于是留了个心眼,将Django部署到Apache上,然后wget看看有无要紧消息(用-S,--spider返回头信息):


HTTP request sent, awaiting response...
  HTTP/1.1 200 OK
  Date: Thu, 16 Sep 2010 14:07:14 GMT
  Server: Apache/2.2.16 (Unix) mod_wsgi/3.3 Python/2.6.5
  Keep-Alive: timeout=5, max=100
  Connection: Keep-Alive
  Content-Type: text/xml;charset=gbk
Length: unspecified [text/xml]
200 OK

 

这可不得了,如若让Django的仇家知道,岂非会被误杀?

 

上网google半响,找到一个mod_headers,支持关闭/增加/设置任一http头,于是在httpd.conf里增加一条命令:

 

Header unset Server

 

但是不管用,尝试了一下unset Connection,结果里果然没了Connection这个头,也就是说Header unset对Server无用。

岂有此理,又不是圣斗士?于是查了一下,原来很久以前就有人报告这个问题了

https://issues.apache.org/bugzilla/show_bug.cgi?id=40026

开发人员用此名句回复:It's not a bug, but a feature

不过改哥们可能也不太好意思,还是提供了一个折中方案,用ServerTokens命令:

 

ServerTokens Prod

 

这次再看看Http回复头:

 

HTTP request sent, awaiting response...
  HTTP/1.1 200 OK
  Date: Thu, 16 Sep 2010 14:29:39 GMT
  Server: Apache
  Keep-Alive: timeout=5, max=100
  Connection: Keep-Alive
  Content-Type: text/xml;charset=gbk
Length: unspecified [text/xml]
200 OK

 

虽然还是可能被Apache的仇家追杀,但是...就这样吧

 

今天真是充实的一天啊。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值