gpt4 book ai didi

java - jsp中登录后显示用户名

转载 作者:太空宇宙 更新时间:2023-11-04 07:03:21 25 4
gpt4 key购买 nike

我有一个登录页面,它通过 servlet 连接到数据库进行验证。在成功登录后的 servlet 中,我使用请求调度程序来登录-success.html

这是 servlet 代码:

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.ResultSet;
import java.sql.SQLException;

import javax.servlet.RequestDispatcher;
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;

import com.mysql.jdbc.Connection;
import com.mysql.jdbc.Statement;

/**
* Servlet implementation class DoLogin
*/
@WebServlet("/DoLogin")
public class DoLogin extends HttpServlet {
private static final long serialVersionUID = 1L;

/**
* @see HttpServlet#HttpServlet()
*/
public DoLogin() {
super();
// TODO Auto-generated constructor stub
}

/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
PrintWriter out = response.getWriter();
response.setContentType("text/html");
out.println("<html>");

//Browser Back Button Disable Script After Logout
out.println("<script>");
out.println("javascript:window.history.forward(1)");
out.println("</script>");
out.println("<body style=\"background-color : rgb(41,85,153);\">");


//Invalidate The Session.
HttpSession session = request.getSession(false);
try
{
session.invalidate();
out.println("<h3><font family=\"Times New Roman\" color=\"white\">Successfully Logout</font></h3>");

out.println("<form action=\"/CloudMoV/login.html\" method=\"post\">");
out.println("<br />");
out.println("<input type=\"submit\" alt=\"submit\" value=\"Login Again!\"/>");
out.println("</form>");

out.println("</body>");
out.println("</html>");
}

catch (Exception ee)
{
out.println(ee);
}

}

/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
response.setHeader("Cache-Control", "private, no-store, no-cache, must-revalidate");
response.setContentType("text/html");
PrintWriter out = response.getWriter();
// out.println("<html>");
// out.println("<head>");
// out.println("<title>");
// out.println("<html>");
// out.println("</title>");
// out.println("</head>");
// out.println("<body style=\"background-color : black;\">");
// connecting to database

Connection con = null;
Statement stmt = null;
ResultSet res = null;

//variable for checking the values true and false.
boolean success=false;

//creating session
HttpSession session = request.getSession(true);

try{
DbConnection db = new DbConnection();
con = db.connDb();

//Receiving Values From HTML FORM
String thisname=request.getParameter("username");
String thispwd=request.getParameter("password");
stmt = (Statement) con.createStatement();

//Query for selecting user name and password from database.
String q = "select username, password from register where username='"+thisname+"'";
res = stmt.executeQuery(q);

while(res.next())
{
if ((thisname.equals(res.getString("username"))) && (thispwd.equals(res.getString("password"))))
{
// out.println("<br /><br /><h3><font family=\"Times New Roman\" color=\"white\">You're successfully logged in. <br />Welcome "+res.getString("username")+"</font></h3>");

success = true;
}


}

}

catch (SQLException e)
{
throw new ServletException("Servlet Could not display records.", e);
}



catch (Exception e)
{
throw new ServletException("Exception.", e);
}

// if(success==true)
// {
// out.println("<font color=\"white\">session Id: " + session.getId() + "</font><br><br>");
// session.setAttribute("username", request.getParameter("username"));
//
// //Logout Button
// out.println("<form onclick=\"doGet("+request+","+ response+")\" >");
// out.println("<input type=\"submit\" value=\"logout\">");
// out.println("</form>");
// }
if(success==true)
{
session.setAttribute("username", request.getParameter("username"));
RequestDispatcher rd = request.getRequestDispatcher("/login-success.html");
rd.forward(request, response);
}

if(success==false)
{
// out.println("<br /><h3 style=\"text-align:center;color:#FFFFFF;margin-top:150px\">Invalid User Name or Password</h3>");
// out.println("<br /><a href=\"login.html\"><h3 style=\"text-align:center;color:#FFFFFF;text-decoration:underline\">Go Back</h3></a>");
session.invalidate();
RequestDispatcher rd = request.getRequestDispatcher("/login.html");
rd.forward(request, response);

}
//
// out.println("</body>");
// out.println("</html>");



}

}

在登录成功时我想显示用户名。我该怎么做?我相信我应该首先将login-success.html更改为login-success.jsp

最佳答案

您正在将用户名值设置为 session 属性“username”,以便您可以使用此 EL 表达式 ${sessionScope.username}在你的jsp中。您应该在 jSTL 标记中使用它

关于java - jsp中登录后显示用户名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21780053/

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