gpt4 book ai didi

java - 在 servlet 中禁用浏览器缓存

转载 作者:行者123 更新时间:2023-12-01 12:59:00 29 4
gpt4 key购买 nike

我知道这个问题之前已被问过并回答过多次,但该解决方案似乎在我的 WebApp 中不起作用。

此 servlet 处理一个 JSP 页面,用户可以在该页面上(虚拟地)购买积分。在 get-方法中,servlet 从数据库请求用户当前的积分,并将其显示在 JSP 页面上。然后用户可以选择他想要购买的积分数量。

post 方法检查用户选择了哪个值并更新该用户数据库中的值。

购买新积分后,用户会觉得他的积分没有更新,因为浏览器 (Google Chrome) 缓存了旧版本的页面。只有一段时间后,用户才能看到他更新的积分。

这是我的 servlet:

<!-- language: lang-java -->

package Controller.Servlets;

import Controller.ListenerHelper;
import Model.Listener;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

/**
*
* @author Jens
*/
public class CreditServlet extends HttpServlet {

private Listener listener;
private int credits;

@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
HttpSession session = request.getSession();

ListenerHelper listenerHelper = new ListenerHelper();

listener = (Listener) session.getAttribute("Listener");

credits = listener.getCredits();

request.setAttribute("credits", credits);

request.getRequestDispatcher("/listener/credits.jsp").forward(request, response);
}

@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

HttpSession session = request.getSession();

listener = (Listener) session.getAttribute("Listener");

String choice = request.getParameter("plan");

ListenerHelper listenerHelper = new ListenerHelper();

int creditsToAdd=0;

switch (choice){
case "plan_10":
creditsToAdd=100;
break;
case "plan_15":
creditsToAdd=150;
break;
case "plan_25":
creditsToAdd=250;
break;
case "plan_50":
creditsToAdd=500;
break;
}

try{
listenerHelper.updateCredits(listener.getUserID(), creditsToAdd, "add");
} catch(Exception e){
request.setAttribute("error", e.getMessage());
}

httpResponse.setHeader("Cache-Control", "no-cache, no-store, must-revalidate");
httpResponse.setHeader("Pragma", "no-cache"); // HTTP 1.0
httpResponse.setDateHeader("Expires", 0); // Proxies.

response.sendRedirect("store.jsp?success=login");

}
}

在 JSP 页面的顶部我添加了这些行:

<%
response.setHeader("Cache-Control","no-store"); //HTTP 1.1
response.setHeader("Pragma","no-cache"); //HTTP 1.0
response.setDateHeader ("Expires", 0); //prevents caching at the proxy server
%>

更新由于我无法回答我自己的问题,我将更新我的问题。经过更多调试后我发现不是浏览器缓存旧结果而是数据库仅在重新启动网络应用程序后更新结果。很抱歉在这件事上浪费了您的时间。我对编程还是新手。我将尝试找出数据库为何如此运行并发布我的答案。感谢您的帮助。

最佳答案

请注意,在 servlet 中,在重定向之前,您将进行以下设置:

response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate");

然后在重定向后的 JSP 中:

response.setHeader("Cache-Control","no-store"); //HTTP 1.1

您为什么放弃使用更强大的 header ? “无缓存、无存储、必须重新验证”发生了什么?

您在重定向之前设置的内容就会消失。就好像你根本没有做过一样。只有您在重定向后设置的内容才会发送到客户端。因此,您需要像在 servlet 中那样在 JSP 中放置更一致的 header 。

关于java - 在 servlet 中禁用浏览器缓存,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23662675/

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