设为首页 收藏本站
查看: 1148|回复: 0

[经验分享] 修改NGINX版本名称伪装任意

[复制链接]

尚未签到

发表于 2018-11-12 10:12:23 | 显示全部楼层 |阅读模式
  这里把任意改称hello
  修改NGINX版本名称伪装任意
  无论是作为Web服务器或其他类型程序的反向代理服务器,Nginx("engine x")都有着高性能且轻量级的优势。其特点是占有内存少,并发能力强,事实上Nginx的并发能力确实在同类型的网页服务器中表现较好。这也使得Nginx在如今不管是存放在高配独立服务器上的大型的门户,还是存放在迷你64M内存VPS上的小型的个人博客,Nginx都在被广泛使用着。
  国内淘宝、新浪、网易、腾讯等都在使用。其中淘宝正是基于原作者的BSD-like协议,在其源代码基础上开发了Tengine,这暂且不谈。
  今天我们来说说,如何修改Nginx其内部默认名称。这对安全或者装逼都是非常实用的。
  一般来说修改3个位置,一个是nginx.h、另一个是ngx_http_header_filter_module.c、还有一个ngx_http_special_response.c。
  提示:以下修改需要在编译安装Nginx之前进行,修改之后再编译
  现在Web Server使用广泛,针对它的***也越来越多,Nginx这玩意出道时间也并不长,虽然国内很多门户网站都用它,小内存VPS用户也爱它,但是我可不想哪天它爆出了个惊天BUG,上次80sec公布的Nginx相关PHP FPM漏洞就是警示哦,倘若伪装了我的Nginx服务器,***者就不知道我使用的是何种Web Server,也就无从下手了。
  修改src/core/nginx.h(Nginx内部名称的)
  #define NGINX_VERSION      "1.8.0"
  #define NGINX_VER          "hello/" NGINX_VERSION
  NGINX_VERSION是版本号,NGINX_VER是名称
  修改src/http/ngx_http_header_filter_module.c(HTTP ResponseHeader)
  tatic u_char ngx_http_server_string[] = "Server: hello" CRLF;
  static u_char ngx_http_server_full_string[] = "Server: hello"  CRLF;
  static u_char ngx_http_server_build_string[] = "Server: hello"  CRLF;
  修改src/http/ngx_http_special_response.c(修改错误页的底部Footer)
  static u_char ngx_http_error_tail[] =
  "hello" CRLF
  "" CRLF
  "" CRLF
  ;修改NGINX版本名称伪装任意
  **
  为什么不修改安装后的Nginx Config下的fastcgi.conf呢?
  因为现在外部已经是无法了解我们的服务器名称,已经达到我们的目的了。
  而且我们常用的一些程序,可能会对你的前端(反向代理服务器)做判断,毕竟Nginx不同于Apache,无法动态规则。
  特别是Wordpress的缓存插件,大多会通过判断你是否Nginx,如果是的话,提醒你添加一些规则语句。
  这时fastcgi.conf就起作用的,其中的
  fastcgi_param SERVER_SOFTWARE
  nginx/$nginx_version;可以使得PHP与Nginx内部之间的互相了解。
  所以我的建议,还是不修改fastcgi.conf,当然你非要改,也可以的。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-634017-1-1.html 上篇帖子: lanmp架构-------------nginx 下篇帖子: 2.Nginx学习-The HTTP Core module
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表