mysql servlet登录验证_使用Servlet和jdbc创建用户登录验证

首先创建一个用户表,用来保存用户名 密码,并插入几条数据

mysql> desc user;

+----------+-------------+------+-----+---------+----------------+

| Field | Type | Null | Key | Default | Extra |

+----------+-------------+------+-----+---------+----------------+

| id | int(11) | NO | PRI | NULL | auto_increment |

| username | varchar(20) | YES | | NULL | |

| password | varchar(50) | YES | | NULL | |

+----------+-------------+------+-----+---------+----------------+

创建语句,注意一定要设置password的长度超过41,因为插入数据时我们使用password函数,生成长度为41的字符串,

例如:

mysql> select password('aasas');

+-------------------------------------------+

| password('aasas') |

+-------------------------------------------+

| *462034BF6D04324F93F1F6CA352B23079A165972 |

+-------------------------------------------+

1 row in set (0.00 sec)

mysql> select length( password('aasas'));

+----------------------------+

| length( password('aasas')) |

+----------------------------+

| 41 |

+----------------------------+

1 row in set (1.76 sec)

CREATE TABLE `user` (

`id`int(11) NOT NULLAUTO_INCREMENT,

`username`varchar(20) DEFAULT NULL,

`password`varchar(50) DEFAULT NULL,PRIMARY KEY(`id`)

) ENGINE=InnoDB AUTO_INCREMENT=4 DEFAULT CHARSET=utf8

插入数据:

mysql> insert into user(username,password) values('root',password('root'));

查看一下插入结果:此时密码已经变成一串字符串.

mysql> select * from user where username='root';

+----+----------+-------------------------------------------+

| id | username | password |

+----+----------+-------------------------------------------+

| 4 | root | *81F5E21E35407D884A6CD4A731AEBFB6AF209E1B |

+----+----------+-------------------------------------------+

1 row in set (0.00 sec)

2.创建一个java web project,新建一个名为user的类,使用jdbc链接数据库,把user表的数据拿出来和输入的用户名密码对比,并添加validate方法

如果用户名密码正确,返回true。之后注意将Mysql JDBC的driver copy到lib目录下,否则无法运行

8afb841699a2c1b9d301f4feeeda80be.png

packagecom.data;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.ResultSet;public classuser {private staticString userName;private staticString password;publicString getUserName() {returnuserName;

}public voidsetUserName(String userName) {this.userName =userName;

}publicString getPassword() {returnpassword;

}public voidsetPassword(String password) {this.password =password;

}public static booleanvalidate()

{

String url= "jdbc:mysql://localhost:3306/study";

String user= "root";

String dbpassword= "3edc4rfv";boolean result = false;try{

String driver="com.mysql.jdbc.Driver";

Class.forName(driver);

Connection con=DriverManager.getConnection(url,user, dbpassword);if(con==null){

System.out.println("can't open DBConnection");

}

String sql= "select * from user where username=? and password=password(?)";

PreparedStatement pstmt=con.prepareStatement(sql);

pstmt.setString(1, userName);

pstmt.setString(2, password);

System.out.println(sql);

ResultSet rs=pstmt.executeQuery();if(rs.next())

{

System.out.println("PASS");

result=true;

}else{

System.out.println("FAIl");

result=false;

}

pstmt.close();

rs.close();

con.close();

}catch(Exception e) {//TODO Auto-generated catch block

e.printStackTrace();

}returnresult;

}

}

并新建一个Servlet,包名com.web,class name login.java,这里主要使用post方法,所以在dopost方法添加代码

将login.java 修改为这样:

