欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ServLet+Tomcat编写穷人版登录Web界面

程序员文章站 2022-04-15 19:10:58
本文中使用到的软件:Tomcat 8.0Mysql 5.7IntelliJ IDEA 2019项目实现流程:在数据库中新建如下的数据表:IDEA中新建一个项目,选中Web Application:在src文件夹下新建如下所示的文件夹:dao: 用于数据库操作model: 用于创建web开发需要用到的类service: 用于为model类提供服务方法Servlet: 用于新建重写Servlet处理Http请求的方法Utils: 用于编写一些工具类,例如建立数据库连接的类...

本文中使用到的软件:

Tomcat 8.0
Mysql 5.7
IntelliJ IDEA 2019

项目实现流程:

  1. 在数据库中新建如下的数据表:
    ServLet+Tomcat编写穷人版登录Web界面

  2. IDEA中新建一个项目,选中Web Application:
    ServLet+Tomcat编写穷人版登录Web界面

  3. 在src文件夹下新建如下所示的文件夹:
    dao: 用于数据库操作
    model: 用于创建web开发需要用到的类
    service: 用于为model类提供服务方法
    Servlet: 用于新建重写Servlet处理Http请求的方法
    Utils: 用于编写一些工具类,例如建立数据库连接的类
    在web文件夹下建立libs文件夹:
    ServLet+Tomcat编写穷人版登录Web界面

  4. 在Libs文件夹中导入以下两个jar包并右键点击 Add as Library:
    ServLet+Tomcat编写穷人版登录Web界面
    ServLet+Tomcat编写穷人版登录Web界面

  5. 点击右上角的Edit Configuration配置Tomcat
    ServLet+Tomcat编写穷人版登录Web界面

  6. 点击左上角的加号,选中Tomcat,选择local:
    ServLet+Tomcat编写穷人版登录Web界面
    然后需要在Configuration中填入电脑中Tomcat的安装地址:
    ServLet+Tomcat编写穷人版登录Web界面
    ServLet+Tomcat编写穷人版登录Web界面

设置完成后如果出现Warning就点击Fix一下即可:
ServLet+Tomcat编写穷人版登录Web界面
然后点击上方的Deployment,清空下方的内容(这部分会导致写出的网页带一个很长的后缀):
ServLet+Tomcat编写穷人版登录Web界面
6. 然后就到了我们的编写代码环节了,编写的内容如下:
model.user:

//User.java
public class User {
    private int id;
    private String name;
    private String password;
    private int age;



    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", password='" + password + '\'' +
                ", age=" + age +
                '}';
    }
}

dao.UserDao:

//UserDao.java
public class UserDao {
    public User selectByName(String name){
        ResultSet rs = null;
        Connection connection = null;
        PreparedStatement pstmt = null;
        DBUtil dbUtil = new DBUtil();
        User user = new User();

        try {
            connection = dbUtil.getConnection();
            pstmt = connection.prepareStatement("select * from user where name=?");
            pstmt.setString(1,name);

            rs = pstmt.executeQuery();
            while(rs.next()){
                user.setId(rs.getInt(1));
                user.setName(rs.getString(2));
                user.setPassword(rs.getString(3));
                user.setAge(rs.getInt(4));
            }
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }finally {
            dbUtil.closeAll(rs,pstmt,connection);
        }
        return user;
    }

    public boolean InsertUser(String name,String password,int age){
        Connection connection = null;
        PreparedStatement pstmt = null;

        try {
            connection = DBUtil.getConnection();
            pstmt = connection.prepareStatement("insert into user(name,password,age) values (?,?,?)");
            pstmt.setString(1,name);
            pstmt.setString(2,password);
            pstmt.setInt(3,age);

            pstmt.execute();
            return true;
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return false;
    }
}

Service.UserService:

//UserService
public class UserService {
    UserDao userDao = new UserDao();

    //查找用户
    public User SelectByName(String name){
        return userDao.selectByName(name);
    }
    //插入一个新用户
    public boolean Register(String name,String password,int age){
        return userDao.InsertUser(name,password,age);
    }
}

ServLet.LoginServLet

//loginServLet.java
public class LoginServLet extends HttpServlet {
    UserService userService = new UserService();
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    	//如果点击的是登录按钮则获取数据
        String name = req.getParameter("name");
        String password = req.getParameter("password");
        System.out.println("name:"+name);
        User user = userService.SelectByName(name);
        System.out.println(user);
        //验证密码是否正确
        if (password.equals(user.getPassword())) {
            resp.getWriter().write("success");
            System.out.println("success");
        } else {
            resp.getWriter().write("fail");
            System.out.println("fail");
        }

    }
}

ServLet.RegisterServLet:

