注销防止后退按钮 java 不起作用我已经尝试了一整天但仍然无法得到结果,我错过了什么?
这是我的 Java 类
package login.example;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.persistence.Id;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
@WebServlet("/UserOne")
public class UserOne extends HttpServlet {
private static final long serialVersionUID = -7250065889869767422L;
@Id
private long id;
private String name;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public void setId(long id) {
this.id = id;
}
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
PrintWriter out = response.getWriter();
response.setContentType("text/html");
long id = Long.parseLong(request.getParameter("id"));
String name = request.getParameter("name");
// String userRePass = request.getParameter("userRePassWord");
try {
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/any", "root", "jaygurudev1@");
PreparedStatement ps = con.prepareStatement("Select id,name from user where id=? and name=?");
ps.setLong(1, id);
ps.setString(2, name);
ResultSet rs = ps.executeQuery();
// HttpServletRequest request = null;
if (rs.next()) {
HttpSession session = request.getSession(true);
session.setAttribute("id", id);
session.setAttribute("name", name);
ServletContext context = request.getServletContext();
response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
response.setHeader("Cache-control", "no-store");
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expire", 0);
RequestDispatcher dispatcher = context.getRequestDispatcher("/admin.jsp");
dispatcher.forward(request, response);
// or you can write whole thing in one line as ........
// getServletContext().getRequestDispatcher("/success").forward(request,
// response);
} else {
// request.setAttribute("wrongUser", userName);
ServletContext context = request.getServletContext();
response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
response.setHeader("Cache-control", "no-store");
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expire", 0);
RequestDispatcher dispatcher = context.getRequestDispatcher("/login.jsp");
dispatcher.forward(request, response);
// or you can write whole thing in one line as ........
// getServletContext().getRequestDispatcher("/fail").forward(request,
// response);
}
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
这是我的 login.jsp 这是
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<div style="text-align: center">
<h1>admin login</h1>
<%
response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expires", 0); // Proxies.
%>
<form action="/UserOne" method="get">
<label for="id">Id</label> <input name="id" /> <label for="name">Name</label>
<input type="text" name="name" />
<button type="submit">Login</button>
</form>
</div>
</body>
</html>
我的 admin.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.io.IOException"%>
<%@page import="java.io.PrintWriter"%>
<!DOCTYPE html>
<html>
<head>
<style>
body {
background-image: url(/images/admin.jpg);
background-repeat: repeat;
background-size: 640px 640px;
}
</style>
</head>
<body>
<%
response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
response.setHeader("Cache-control", "no-store");
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expire", 0);
%>
<a href="/userone">get all users</a>
<h3>view user</h3>
getMobileInfo
<a href="/indexone">get all mobile details</a>
<form action="/LogoutServlet" method="get">
<input type="submit" value="logout">
</form>
</body>
</html>
这是注销 servlet
package login.example;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
@WebServlet(name = "LogoutServlet", urlPatterns = { "/LogoutServlet" })
public class LogoutServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
public LogoutServlet() {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
PrintWriter out = response.getWriter();
response.setContentType("text/html");
HttpSession session = request.getSession();
session.removeAttribute("id");
session.removeAttribute("name");
request.getSession(false);
session.invalidate();
out.println("Thank you,you are successfully logged out");
// response.setHeader("Cache-Control", "no-cache,no-store,must-revalidate");
HttpServletResponse httpResponse = (HttpServletResponse) response;
httpResponse.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
httpResponse.setHeader("Pragma", "no-cache"); // HTTP 1.0
httpResponse.setDateHeader("Expires", 0); // Proxies.
// request.getRequestDispatcher("login.jsp").include(request, response);
response.sendRedirect("login.jsp");
}
}
我应该添加或删除什么才能获得所需的输出,例如注销后不显示上一页?我的代码有什么问题吗?我是否需要任何依赖或其他东西来实现这一目标?怎么解决这个问题呢?
我的网址就像 http://localhost:8080/home.html
然后http://localhost:8080/login.jsp?
和http://localhost:8080/UserOne?id=1&name=ritu
This is my Java class
package login.example;
import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import javax.persistence.Id;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
@WebServlet("/UserOne")
public class UserOne extends HttpServlet {
private static final long serialVersionUID = -7250065889869767422L;
@Id
private long id;
private String name;
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public void setId(long id) {
this.id = id;
}
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
PrintWriter out = response.getWriter();
response.setContentType("text/html");
long id = Long.parseLong(request.getParameter("id"));
String name = request.getParameter("name");
// String userRePass = request.getParameter("userRePassWord");
try {
Class.forName("com.mysql.jdbc.Driver");
Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/any", "root", "jaygurudev1@");
PreparedStatement ps = con.prepareStatement("Select id,name from user where id=? and name=?");
ps.setLong(1, id);
ps.setString(2, name);
ResultSet rs = ps.executeQuery();
// HttpServletRequest request = null;
if (rs.next()) {
HttpSession session = request.getSession(true);
session.setAttribute("id", id);
session.setAttribute("name", name);
ServletContext context = request.getServletContext();
response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
response.setHeader("Cache-control", "no-store");
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expire", 0);
RequestDispatcher dispatcher = context.getRequestDispatcher("/admin.jsp");
dispatcher.forward(request, response);
// or you can write whole thing in one line as ........
// getServletContext().getRequestDispatcher("/success").forward(request,
// response);
} else {
// request.setAttribute("wrongUser", userName);
ServletContext context = request.getServletContext();
response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
response.setHeader("Cache-control", "no-store");
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expire", 0);
RequestDispatcher dispatcher = context.getRequestDispatcher("/login.jsp");
dispatcher.forward(request, response);
// or you can write whole thing in one line as ........
// getServletContext().getRequestDispatcher("/fail").forward(request,
// response);
}
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
This is my login.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Insert title here</title>
</head>
<body>
<div style="text-align: center">
<h1>admin login</h1>
<%
response.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expires", 0); // Proxies.
%>
<form action="/UserOne" method="get">
<label for="id">Id</label> <input name="id" /> <label for="name">Name</label>
<input type="text" name="name" />
<button type="submit">Login</button>
</form>
</div>
</body>
</html>
This is my admin.jsp
<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
pageEncoding="ISO-8859-1"%>
<%@page import="java.sql.DriverManager"%>
<%@page import="java.sql.ResultSet"%>
<%@page import="java.sql.Statement"%>
<%@page import="java.sql.Connection"%>
<%@page import="java.io.IOException"%>
<%@page import="java.io.PrintWriter"%>
<!DOCTYPE html>
<html>
<head>
<style>
body {
background-image: url(/images/admin.jpg);
background-repeat: repeat;
background-size: 640px 640px;
}
</style>
</head>
<body>
<%
response.setHeader("Cache-control", "no-cache"); // HTTP 1.1
response.setHeader("Cache-control", "no-store");
response.setHeader("Pragma", "no-cache"); // HTTP 1.0
response.setDateHeader("Expire", 0);
%>
<a href="/userone">get all users</a>
<h3>view user</h3>
getMobileInfo
<a href="/indexone">get all mobile details</a>
<form action="/LogoutServlet" method="get">
<input type="submit" value="logout">
</form>
</body>
</html>
This is logout servlet
package login.example;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletContext;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
@WebServlet(name = "LogoutServlet", urlPatterns = { "/LogoutServlet" })
public class LogoutServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
public LogoutServlet() {
}
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws IOException, ServletException {
PrintWriter out = response.getWriter();
response.setContentType("text/html");
HttpSession session = request.getSession();
session.removeAttribute("id");
session.removeAttribute("name");
request.getSession(false);
session.invalidate();
out.println("Thank you,you are successfully logged out");
// response.setHeader("Cache-Control", "no-cache,no-store,must-revalidate");
HttpServletResponse httpResponse = (HttpServletResponse) response;
httpResponse.setHeader("Cache-Control", "no-cache, no-store, must-revalidate"); // HTTP 1.1
httpResponse.setHeader("Pragma", "no-cache"); // HTTP 1.0
httpResponse.setDateHeader("Expires", 0); // Proxies.
// request.getRequestDispatcher("login.jsp").include(request, response);
response.sendRedirect("login.jsp");
}
}
What should I add or remove in order to get desired output such as it does not show previous page after I logged out? What is wrong with my code? Should I need any dependency or anything else to achieve this? How to solve this?
my url is like http://localhost:8080/home.html
then http://localhost:8080/login.jsp?
and http://localhost:8080/UserOne?id=1&name=ritu
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
当您单击后退按钮时,URL (
/UserOne?id=1&name=ritu
) 会提交旧的 ID 和名称,使其能够再次登录该页面。在 post 参数中发送登录凭据以解决问题。即:在login.jsp中,提交方法应该是post
When you click back button the the url (
/UserOne?id=1&name=ritu
) submits the old id and name making it to login to the page again. Send the login credentials in post parameter to fix the issue.ie: In login.jsp the submit method should be post
我在每个我想要作为安全页面的jsp页面中添加了以下代码,
无需在springboot中编写以下代码,因为springboot自动添加以下代码
i have added below code in every jsp page which i want as secure page
no need to write this below code in springboot,as springboot automatically add below code