Servlet教程3-连接数据库

JDBC配置

创建Tomcat的时候是没有JDBC数据库包的。按以下步骤配置
1.在webapp目录下创建一个新的目录lib之后把JDBC数据库包放到这个目录下:
在这里插入图片描述
2.右键这个libs文件夹,点击添加为库就可以了
在这里插入图片描述

测试配置是否成功

可以使用这段代码来测试连接是否成功:

import com.example.webtest.Servlet6;
import java.sql.Connection;
import java.sql.SQLException;
import static JDBC的可调用方法.MainGUI.Findid;
public class MY1 {
    private static Connection conn; // 声明为类的静态成员变量
    //在这里连接数据库,注意更改数据库名(在?前面是数据库的名字),注意最后一个参数是允许批量导入
    private static final String URL = "jdbc:mysql://localhost:3306/nnn?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&allowLoadLocalInfile=true";
    public static void main(String[] args) throws SQLException {
        String driver = "com.mysql.cj.jdbc.Driver";//数据库驱动类所对应的字符串
        Connection conn = null;
        try {
            Class.forName(driver);//加载MySQL数据库驱动
        } catch (ClassNotFoundException e) {//这个错误是你的配置没有配置好
            System.out.println("驱动程序配置未配置成功!!!");
            System.out.println("可能是你的 jar包没有导入或出错!");
        }
        try {
        } catch (Exception e) {//未连接成功,执行下面的异常处理
            System.out.println("数据库连接失败!!!");
            System.out.println("有可能是你没有启动数据库,cmd输入 net start mysql 以启动(我的数据库名字是mysql2)");
            System.out.println("下面是错误提示:");
            System.out.println(e);
        }
    }
}

使用数据库连接

可以连接一个试试看,先创建一个Java类,之后直接在Servlet中使用这个类就行了。
比如下面是我查找用户id的一个JDBC(可以换成你想要的sql语句)

public static int Findid(String username, String password) throws SQLException, ClassNotFoundException {
        final String URL = "jdbc:mysql://localhost:3306/nnn?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&allowLoadLocalInfile=true";
        String driver = "com.mysql.cj.jdbc.Driver";//数据库驱动类所对应的字符串
        Class.forName(driver);//加载MySQL数据库驱动
        int id = -1; // 默认值为-1,表示未找到对应记录

        try {
            conn = DriverManager.getConnection(URL, "root", "ikunjojo");
            String selectQuery = "SELECT id FROM classmate WHERE username = ? AND password = ?";
            PreparedStatement preparedStatement = conn.prepareStatement(selectQuery);

            preparedStatement.setString(1, username);
            preparedStatement.setString(2, password);

            ResultSet resultSet = preparedStatement.executeQuery();

            if (resultSet.next()) {
                id = resultSet.getInt("id");
                System.out.println("成功找到对应ID: " + id);
                //logCurrentTime("本地时间为");
            } else {
                System.out.println("未找到对应记录");
            }
        } catch (SQLException e) {
            System.out.println("查找ID失败");
            e.printStackTrace();
        } finally {
            if (conn != null) {
                conn.close();
            }
        }

        return id;
    }

在类中创建一个方法:

    public void login(String username,String password) throws SQLException, ClassNotFoundException {
        int money = Findid(username,password);
        System.out.println("该用户有:"+money+"元");
    }

在Serlet直接使用就行了:

@Override
    public void service(ServletRequest servletRequest, ServletResponse servletResponse) throws ServletException, IOException {
        System.out.println("你好aaa");
        User a = new User();
        try {
            a.login("11","32");
        } catch (SQLException e) {
            throw new RuntimeException(e);
        } catch (ClassNotFoundException e) {
            throw new RuntimeException(e);
        }
    }