//RegisterServlet.java
public class RegisterServLet extends HttpServlet {
    UserService userService = new UserService();
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //如果点击了注册按钮则显示如下的HTML页面
        PrintWriter out = resp.getWriter();
        out.write("<html>\n" +
                "  <head>\n" +
                "    <meta http-equiv=\"content-type\" content=\"text/html;charset=gbk\" />\n"+
                "    <title>register</title>\n" +
                "  </head>\n" +
                "  <body>\n" +
                "  <H1>register</H1>\n" +
                "    <form action=\"/register\" method=\"post\">\n" +
                "    name:<input name=\"name\" type=\"text\">\n" +
                "    password:<input name=\"password\" type=\"password\">\n" +
                "    age:<input name=\"age\" type=\"text\">\n"+
                "      <input type=\"submit\" formaction=\"/registerSubmit\" value=\"register\">\n" +
                "    </form>\n" +
                "  </body>\n" +
                "</html>");

    }
}

ServLet.RegisterSubmitServLet:

//RegisterSubmitServLet.java
public class RegisterSubmitServLet extends HttpServlet {
    UserService userService = new UserService();
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    	//获取注册界面数据并插入
        String name = req.getParameter("name");
        String password = req.getParameter("password");
        String age = req.getParameter("age");
        //int age = Integer.parseInt(req.getParameter("age"));
        boolean re = userService.Register(name,password,Integer.valueOf(age));
        System.out.println(name+password+age);
        //String msg = lStrings.getString("http.method_post_not_supported");
        if (re) {
            resp.getWriter().write("success");
        } else {
            resp.getWriter().write("fail");
        }

    }
}

Utils.DBUtil:

//DBUtil.java
public class DBUtil {
    public static Connection connection = null;
    public static Connection getConnection() throws ClassNotFoundException, SQLException {
        if(connection==null) {
            Class.forName("com.mysql.cj.jdbc.Driver");
            Connection connection = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?useSSL=false&autoReconnect=true&serverTimezone=GMT", "root", "hxh19981225");
            return connection;
        }else {
            return connection;
        }
    }

    public static void closeAll(ResultSet rs, Statement statement, Connection connection){
        if(rs!=null){
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if(statement!=null){
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
        if(connection!=null){
            try {
                rs.close();
            } catch (SQLException e) {
                e.printStackTrace();
            }
        }
    }
}

  1. 接下来还需要编写Web文件夹下的index.jsp以及在WEB-INF中注册编写的ServLet:
    index.jsp:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
  <head>
    <title>登录界面</title>
  </head>
  <body>
  <H1>登录界面</H1>
    <form action="/login" method="post">
    name:<input name="name" type="text">
    password:<input name="password" type="password">
    <input type="submit" formaction="/login" value="登录">
      <input type="submit" formaction="/register" value="注册">
    </form>
  </body>
</html>

web.xml:

<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
         version="4.0">
<!--    登录界面-->
    <servlet>
        <servlet-name>login</servlet-name>
        <servlet-class>com.huxiaoheng.ServLet.LoginServLet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>login</servlet-name>
        <url-pattern>/login</url-pattern>
    </servlet-mapping>
<!--    注册界面-->
    <servlet>
        <servlet-name>register</servlet-name>
        <servlet-class>com.huxiaoheng.ServLet.RegisterServLet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>register</servlet-name>
        <url-pattern>/register</url-pattern>
    </servlet-mapping>
<!--    注册提交-->
    <servlet>
        <servlet-name>registerSubmit</servlet-name>
        <servlet-class>com.huxiaoheng.ServLet.RegisterSubmitServLet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>registerSubmit</servlet-name>
        <url-pattern>/registerSubmit</url-pattern>
    </servlet-mapping>
</web-app>

这样我们的项目就算完成了,点击运行效果如图所示:
ServLet+Tomcat编写穷人版登录Web界面
(没有写css,所以长得很抽象)
点击注册显示界面:
ServLet+Tomcat编写穷人版登录Web界面
注册成功跳转到显示success界面:
ServLet+Tomcat编写穷人版登录Web界面
ServLet+Tomcat编写穷人版登录Web界面
可以在数据库查看到该条数据:
ServLet+Tomcat编写穷人版登录Web界面
然后就可以登录该账号了:
ServLet+Tomcat编写穷人版登录Web界面

ServLet+Tomcat编写穷人版登录Web界面
没错因为懒得修改了所以 显示的内容和注册成功是一样的。不过还是可以通过地址看到它们导向的是不一样的地址~~,而且自己所学有限,实在是做不出其他不一样的页面~~
今日的Debug日记:
在写SQL插入语句的时候报错:
ServLet+Tomcat编写穷人版登录Web界面
查阅之后发现,如果是插入,删除等语句对应的函数一个是execute()而非executeQuery()。另外返回值为一个布尔类型, 而且,不是插入成功就返回True,插入失败返回False。 而是如果第一个结果是 ResultSet 对象,则返回 true;如果第一个结果是更新计数或者没有结果,则返回 false。

好了这差不多是本文的全部内容了,超级简陋的登录界面!

本文地址:https://blog.csdn.net/qq_41823958/article/details/107495396

相关标签: html