gpt4 book ai didi

Java RMI 不适用于多个服务器 - 安全

转载 作者:行者123 更新时间:2023-12-01 13:21:45 24 4
gpt4 key购买 nike

我在 ubuntu 服务器上使用 RMI 开发了 java 代码。当 RMI 客户端和服务器位于同一台计算机上时,它可以很好地工作。当我使用两台机器(一台作为服务器,另一台作为客户端 - 都是 ubuntu)时,它给我“RMI 连接拒绝异常”。为了解决这个问题,我尝试使用下面的代码覆盖 java 策略文件:

System.setSecurityManager(new RMISecurityManager());
System.setProperty("java.security.policy","file:///home/{local path}/client.policy");

我也在服务器端使用了类似的代码。

客户端和服务器策略文件的内容如下:

grant codebase  {
permission java.security.AllPermission;
};

现在我在客户端的“System.setProperty(....)”行上遇到以下异常。

java.security.AccessControlException: access denied (java.util.PropertyPermission java.security.policy write)
at java.security.AccessControlContext.checkPermission(AccessControlContext.java:374)
at java.security.AccessController.checkPermission(AccessController.java:546)
at java.lang.SecurityManager.checkPermission(SecurityManager.java:532)
at java.lang.System.setProperty(System.java:725)
at ParaselectionServlet.doPost(ParaselectionServlet.java:106)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:641)
at javax.servlet.http.HttpServlet.service(HttpServlet.java:722)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:304)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:224)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:185)
at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:151)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:100)
at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:405)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:269)
at org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:515)
at org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:302)
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
at java.lang.Thread.run(Thread.java:662)

我不是 java 或 ubuntu 方面的专家,但是有人可以帮助我解决上述问题吗?

-拉什米

最佳答案

您需要在安全管理员之前设置安全策略。

关于Java RMI 不适用于多个服务器 - 安全,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21975855/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com