自定义tomcat服务器,tomcat服务器安全设置方法

Tomcat是一个HTTP服务器,是Sun透过Java Community Process开发的、对广泛使用的Servlet和JavaServer Page(JSP)技术的正式参考实作。Servlet和JSP技术用于建构HTTP服务器应用程序。虽然Servlet技术中加入了许多特性(包括存取安全性、Session管理和执行绪控制)。JSP技术提供了一种处理动态生成的 HTML 页面的简便方法,这些 HTML 页面被直接编译成 Servlet 以用于快速执行时作业。Tomcat除了上述的两种技术保障安全之外,还可以通过配置Tomcat的参数以增加安全性

安全设置:

1. 删除webapps目录下的所有文件,禁用tomcat管理界面

rm -rf /usr/local/tomcat/apache-tomcat-9.0.1/webapps/*

2.注释或删除tomcat-users.xml文件内的所有用户权限:

5a37d2fcf72772ab986d955f6de8e627.png

3.隐藏版本信息,修改conf/server.xml

c3f23a9797c4b927cc58a56bd73e5bb0.png

5a492fea461981e4a4d145e12f3cc73b.png

3.用户问题:

nginx,httpd 使用root用户启动守护80端口,子进程/线程会通过setuid(),setgid()两个函数切换到普通用户。即父进程所有者是root用户,子进程与多线程所有者是一个非root用户,这个用户没有shell,无法通过ssh与控制台登陆系统;

而Java 的JVM 是与系统无关的,是建立在OS之上的,使用什么用户启动Tomcat,那麽Tomcat 就会继承该所有者的权限。

这造成了一个问题,Linux系统小于1024的端口只有root可以使用,这也是Tomcat默认端口是8080。如果想使用80端口只能使用root启动Tomcat。这有带来了很多安全问题。

创建一个用户,只能用于启动tomcat:

groupadd -g 80 tomcat

adduser -o --home /tomcat --shell /sbin/nologin --uid 80 --gid 80 -c "Web server" tomcat

chown tomcat:tomcat -R /usr/local/tomcat/apache-tomcat-9.0.1/*

su - tomcat -c "/usr/local/tomcat/apache-tomcat-9.0.1/bin/startup.sh"

做一个端口映射,访问80时调用8080端口

iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080

5d59404f4133a2a9042216aa853b1d62.png

取消跳转:

iptables -t nat -D PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8080

4.关闭自动部署war

vim conf/server.xml

e485d2b5d613ef7d5ebcceefcfb63143.png

5.隐藏404出现的版本信息:

到lib下解压catalina.jar,   jar xf catalina.jar

vim /usr/local/tomcat/apache-tomcat-9.0.1/lib/org/apache/catalina/util/ServerInfo.properties

5f62684cc2f7b2285136678bffd48038.png

0e4fa78e81be675b7dcd0feb4c682b1d.png

6.更改关闭tomcat指令

server.xml中定义了可以直接关闭 Tomcat 实例的管理端口。我们通过 telnet 连接上该端口之后,输入 SHUTDOWN (此为默认关闭指令)即可关闭 Tomcat 实例(注意,此时虽然实例关闭了,但是进程还是存在的)。由于默认关闭Tomcat 的端口和指令都很简单。默认端口为8005,指令为SHUTDOWN 。需要将关闭指令修改复杂一点。

ce3739d5dbf5d2a79668118644d26d47.png

43993f1ff6331798b5b21eabac8e9865.png

或者禁用8005端口

7.分离tomcat和项目用户

为了防止 Tomcat 被植入 web shell 程序后,可以修改项目文件。因此我们要将 Tomcat 和项目的属主做分离,这样子,即便被搞,他也无法创建和编辑项目文件。

8.在conf/web.xml  添加如下配置

ff1cf0235810b80a258262eb59e882ba.png

9.自定义错误页面

web.xml是在某一个应用下面的,他处理的应当是本应用的404,而http://localhost/访问的是tomcat自已的应用,那么这个web.xml配置就应当在webapp/Root/下面的应用来配了,

Root目录下面放着Tomcat的应用,把里面换成自已的就行了.

在/webapps/ROOT/WEB-INF/web.xml添加

120ee9754eff3233ba8abc8f375292b7.png

在webapps目录下创建error.jsp文件

404 page
 
 

Enumeration attributeNames = request.getAttributeNames();

while (attributeNames.hasMoreElements())

{

String attributeName = attributeNames.nextElement();

Object attribute = request.getAttribute(attributeName);

out.println("request.attribute['" + attributeName + "'] = " + attribute);

}

%>

31f21dbea4f7b28caf1eaeb905493b1c.png

exception.jsp文件

exception page
 
 

response.getWriter().println("Exception: " + exception);

if(exception != null)

{

response.getWriter().println("

");

exception.printStackTrace(response.getWriter());

response.getWriter().println("

");

}

respons

e.getWriter().println("


");

%>

在浏览器测试自定义的错误页面:

11f7aba5065548ea01427a02fee8cdfb.png

3250998eb382348d78cf8b16da3ab07d.png

定义会话超时时间及禁止列目录

0bef3926b67594c1537d8d82fd7ff3a7.png

好了这篇文章就介绍到这了,希望能帮助到你。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值