项目中需要对安全问题引起足够的重视,比如下列tomcat的安全问题容易被忽略:
server.xml默认有下面一行:
[code="java"]
<Server port="8005" shutdown="SHUTDOWN">
[/code]
这样允许任何人只要telnet到服务器的8005端口,输入"SHUTDOWN",然后回车,服务器立即就被关掉了。
从安全的角度上考虑,我们需要把这个shutdown指令改成一个别人不容易猜测的字符串。
例如修改如下:
[code="java"]
<Server port="8006" shutdown="lizongbo">,
[/code]
这样就只有在telnet到8006,并且输入"lizongbo"才能够关闭Tomcat.
注意:这个修改不影响shutdown.bat的执行。运行shutdown.bat一样可以关闭服务器。
参考Tomcat安全文档英文链接:http://jakarta.apache.org/tomcat/faq/security.html#8005
还有两个问题需要注意:
[color=red]1、 对于tomcat3.1中,屏蔽目录文件自动列出的方法是什么? [/color]
缺省情况下,如果你访问tomcat下的一个web应用,那么如果你输入的是一个目录名,而且该目录下没有一个可用的welcome文件,那么tomcat会将该目录下的所有文件列出来,如果你想屏蔽这个缺省行为,那么可以修改conf/web.xml文件,将其中的:
[code="java"]
<servlet>
<servlet-name>default</servlet-name>
<servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>0</param-value>
</init-param>
<init-param>
<param-name>listings</param-name>
<param-value>true</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
[/code]
修改为:
[code="java"]
<servlet>
<servlet-name>default</servlet-name>
<servlet-class>org.apache.catalina.servlets.DefaultServlet</servlet-class>
<init-param>
<param-name>debug</param-name>
<param-value>0</param-value>
</init-param>
<init-param>
<param-name>listings</param-name>
<param-value>false</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
[/code]
[color=red]2、 如何让Tomcat记录客户端的访问日志 [/color]
下面是Tomcat相关手册中的介绍:
以下是引用来自 的内容:
Valve (功能与Logger差不多,其prefix和suffix属性解释和Logger 中的一样) className 指定Valve使用的类名,
如用org.apache.catalina.valves.AccessLogValve类可以记录应用程序的访问信息 directory 指定log文件存放
的位置 pattern 有两个值,common方式记录远程主机名或ip地址,用户名,日期,第一行请求的字符串,HTTP响
应代码,发送的字节数。combined方式比common方式记录的值更多
所以需要完成的步骤:
1。修改Tomcat的conf/server.xml文件。
2。加上Valve节点到server.xml文件中,和您目前使用的Connector的节点平级。
如:<Valve className="org.apache.catalina.valves.AccessLogValve"
directory="e:\trs\trscds\tomcat\logs" pattern="combined"/>
3。重新启动您的Tomcat
4。有用户在访问的时候,在指定的log目录下面会生成一个access_log文件(每天一个)。
上述的步骤是以Tomcat4.x为例。(可能会影响性能,不推荐大家使用)。
[color=red]还有一个问题:需要处理好Tomcat管理台的安全。[/color]
Tomcat管理台的应用文件,默认在{Tomcat安装目录}\server\webapps下,有admin和manager两个应用。
其用户密码,在{Tomcat安装目录}\conf/tomcat-users.xml中定义。在{Tomcat安装目录}\webapps下
admin.xml和manager.xml文件定义了可以通过访问/admin和/manager进入。
默认情况下,完全可以登录tomcat管理台,造成严重安全问题
检测办法:用IE打开链接http://[IP]:[Port]/admin,以用户名admin,密码为空登录,如果成功,
说明存在问题。
解决办法:可以删除{Tomcat安装目录}\webapps下admin.xml和manager.xml文件,或者去掉用户密
码,也可以删除应用文件。
我们一个用户提到如果找不到网页即出现404错误,会显示服务器版本号,服务器配置也一目了然,
为了避免这种情况,希望自定义设置错误页面。
设置如下:
1、将附件的index.htm文件拷贝至\webapps\ROOT目录内,删除或改名原来的index.jsp文件。
2、用记事本打开\conf\web.xml文件,在文件的倒数第二行(</web-app>一行之前)加入以下内容:
code="java"]
<error-page>
<error-code>404</error-code>
<location>/index.htm</location>
</error-page>
[/code]
分享到:
相关推荐
此外,安全性和性能优化也是管理Tomcat时不可忽视的方面,例如定期更新Tomcat以修复安全漏洞,以及根据实际负载调整配置参数。 总的来说,Apache Tomcat 7.0.2是一个强大的Java Web应用服务器,它的易用性和高效性...
4. `webapps` 目录:默认的应用部署位置,任何放置在此目录下的Web应用结构会被Tomcat自动识别并部署。 5. `work` 目录:存储编译后的JSP页面和Servlet的临时工作文件。 6. `logs` 目录:记录Tomcat运行时的日志文件...
在运行环境方面,应确保运行Tomcat的用户权限不是最高权限,例如在Windows下的administrator和Linux下的root用户或用户组。推荐创建一个专门的Tomcat用户,并根据业务需求对涉及的应用文件夹的读取、写入和执行权限...
1. **bin** 目录:包含了可执行文件和脚本,如`catalina.sh`(Unix/Linux系统)和`catalina.bat`(Windows系统),这些是启动、停止和管理Tomcat服务器的命令。 2. **conf** 目录:存储服务器配置文件,如`server....
在Linux环境中,Web服务器的安全性至关重要,因为它通常是网络服务的入口点,承载着大量敏感信息。本篇文章将深入探讨Linux Web安全的一些关键设置,以帮助您保护系统免受潜在威胁。 首先,我们来关注Web服务器的...
5. **社区支持**:尽管版本较老,但在网上仍然可以找到关于Tomcat 6的大量文档和论坛讨论,开发者社区提供的支持不容忽视。 在解压"apache-tomcat-6.0.20.zip"后,你会得到以下主要组件: - `bin`目录:包含启动和...
总的来说,tcnative-1.dll在Java应用尤其是Tomcat服务器中的作用不可忽视,正确使用和更新这个库文件对于提升服务器性能和保证系统安全至关重要。在实际部署时,应根据具体需求和系统环境选择合适的版本,并确保正确...
在Linux服务器环境中,JDK1.8广泛应用于各种服务器软件,如Tomcat、Jetty、JBoss等。运维人员需要确保JDK的稳定性和安全性,定期更新JDK以修复安全漏洞,并监控Java应用的性能,如内存使用、CPU负载和网络I/O。此外...
9. **部署与运行**:在Linux环境下,解压"struts-1.2.8-bin.tar.gz"后,需要将其包含的JAR文件添加到项目的类路径中,然后按照Web应用的部署规范,将应用目录复制到Tomcat或其他Servlet容器的webapps目录下。...
- 默认情况下,Linux系统中Apache服务通常使用`apache`或`nobody`用户,而Unix系统则使用`daemon`用户。 ##### 2. 授权设置 - **严格控制Apache主目录的访问权限** - 设置Apache主目录的权限,确保非超级用户无法...
服务器上常需要安装数据库管理系统(如MySQL、PostgreSQL)、中间件(如Tomcat、IIS)、开发环境(如Python、Java等)等。软件安装应遵循最小化安装原则,只安装必需组件,以降低安全风险。同时,定期更新软件版本,...
2. **Shell命令**:Shell是Unix/Linux系统中的一个命令行接口,允许用户通过输入命令来执行各种系统操作。通过Web应用执行Shell命令,可以实现如文件管理(创建、移动、删除、重命名)、进程控制(启动、停止、重启...