Http状态404 - /请求的资源不可用

时间:2014-03-05 18:04:23

标签: java tomcat servlets

我已经使用tomcat服务器为登录页面... am编写了一个servlet程序...我在服务器上运行后得到上述错误... 下面是我的servlet代码。

包演示;

import java.io.IOException;
import java.io.PrintWriter;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

/**
 * Servlet implementation class LoginServlet
 */

public class LoginServlet extends HttpServlet {

    static private String dbUrl="jdbc:mysql://localhost:3306/employee";
    static private String dbUn="root";
    static private String dbPwd="root";
    static private Connection ConObj;
    static private Statement StmtObj;
    static private ResultSet RsObj; 


  public void service(HttpServletRequest request,HttpServletResponse response)throws IOException


  {
      try {
        Class.forName("com.mysql.jdbc.driver");

      ConObj=DriverManager.getConnection(dbUrl, dbUn, dbPwd);
      StmtObj=ConObj.createStatement();
      response.setContentType("text/html");
      PrintWriter out=response.getWriter();
      out.write("<html><body>");
      out.write("<h2>");
      String ActLogName=request.getParameter("Logname");
      String ActPwd=request.getParameter("Pwd");
      String SqlQuery="select * from users where username='"+ActLogName+"' and password='"+ActPwd+"'";
      RsObj=StmtObj.executeQuery(SqlQuery);
      if(RsObj.next()==true)
      {
          String ExpLogName=RsObj.getString("username");
          String ExpPwd=RsObj.getString("password");
          if(ActLogName.equals(ExpLogName)&& ActPwd.equals(ExpPwd))
          {
              out.write("Login Success");
          }
      }
      else
      {
          out.write("Login Failed");
      }
      out.write("</h2>");
      out.write("</body></html>");
      }
      catch (ClassNotFoundException|SQLException exp) {

            exp.printStackTrace();
        }

      finally{
          try {
            RsObj.close();
            StmtObj.close();
            ConObj.close();
        } catch (SQLException e) {

            e.printStackTrace();
        }

      }


  }
}

以下是我的HTML代码

<!DOCTYPE html>
<html>
<head>

<title>login page</title>
</head>
<body>
<form action="http://localhost:8080/FlipKart/loginpage">

LoginName :<input type="text" name="Logname"><br>
Password :<input type="password" name="Pwd"><br>
<input type="submit" value="Login">
<input type="button" value="cancel">

 </form>

</body>
</html>

下面是我的web.xml代码

<web-app>
<servlet>
<servlet-name>loginserv</servlet-name>
<servlet-class>LoginServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>loginserv</servlet-name>
<url-pattern>/loginpage</url-pattern>]
</servlet-mapping>
</web-app>

有人可以帮我解决这个问题吗? 在此先感谢.. :))

4 个答案:

答案 0 :(得分:2)

您要覆盖错误的方法,改为覆盖doPost()并修改表单以包含method="post",如下所示:

public void doPost(HttpServletRequest request,HttpServletResponse response)throws IOException
{
    //...
}

和这个

<form action="http://localhost:8080/FlipKart/loginpage" method="post">

,如果您不想总是手动包含上下文的完整路径,则可以阅读this

答案 1 :(得分:1)

在更改软件包名称后是否重新启动了服务器? Tomcat仅在启动时读取web.xml。 此外,请确保您的课程位于webapps/WEB-INF/classes文件夹下。

答案 2 :(得分:1)

我认为您的应用程序上下文需要更改。也许它被设置为root。所以它没有击中/ FlipKart

查看this stackoverflow链接,了解有关设置应用程序上下文的更多信息。

这是针对tomcat 7.我知道您可以编辑以前版本的META-INF / context.xml。如果你没有该文件夹和文件,只需创建它。

EDIT 检查您的tomcat日志以查看它的部署位置,或者是否导致它根本没有部署。如果您从IDE运行,则可以从控制台看到。

答案 3 :(得分:0)

web.xml中对类的错误引用 使用包名为

的Class的全名
<servlet>
<servlet-name>loginserv</servlet-name>
<servlet-class>demo.LoginServlet</servlet-class>
</servlet>