JavaWeb登入窗口实现,连接数据库

15 篇文章 0 订阅
1 篇文章 0 订阅

1.学生界面前端代码

<body>
    <form  class="table_login" action="/web1/LoginServlet_student" method="post">//这里的action是当点击submit按钮是=时跳转到的servlet。
        <div class="login_windows">学生登入页面</div>

        <form>
            <span style="padding-left: 10px"><input type="button" class="text_login" name="teacherlogin"  value="教师登入" onclick="window.location.href='Teacher Login Windows .jsp'"></span>

            <span style="padding-left: 50px"><input type="button" class="text_login" name="studentlogin" value="学生登入"></span><br><br>
            <label for="username">用户名:</label>
            <input type="text" class="td_text1" name="username" id="username" placeholder="请输入用户名"><br><br>
            <label for="username">密码:</label>
            <span>&nbsp&nbsp&nbsp</span><input type="password" class="td_text1" name="password" id="password" placeholder="请输入密码"><br><br>
            <span style="padding-left: 30px;"><input type="submit" class="text_login" name="login" id="login" value="登入"></span>
            <span style="padding-left: 50px"><input type="button" class="text_login" name="register" id="register" value="注册" onclick="window.location.href='register.jsp'"></span>      
        </form>
    </form>
</body>

2.在连接数据库时,要到文件中修改url以及数据库的账号和密码

在这里插入图片描述
在这里插入图片描述
并且还需要添加文件的虚拟路径,在编写Java代码的路径时不加虚拟路径,因为会默认添加,但是在编写jsp代码时,需要加上前面的虚拟路径。
在这里插入图片描述

LoginServlet_student代码

@WebServlet( urlPatterns = "/LoginServlet_student")
public class LoginServlet_student extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //1.设置编码
        //System.out.println("1111");
        req.setCharacterEncoding("utf-8");
        //2.获取所有请求参数
        Map<String, String[]> map = req.getParameterMap();
        //3.创建User对象
        User loginUser = new User();
        //3.2使用BeanUtils封装
        try {
            BeanUtils.populate(loginUser,map);
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            e.printStackTrace();
        }
        
        //4.调用UserDao的login方法
        UserDao dao = new UserDao();
        User user = dao.login_student(loginUser);

        //5.判断user
        if(user == null){
            //登录失败
            req.getRequestDispatcher("/failServlet").forward(req,resp);
        }else{
            //登录成功
            //存储数据
            req.setAttribute("user",user);
            HttpSession session=req.getSession();
            session.setAttribute("user",user);
            //转发
            req.getRequestDispatcher("/successServlet_student").forward(req,resp);
        }
    }

    @Override
    protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        this.doGet(req,resp);
    }
}

在UserDao类中编写与数据库进行操作的代码

public class UserDao {

    //声明JDBCTemplate对象公用
    private JdbcTemplate template =new JdbcTemplate(JDBCUtil.getDataSource());

    public User login(User loginUser) {

        //编写sql
        try {
            String sql = "select * from user where username = ? and password = ?";
            //调用query  方法
            User user = template.queryForObject(sql,
                    new BeanPropertyRowMapper<User>(User.class),
                    loginUser.getUsername(), loginUser.getPassword());

            return user;
        } catch (DataAccessException e) {
            e.printStackTrace();
            return null;
        }
    }
}

eclipse连接数据库

1.刚开始一直连接不上,原因有可能是因为我的驱动包太久了。
在这里插入图片描述
2.重新下载一个新的驱动包:
在这里插入图片描述
连接步骤:

  1. 先build,mysql-connector-java驱动包
    在这里插入图片描述
    2.加载驱动
    在这里插入图片描述
    3.连接数据库
    在这里插入图片描述
Class.forName("com.mysql.cj.jdbc.Driver");// 加载驱动
				String jdbc = "jdbc:mysql://localhost:3306/person?useSSL=false&allowPublicKeyRetrieval=true&serverTimezone=UTC";;
				Connection conn = DriverManager.getConnection(jdbc, "root", "root");// 链接到数据库

				String sql = "select * from client where username=? and passwork=?";
				PreparedStatement state = conn.prepareStatement(sql);
				state.setString(1, usernameString);
				state.setString(2, passworkString);
				ResultSet resultSet = state.executeQuery();
				if (resultSet.next()) {
					System.out.println("登入成功" + resultSet.getString(1) + "欢迎你");
				} else {
					System.out.println("登入失败。账号或密码有误");
				}
				resultSet.close();
				conn.close();
  • 2
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现JavaWeb登录连接数据库,需要以下步骤: 1. 导入JDBC驱动包:在项目中导入MySQL JDBC驱动包,可以从MySQL官网或者Maven仓库下载。 2. 创建数据库和数据表:创建一个用户表,包含id、username、password等字段。 3. 创建JDBC连接:通过JDBC连接数据库,使用JDBCUtils类封装JDBC连接的操作,获取数据库连接。 4. 编写登录逻辑:获取用户输入的用户名和密码,查询数据库中是否存在该用户,若存在则登录成功,否则登录失败。 下面是一个简单的JavaWeb登录连接数据库的示例代码: ``` // 导入JDBC驱动包和JDBCUtils类 import java.sql.*; import com.utils.JDBCUtils; public class LoginServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取用户输入的用户名和密码 String username = request.getParameter("username"); String password = request.getParameter("password"); Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; try { // 获取数据库连接 conn = JDBCUtils.getConnection(); // 编写SQL语句,查询用户是否存在 String sql = "select * from user where username=? and password=?"; pstmt = conn.prepareStatement(sql); pstmt.setString(1, username); pstmt.setString(2, password); rs = pstmt.executeQuery(); if (rs.next()) { // 若存在则登录成功 request.getRequestDispatcher("success.jsp").forward(request, response); } else { // 否则登录失败 request.getRequestDispatcher("fail.jsp").forward(request, response); } } catch (SQLException e) { e.printStackTrace(); } finally { // 关闭数据库连接 JDBCUtils.release(conn, pstmt, rs); } } } ``` 需要注意的是,JDBCUtils类需要根据具体的数据库配置进行修改,例如数据库的URL、用户名和密码等。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值