0

ユーザー名とパスワードを取得し、mysql データベース テーブルをチェックする単純なログイン フォームを作成しようとしました。申し訳ありませんが、私はこの Java の初心者です...一致する場合は、ホームページにリダイレクトされますが、実行できません。誰かがこれで私を助けてくれませんか.迅速な返信をありがとう.Tomcatエラーが発生していますここに投稿しています....助けてください....

SerExam.java

 package myPack;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.*;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class SerExam extends HttpServlet
{
      Connection con;
      PreparedStatement ps;
      ResultSet rs;
      public void init(ServletConfig config)throws ServletException
      {
            try
               {
                        Class.forName("oracle.jdbc.driver.OracleDriver");
                        con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe","system","tiger");
               }
                  catch (ClassNotFoundException e)
                     {
                        System.out.println(e);
                     }
                  catch (SQLException e)
                     {
                        System.out.println(e);
                     }
      }
      protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
      {
            doPost(request, response);
            {
                response.setContentType("text/html");
                PrintWriter pw=response.getWriter();
                String username=request.getParameter("username");
                String password=request.getParameter("password");
                pw.println("<html><body>");
                try
                {
                      ps=con.prepareStatement("select * from loginvalidation where username=? and password=?");
                      ps.setString(1, username);
                      ps.setString(2, password);
                      rs=ps.executeQuery();
                      if(rs.next())
                      {
                            pw.println("<h3>welcome " +" " + username +"</h3>");
                            RequestDispatcher rd1=request.getRequestDispatcher("./home.html");
                            rd1.include(request,response);
                            //or
                            //response.sendRedirect("./home.html");
                            pw.println("<form method=\"post\" action=\"Login.html\">");
                            pw.println("<input type=\"submit\" name=\"logout\" " + "value=\"Logout\">");
                            pw.println("</form>");

                      }
                      else
                      {
                            pw.println("<center><h3>invalid username/password Enter Correct username/password</h3></center>");
                            RequestDispatcher rd2=request.getRequestDispatcher("./Login.html");
                            rd2.include(request,response);
                            //or
                            //response.sendRedirect("./Login.html");
                      }
                }
                catch (SQLException e)



    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{
    }
    }

login.html

<!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>Login page</title>
</head>
<body>
<center>
<form action="./firstserv" method="post">
username &nbsp;&nbsp;&nbsp;
<input type="text" name="username" />
<br>
<br>
password &nbsp;&nbsp;&nbsp;
<input type="password" name="password"></input><br><br>
&nbsp;&nbsp;&nbsp;
<input type="submit" value="login"></input>
&nbsp;&nbsp;&nbsp;
<a href="./reg.html">new user</a>
</form>
</center>
</body>
</html>

reg.html

<!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>Registration Form</title>
</head>
<body>
registration page under construction...............

</body>
</html>

web.xml

<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
    <display-name>UserDemo</display-name>
    <servlet>
        <description>
        </description>
        <display-name>SerExam</display-name>
        <servlet-name>SerExam</servlet-name>
        <servlet-class>
        myPack.SerExam</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>SerExam</servlet-name>
        <url-pattern>/home.html</url-pattern>
    </servlet-mapping>
    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
        <welcome-file>index.jsp</welcome-file>
        <welcome-file>default.html</welcome-file>
        <welcome-file>default.htm</welcome-file>
        <welcome-file>default.jsp</welcome-file>
    </welcome-file-list>
</web-app>
4

2 に答える 2

0

サーブレット マッピング タグを次のように変更します。

<servlet-mapping>
    <servlet-name>SerExam</servlet-name>
    <url-pattern>/MyServlet</url-pattern>
</servlet-mapping>

次に、上記のサーブレット マッピングに従ってMyServlet、フォーム パラメータを含むリクエストがサーブレットに送信されるように、フォームのアクション パラメータとして使用できます。SerExam

<form action="MyServlet" method="post">

フォーム内でメソッドを使用してPOSTいるため、サーブレットdoPostメソッドが呼び出され、メソッド内にコードを記述していないことがコードからわかりますdoPost

それを削除します(これはメソッドdoPost(request,response);内の最初の行です。doGet

したがって、サーブレット コードを次のように変更します。

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException
{
       //your existing code inside doGet with that doPost call removed   
}

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException{

     doGet(request,response);
}

それでも、コードがうまく機能する前にやらなければならないことがたくさんあります。

したがって、基本的な理解を得るために、サーブレット wikiを参照してください。

于 2012-11-28T09:02:10.360 に答える
0

サーブレットは次の場所にマップされてい/home.htmlます:

<servlet-mapping>
    <servlet-name>SerExam</servlet-name>
    <url-pattern>/home.html</url-pattern>
</servlet-mapping>

あなたがアクセスしている間firstserv

<form action="./firstserv" method="post">

サイドノート:

パスワードをプレーンテキストでデータベースに保存しないでください。

ps=con.prepareStatement("select * from loginvalidation where username=? and password=?");
ps.setString(1, username);
ps.setString(2, password);
于 2012-11-28T08:01:59.757 に答える