4

ユーザー名とパスワードを検証するためのサンプルログインページを開発しました。ユーザーが正しい資格情報を指定すると、ページは他のページに移動します。それ以外の場合は、servletから同じログインページにメッセージを返します。

ここにサンプルを同封しcodeました:

FirstJSP.jsp

<%@ page language="java" contentType="text/html; charset=ISO-8859-1"
    pageEncoding="ISO-8859-1"%>`
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org   /TR/html4/loose.dtd">`
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
        <title>Insert title here</title>`
    </head>
    <body>
        <form action="Login" method="post">
            <input type="text" name="Name"/><br>
            <input type="password" name=Pass><br><br><br>
            <input type="submit" value="submit"/><br>
            <%if(request.getAttribute("message")!=(""))
            out.println(request.getAttribute("message"));
            else
            out.println("");%>
            <h1>Hi This is JSP sample code </h1>
            <font color="blue" size="25">
            <marquee>Please login to Work with JSP</marquee></font>
            <%java.text.DateFormat df = new java.text.SimpleDateFormat("MM/dd/yyyy"); %>
            <h1>Current Date: <%= df.format(new java.util.Date()) %> </h1>
        </form>
    </body>
</html>

そして、servletコード、Login.java:

package com.controller;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class Login extends HttpServlet {
    private static final long serialVersionUID = 1L;
    
    public Login() {
        super();
    }
    
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String username = request.getParameter("Name");
        String password = request.getParameter("Pass");
        response.setContentType("text/html");
        if(username.equals("sugan") && password.equals("raj")) {
            response.getWriter().println("<html><body><Marquee>Welcome to JSP!!!</marquee></body></html>");                
        } 
        else {                
            String message = "OOps!!! Invalid Username/Password";
            request.setAttribute("message", message);
            request.getRequestDispatcher("/FirstJSP.jsp").forward(request, response);                
        }
    }
}

正常に動作しますが、ログインページをロードすると、自動的にが表示されますNull。次に、ユーザーが間違った資格情報を指定すると、実際のメッセージが表示されます。Null実行時にメッセージを無効にするにはどうすればよいですか?

4

3 に答える 3

4

を使用してメッセージを空の文字列と比較しています==

まず、メッセージが null (空の文字列ではない) になるため、比較が間違っています。

equals()第二に、 Objects は ではなくと比較する必要があるため、間違ってい==ます。

第 3 に、JSP でスクリプトレットを使用するのを避け、代わりに JSP EL、JSTL、およびその他のカスタム タグを使用する必要があるため、これは間違っています。

<c:id test="${!empty message}">
    <c:out value="${message}"/>
</c:if>
于 2012-06-11T13:42:32.330 に答える
0

doGet() メソッドを実際に使用していません。ページを開くと、POST ではなく GET リクエストが発行されます。

代わりに doPost() を service() に変更してみてください...その後、同じメソッドを使用して GET および POST リクエストを処理しています。

...

于 2012-06-11T13:39:16.133 に答える