嵌入式Tomcat强化-如何在Spring引导中更改/覆盖广告服务器信息?

如何解决嵌入式Tomcat强化-如何在Spring引导中更改/覆盖广告服务器信息?

我一直在研究如何在嵌入式tomcat上进行“ tomcat强化”,但我找不到改变这3种Catalina服务器信息属性方法server.infoserver.built,{{1 }}

是否有办法在spring application.property文件中更改这3个属性?还是通过其他方式?

下面的配置是专门针对ServerInfo.properties而不是嵌入式tomcat强化tomcat服务器的指南

理论上:
更改server.info属性可能会使操作更困难 攻击者确定哪些漏洞影响服务器 平台。

所需的配置:

执行以下更改服务器 客户端连接到tomcat时显示的平台字符串 服务器。

  1. 从catalina.jar文件提取ServerInfo.properties文件:$ cd $ CATALINA_HOME / lib $ jar xf catalina.jar org / apache / catalina / util / ServerInfo.properties
  2. 导航到已创建的util目录cd org / apache / Catalina / util
  3. 在编辑器中打开ServerInfo.properties
  4. 更新ServerInfo.properties文件中的server.info属性。 server.info =
  5. 使用修改后的ServerInfo.properties文件更新catalina.jar。 $ jar uf catalina.jar org / apache / catalina / util / ServerInfo.properties

更新:

我尝试通过使用修改后的ServerInfo.properties覆盖tomcat-embed-core-9.0.36来修改应用程序胖子。但是当我通过Java启动应用程序时,出现了此错误

原因:java.lang.IllegalStateException:无法打开嵌套条目“ BOOT-INF / lib / tomcat-embed-core-9.0.36.jar”。它已被压缩,嵌套的jar文件必须未经压缩而存储。请检查用于创建可执行jar文件的机制 在org.springframework.boot.loader.jar.JarFile.createJarFileFromFileEntry(JarFile.java:283) 在org.springframework.boot.loader.jar.JarFile.createJarFileFromEntry(JarFile.java:265) 在org.springframework.boot.loader.jar.JarFile.getnestedJarFile(JarFile.java:254) ...还有6个

解决方法

提出2种解决方案:

    修补了tomcat-embed-core.jar中的
  1. Fat Jar方法-> ServerInfo.properties,并在构建过程中打包了可执行的fat jar。但是要求修补的tomcat-embed-core.jar必须在repo / artifactory中才能正常工作。

  2. Thin Jar方法->可执行jar与外部库分开,使用spring-boot-thin-layout和spring-boot-thin-maven-plugin(用于构建)。这样可以外部化依赖关系,您可以在其中本地化任何jar文件,而不会破坏可执行的瘦jar。

目前,这是我可以想到的两种在春季启动应用程序中强化嵌入式tomcat的方法。

在有人提出更好的解决方案之前,我会将此标记为答案。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?