JavaWeb连接MySQL数据库
自己建立JavaWeb项目,连接MySQL数据库。
1.做一登陆界面,能够查询数据库验证用户名和密码;
2.登录成功后,显示用户表里所有用户数据。
注:数据库和表以及数据自己建立。
看看能用几种方式连接MySQL数据库,写出博文,配图、配代码。
一、jdbc连接
1.下载sqljdbc.jar的压缩包(下载地址:Maven Repository: mysql » mysql-connector-java (mvnrepository.com)),解压之后,将sqljdbc4.jar复制粘贴到你项目的WEB-INF的lib目录下
2.创建login.jsp登录页面welcom.jsp登录成功页面
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>登录</title> </head> <body> <form action="./AServlet" method="post"> 用户名:<input name="userName"/><br/> 密码:<input type="password" name="userPassword"><br/> <input type="submit"/> </form> </body> </html>
3.创建数据库,建表users
4.创建dao类
步骤:加载/驱动jdbc驱动包,连接,执行(预执行,执行),释放
package aa; import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import org.apache.tomcat.jni.OS; public class Userdao { public boolean selectByNameAPwd(String userName,String userPassword ){ try {//异常处理 Class.forName("com.mysql.jdbc.Driver"); System.out.println("加载驱动成功"); String ur1 ="jdbc:mysql://localhost:3306/llq?&useSSL=false&serverTimezone=UTC"; String username ="root";//数据库用户名 String password ="1234";//数据库密码 //数据库对象connection,Connection代表数据库 Connection connection =DriverManager.getConnection(ur1,username,password); PreparedStatement ps=connection.prepareStatement("SELECT*FROM users where userName=?and userPassword=?"); ps.setString(1, userName); ps.setString(2, userPassword); ResultSet rs=ps.executeQuery(); boolean r; if (rs.next()) { r=true; }else { r=false; } connection.close(); rs.close(); ps.close(); return r; } catch (Exception e) { } return false; } }
4.创建servlet类处理请求
package aa; import java.io.IOException; 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 org.apache.catalina.ant.jmx.JMXAccessorQueryTask; @WebServlet("/AServlet") public class AServlet extends HttpServlet { private static final long serialVersionUID = 1L; public AServlet() { super(); } protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String username=request.getParameter("userName"); String password=request.getParameter("userPassword"); boolean r2=new Userdao().selectByNameAPwd(username, password);//调用UserDao类中布尔类型selectByNameAPwd(username, password);
if (r2) { response.sendRedirect("./welcome.jsp"); }else { response.sendRedirect("./login.jsp"); } } protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub doGet(request, response); } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?