gpt4 book ai didi

java - Servlet 方法不重定向页面

转载 作者:行者123 更新时间:2023-12-02 11:57:35 25 4
gpt4 key购买 nike

我正在创建一个应用程序,我从用户登录开始,我尝试当他们登录页面重定向到另一个页面时,我尝试使用response.sendRedirect 来执行此操作,但这不起作用,它只是显示控制台日志中的 html 代码。我想知道为什么会发生这种情况

登录类post方法:

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=UTF-8");
PrintWriter out = response.getWriter();
HttpSession session = request.getSession();
JSONObject reqBody = new JSONObject(request.getReader().lines().collect(Collectors.joining(System.lineSeparator())));
JSONObject json = new JSONObject();
Database db = new Database("postgresql", "localhost", "5432", "Reader", "postgres", "kush");
if(session.isNew()) {
if(db.checkUser(reqBody.getString("email"), reqBody.getString("pass")) == true) {
json.put("status", "new session, welcome back");
storeValue(reqBody.getString("email"), reqBody.getString("pass"), reqBody.getBoolean("admin"), session);
response.sendRedirect(request.getContextPath() + "/loggedin.html");
} else {
json.put("status", "username or password incorrect");
session.invalidate();
}
} else {
json.put("status", "session updated");
storeValue(reqBody.getString("email"), reqBody.getString("pass"), reqBody.getBoolean("admin"), session);
}
out.println(json.toString());
}

我尝试过使用

response.sendRedirect("loggedin.html");

response.setStatus(response.SC_MOVED_TEMPORARILY);
response.setHeader("Location", "loggedin.html");

ServletContext sc = getServletContext();
sc.getRequestDispatcher("/loggedin.html").forward(request, response);

我的 web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app>

<servlet>
<servlet-name>Login</servlet-name>
<servlet-class>Login</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>Login</servlet-name>
<url-pattern>/Login</url-pattern>
</servlet-mapping>

<servlet>
<servlet-name>page</servlet-name>
<jsp-file>/loggedin.html</jsp-file>
</servlet>
<servlet-mapping>
<servlet-name>page</servlet-name>
<url-pattern>/Reader/loggedin.html</url-pattern>
</servlet-mapping>
</web-app>

我使用 xml http 请求调用 get 和 post 方法

登录.html

<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Login successful</title>
</head>
<body>
<h1>Welcome</h1>
</body>
</html>

index.html:

<!DOCTYPE html>
<html>
<head>
<meta charset="ISO-8859-1">
<title>Reader | Project</title>
<script src = 'js/XHR.js'><</script>
</head>

<p><input id="email" type="text" name="em"></p>
<p><input id="password" type="password" name="pw"></p>
<p>
<p> Admin user?
<select id="admin">
<option value="true">Si</option>
<option value="false">No</option>
</select>
</p>

<button onclick='sendValue()'>Send</button>
<button onclick='getValue()'>Get</button>
<button onclick='deleteValue()'>Delete</button>
<body>
<script>
var wrapper = new XHR();
function element(id) {
return document.getElementById(id);
}

function sendValue() {
var email = element('email').value;
var password = element('password').value;
var is_admin = element('admin').value;
wrapper.post('./Login',{email:email, pass:password, admin:is_admin},{'Content-Type':'application/x-www-form-urlencoded'})

}

function getValue() {
wrapper.get('./Login',{},{'Content-Type':'application/x-www-form-urlencoded'})
}

function deleteValue() {
wrapper.get('./Logout',{},{'Content-Type':'application/x-www-form-urlencoded'})
}

</script>
</body>
</html>

XHR.js

function XHR() {

var jsonToParams = json => {
var res = "";
for (var attr in json) {
if (res === "") {
res = attr + "=" + json[attr];
} else {
res += "&" + attr + "=" + json[attr];
}
}
return res;
};

this.send = function(method, url, params, headers) {
return new Promise(function(fullfill, reject) {
var wrapper = new XMLHttpRequest();
wrapper.open(method, url);
wrapper.onload = function() {
if (this.status == 200) {
fullfill(wrapper.responseText);
} else {
reject({ status: this.status, statusText: wrapper.statusText });
}
};

for (var header in headers) {
wrapper.setRequestHeader(header, headers[header]);
}

if (method === 'POST') {
wrapper.send(JSON.stringify(params));
} else {
wrapper.send();
}
});
}

this.get = function(url, params, headers) {
params=typeof params==="string" ? params : jsonToParams(params);
url += "?" + params;
this.send('GET', url, params, headers)
.then(function(data) {
console.log(data)
})
.catch(function(error) {
console.log(error);
})
}

this.post = function(url, params, headers) {
this.send('POST', url, params, headers)
.then(function(data) {
console.log(data);
})
.catch(function(error) {
console.log(error);
})
}
}

最佳答案

这可能对你有用:)

<form action="loggedin.html">
<input type="submit"/>
</form>

关于java - Servlet 方法不重定向页面,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47478858/

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