packagecom.web;importjava.io.IOException;importjava.io.PrintWriter;importjava.sql.Connection;importjava.sql.DriverManager;importjava.sql.PreparedStatement;importjava.sql.ResultSet;importjava.util.ArrayList;importjava.util.List;importjavax.servlet.ServletException;importjavax.servlet.http.HttpServlet;importjavax.servlet.http.HttpServletRequest;importjavax.servlet.http.HttpServletResponse;importcom.data.book;importcom.data.user;public class login extendsHttpServlet {/*** Constructor of the object.*/

publiclogin() {super();

}/*** Destruction of the servlet.
*/

public voiddestroy() {super.destroy(); //Just puts "destroy" string in log//Put your code here

}/*** The doGet method of the servlet.

*

* This method is called when a form has its tag value method equals to get.

*

*@paramrequest the request send by the client to the server

*@paramresponse the response send by the server to the client

*@throwsServletException if an error occurred

*@throwsIOException if an error occurred*/

public voiddoGet(HttpServletRequest request, HttpServletResponse response)throwsServletException, IOException {//Add some codes

doPost(request,response);

}/*** The doPost method of the servlet.

*

* This method is called when a form has its tag value method equals to post.

*

*@paramrequest the request send by the client to the server

*@paramresponse the response send by the server to the client

*@throwsServletException if an error occurred

*@throwsIOException if an error occurred*/

public voiddoPost(HttpServletRequest request, HttpServletResponse response)throwsServletException, IOException {

request.getParameter("username");

request.getParameter("password");

request.getSession().setAttribute("user", request.getParameter("username")); //将user放在Attribute中

user user1=newuser();

user1.setUserName(request.getParameter("username"));

user1.setPassword(request.getParameter("password"));

System.out.println(request.getParameter("username")+request.getParameter("password"));if(user1.validate())

{request.getRequestDispatcher("welcome.jsp").forward(request, response); //校验用户名密码正确,跳转到welcome.jsp

}else{

request.getRequestDispatcher("index.jsp").forward(request, response); //校验用户名密码不正确,跳转到index.jsp

}

}/*** Initialization of the servlet.

*

*@throwsServletException if an error occurs*/

public void init() throwsServletException {//Put your code here

}

}

此时web.xml代码如下。可以使用login.do访问这个Servlet

http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">

login Page

login Page

login

com.web.login

login

/login.do

index.jsp

3.在jsp页面添加相应的action,在index.jsp的body标签之间添加,会生出登录界面,用户名 密码

username


password

4.添加welcome.jsp

在welcome.jsp body标签添加

Welcome

5.加载工程

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的使用 JDBCServlet 实现用户注册和登录功能的示例代码: 1. 首先,我们需要创建一个数据库来存储用户信息,例如: CREATE TABLE users ( id INT PRIMARY KEY AUTO_INCREMENT, username VARCHAR(50) NOT NULL UNIQUE, password VARCHAR(50) NOT NULL ); 2. 接下来,我们需要编写一个注册 Servlet,用于处理用户提交的注册单。以下是一个示例代码: import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; @WebServlet("/register") public class RegisterServlet extends HttpServlet { private static final long serialVersionUID = 1L; // 数据库连接信息 private static final String URL = "jdbc:mysql://localhost:3306/test"; private static final String USER = "root"; private static final String PASSWORD = "123456"; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取用户提交的注册信息 String username = request.getParameter("username"); String password = request.getParameter("password"); // 插入用户信息到数据库 try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD)) { String sql = "INSERT INTO users (username, password) VALUES (?, ?)"; PreparedStatement stmt = conn.prepareStatement(sql); stmt.setString(1, username); stmt.setString(2, password); stmt.executeUpdate(); // 注册成功后跳转到登录页面 response.sendRedirect("login.html"); } catch (SQLException e) { e.printStackTrace(); } } } 3. 然后,我们需要编写一个登录 Servlet,用于验证用户提交的登录信息。以下是一个示例代码: import java.io.IOException; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; 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; @WebServlet("/login") public class LoginServlet extends HttpServlet { private static final long serialVersionUID = 1L; // 数据库连接信息 private static final String URL = "jdbc:mysql://localhost:3306/test"; private static final String USER = "root"; private static final String PASSWORD = "123456"; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取用户提交的登录信息 String username = request.getParameter("username"); String password = request.getParameter("password"); // 验证用户信息是否正确 try (Connection conn = DriverManager.getConnection(URL, USER, PASSWORD)) { String sql = "SELECT * FROM users WHERE username=? AND password=?"; PreparedStatement stmt = conn.prepareStatement(sql); stmt.setString(1, username); stmt.setString(2, password); ResultSet rs = stmt.executeQuery(); if (rs.next()) { // 登录成功,将用户信息保存到 Session 中 HttpSession session = request.getSession(); session.setAttribute("username", username); response.sendRedirect("welcome.jsp"); } else { // 登录失败,返回错误信息 response.sendRedirect("login.html?error=1"); } } catch (SQLException e) { e.printStackTrace(); } } } 4. 最后,我们需要编写一个欢迎页面,用于显示用户登录成功后的信息。以下是一个示例代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>欢迎</title> </head> <body> <h1>欢迎 <%= session.getAttribute("username") %>!</h1> <a href="logout">退出</a> </body> </html> 以上就是一个简单的使用 JDBCServlet 实现用户注册和登录功能的示例代码。当然,这只是一个示例,实际应用中可能需要更复杂的逻辑和更完善的安全性措施。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值