Jsp 为什么我的登录没有失败
这是我的servlet,用于登录我的JSP页面。当我输入正确的凭据时,它工作正常。如果我只输入用户名和空密码,它将转到else(invalid.jsp)。但我的问题是,当我没有为用户名和密码添加任何内容,或者只是将用户名留空时,我的servlet失败,网页什么也不显示,只是留空。为什么呢?请解释一下,我已经做了实验并尽了最大努力,但仍然没有成功Jsp 为什么我的登录没有失败,jsp,servlets,Jsp,Servlets,这是我的servlet,用于登录我的JSP页面。当我输入正确的凭据时,它工作正常。如果我只输入用户名和空密码,它将转到else(invalid.jsp)。但我的问题是,当我没有为用户名和密码添加任何内容,或者只是将用户名留空时,我的servlet失败,网页什么也不显示,只是留空。为什么呢?请解释一下,我已经做了实验并尽了最大努力,但仍然没有成功 package servlet; import bean.User; import java.io.IOException; import java.
package servlet;
import bean.User;
import java.io.IOException;
import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
public class Login extends HttpServlet {
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
try {
request.getSession().invalidate();
String username = request.getParameter("user");
String password = request.getParameter("pass");
String fname, lname, idaccount, cat;
Connection conn = (Connection) this.getServletContext().getAttribute("conn");
String query = "SELECT username, password, user_type, firstname, lastname, idaccount FROM account WHERE username = ?";
PreparedStatement ps = conn.prepareStatement(query);
ps.setString(1, username);
ResultSet rs = ps.executeQuery();
while(rs.next()){
cat = rs.getString(3);
fname = rs.getString(4);
lname = rs.getString(5);
idaccount = rs.getString(6);
// for testing int test = username.length();
if (username.equals(rs.getString(1)) && (password.equals(rs.getString(2)))) {
User users = new User();
users.setUsername(username);
users.setPassword(password);
users.setCat(cat);
users.setIdaccount(idaccount);
users.setFname(fname);
users.setLname(lname);
HttpSession session = request.getSession();
session.setAttribute("user", users);
// System.out.println(test);
response.sendRedirect("healthlink/home.jsp");
} else {
response.sendRedirect("invalid.jsp");
}
}
rs.close();
ps.close();
} catch (Exception e) {
response.sendError(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
}
}
}
这是意料之中的。如果用户名为null,则查询不会返回任何内容,因此
rs.next()
始终为false,并且您的方法不会执行任何操作
while循环实际上应该是一个if
(因为不应该有多个用户具有相同的用户名),并且应该有一个else
子句处理不存在的用户名:
ResultSet rs = ps.executeQuery();
if (rs.next()) {
// there is a user with this name. Check its password
}
else {
// there is no user with this name: send back an error response here
}
我的意思是我的标题为什么我的登录失败…如果可能的话,你能发布一些代码吗?我正在尝试这样做,但是servlet仍然失败,我仍然想创建bean…哦,别担心,先生。。。我得到了它。。谢谢你。。。也许我只是累了。。。再次感谢你