当前位置: 首页 > 面试题库 >

我可以关闭web.xml中的HttpSession吗?

鲜于煜祺
2023-03-14
问题内容

我想完全消除HttpSession-
我可以在web.xml中这样做吗?我敢肯定,有一些特定于容器的方法可以做到这一点(当我进行Google搜索时,搜索结果会很拥挤)。

PS这是个坏主意吗?在我真正需要它们之前,我宁愿完全禁用它们。


问题答案:

我想彻底消除HttpSession

您不能完全禁用它。您需要做的就是 不要
在Web应用程序的代码中任何地方request.getSession()request.getSession(true)任何地方都得到它的句柄,并确保您的JSP不会通过设置隐式地做到这一点<%@page session="false"%>

如果您主要关心的是实际上禁用在幕后使用的cookie HttpSession,那么您只能在Java EE 5 / Servlet
2.5中在特定于服务器的webapp配置中这样做。例如在Tomcat中,您可以将cookies属性设置为falsein <Context>元素。

<Context cookies="false">

另请参阅此Tomcat特定文档。这样,只有在您出于某种原因从请求中获取会话时,该会话才不会保留在后续的未进行URL重写的请求中。毕竟,如果您不需要它,
只是 不要抓住它,那么它将根本不会被创建/保留。

或者,如果您已经在使用Java EE 6 / Servlet 3.0或更高版本,并且确实想通过进行操作web.xml,则可以按如下所示使用new
<cookie-config>元素web.xml将最大使用期限归零:

<session-config>
    <session-timeout>1</session-timeout>
    <cookie-config>
        <max-age>0</max-age>
    </cookie-config>
</session-config>

如果你想硬编码在你的web应用,这样getSession()永远不会返回HttpSession(或“空”
HttpSession),那么你就需要上创建一个过滤器监听url- pattern/*取代了HttpServletRequestHttpServletRequestWrapper实现其所有收益getSession()的方法null,或虚拟定制HttpSession什么都不做甚至抛出的实现UnsupportedOperationException

@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
    chain.doFilter(new HttpServletRequestWrapper((HttpServletRequest) request) {
        @Override
        public HttpSession getSession() {
            return null;
        }
        @Override
        public HttpSession getSession(boolean create) {
            return null;
        }
    }, response);
}

PS这是个坏主意吗? 在我真正需要它们之前,我宁愿完全禁用它们。

如果您不需要它们,那就不要使用它们。就这样。真的:)



 类似资料:
  • 问题内容: 我想完全消除HttpSession-我可以在web.xml中这样做吗?我敢肯定,有一些特定于容器的方法可以做到这一点(当我进行Google搜索时,这会挤满搜索结果)。 PS这是个坏主意吗?在我真正需要它们之前,我宁愿完全禁用它们。 问题答案: 我想彻底消除HttpSession 您不能完全禁用它。您所需要做的就是不要在Web应用程序的代码中任何地方)或任何地方获取它的句柄,并确保您的J

  • 问题内容: 我当时正在帮助一个朋友编写一些Java代码,而他们对Java并不了解很多。因此,我给他写了一些辅助函数,以轻松地完成在他眼中有些古怪的事情。其中一个函数是将String写入的函数。看一看: 现在,您可以轻松地以各种方式使用它,在任何地方书写。例如,您可以这样做: 这样做后,我发现之后不再向外壳写入任何内容。所以我认为也许也会自动关闭,我想知道如何重新激活它,以便在该功能再次完成后可以使

  • 问题内容: 更新: 问题后的解决方案。 通常,同步是在JVM中序列化并行请求,例如 在查看Web应用程序时,“ JVM全局”范围内的某些同步可能正在成为性能瓶颈,仅在用户HttpSession范围内的同步才有意义。 以下代码是否可能?我怀疑在会话对象上进行同步是个好主意,但是听到您的想法会很有趣。 关键问题: 对于所有处理来自同一用户的请求的线程 ,是否保证会话对象是 同一实例 ? 总结答案/解决

  • 问题内容: 我在学元素,画线等。 我注意到我的对角线是抗锯齿的。我希望自己的工作看上去比较粗糙-有什么办法可以关闭此功能? 问题答案: 对于图像,现在有。 但是,没有任何东西可以显式控制线条绘制。您可能需要使用和绘制自己的线条困难的方式。

  • 我想做的是将这个JerseyClientConfig应用为所有创建的客户端的默认配置(不想每次构造客户端istance时都创建配置实例)。 是否可以在web.xml中设置它,就像我对服务器配置那样? 我在正式文档中没有找到任何关于它的信息。

  • 问题内容: 我想让我的方法的参数引用一个闭包属性,它们都存在于同一作用域中。例如, 但是,这显示错误:。 当然,我可以定义一个新的单独方法,并将闭包的实现移到该方法上,但是对于这样小的实现,我想保持节俭。 是否可以为参数设置闭包? 问题答案: 就像@ gnasher729指出的那样,这是不可能的,因为选择器只是方法的名称,而不是方法本身。在一般情况下,我会在这里使用,但是在这种特殊情况下,更好的工