在这里插入图片描述

  • 8
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
下面是一个简单的Servlet和JSP编写登录注册页面的完整教程。 1. 创建数据库表格 首先,我们需要创建一个名为“users”的数据库表格,包含以下字段: - id(int,自增长) - username(varchar) - password(varchar) 2. 创建JavaBean类 然后,我们需要创建一个JavaBean类来代表用户: ```java public class User { private int id; private String username; private String password; public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } } ``` 3. 创建数据库访问类 接下来,我们需要创建一个类来处理与数据库的交互。我们将使用JDBC连接到MySQL数据库。在这个例子中,我们将使用一个简单的DAO模式(数据访问对象)来处理所有数据库访问: ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; public class UserDao { private String jdbcUrl; private String jdbcUsername; private String jdbcPassword; private Connection jdbcConnection; public UserDao(String jdbcUrl, String jdbcUsername, String jdbcPassword) { this.jdbcUrl = jdbcUrl; this.jdbcUsername = jdbcUsername; this.jdbcPassword = jdbcPassword; } protected void connect() throws SQLException { if (jdbcConnection == null || jdbcConnection.isClosed()) { try { Class.forName("com.mysql.jdbc.Driver"); } catch (ClassNotFoundException e) { throw new SQLException(e); } jdbcConnection = DriverManager.getConnection(jdbcUrl, jdbcUsername, jdbcPassword); } } protected void disconnect() throws SQLException { if (jdbcConnection != null && !jdbcConnection.isClosed()) { jdbcConnection.close(); } } public boolean addUser(User user) throws SQLException { String sql = "INSERT INTO users (username, password) VALUES (?, ?)"; connect(); PreparedStatement statement = jdbcConnection.prepareStatement(sql); statement.setString(1, user.getUsername()); statement.setString(2, user.getPassword()); boolean rowInserted = statement.executeUpdate() > 0; statement.close(); disconnect(); return rowInserted; } public User getUser(String username, String password) throws SQLException { String sql = "SELECT * FROM users WHERE username = ? AND password = ?"; connect(); PreparedStatement statement = jdbcConnection.prepareStatement(sql); statement.setString(1, username); statement.setString(2, password); ResultSet resultSet = statement.executeQuery(); User user = null; if (resultSet.next()) { user = new User(); user.setId(resultSet.getInt("id")); user.setUsername(resultSet.getString("username")); user.setPassword(resultSet.getString("password")); } resultSet.close(); statement.close(); disconnect(); return user; } } ``` 4. 创建Servlet 现在我们可以创建一个Servlet来处理登录和注册请求。这个Servlet将使用我们刚刚创建的UserDao类来访问数据库。 ```java import java.io.IOException; 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("/login") public class LoginServlet extends HttpServlet { private static final long serialVersionUID = 1L; private UserDao userDao; public void init() { String jdbcUrl = "jdbc:mysql://localhost:3306/test"; String jdbcUsername = "root"; String jdbcPassword = "password"; userDao = new UserDao(jdbcUrl, jdbcUsername, jdbcPassword); } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username = request.getParameter("username"); String password = request.getParameter("password"); try { User user = userDao.getUser(username, password); if (user != null) { request.setAttribute("user", user); request.getRequestDispatcher("welcome.jsp").forward(request, response); } else { response.sendRedirect("login.jsp"); } } catch (SQLException ex) { throw new ServletException(ex); } } } ``` 5. 创建JSP 最后,我们需要创建一个JSP文件来显示登录表单和欢迎消息。 ```html <!DOCTYPE html> <html> <head> <title>Login</title> </head> <body> <h1>Login</h1> <form action="login" method="post"> <label>Username:</label> <input type="text" name="username"><br><br> <label>Password:</label> <input type="password" name="password"><br><br> <input type="submit" value="Login"> </form> </body> </html> ``` ```html <!DOCTYPE html> <html> <head> <title>Welcome</title> </head> <body> <h1>Welcome <%= request.getAttribute("user").getUsername() %>!</h1> </body> </html> ``` 6. 部署应用程序 现在,我们已经完成了我们的应用程序。我们只需要将它部署到一个Web服务器上,例如Tomcat或Jetty,就可以开始使用它了。 注意:这只是一个简单的例子,实际的Web应用程序需要更多的安全性和错误处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值