2023.2.9日学习内容

该文介绍了如何使用Java构建登录页面,涉及Servlet处理HTTP请求,包括乱码处理、获取前端数据、对象封装。通过UserService进行业务逻辑,如密码加密(MD5),并与UserDao交互,查询数据库验证用户信息。最后返回结果到前端。
摘要由CSDN通过智能技术生成

如何连接数据库并且完成登录页面

1,准备工作

数据库内有user数据,Java后台有user对象,装好tomcat等

2,流程

1)创建LoginServlet类,完成六大步骤(乱码处理,获取前端数据,将数据封装到对象,将对象传到逻辑处理层处理,得到逻辑处理的返回值,将最终结果返回给前端),在Servlet中可以完成前三步。

2)创建UserService类,封装到对象后的逻辑需要创建一个UserService类将从前端得到的用户名跟密码进行处理,例如加密处理,验证码生成与验证,处理后将数据发送给dao层。

3)创建userDao类,连接数据库并且遍历选中的表,与处理后的数据进行比较,将比较的结果返回给UserService层。

4)UserService层得到结果并根据结果将对应值传递给前端。

3,实现代码

LoginServlet类

protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //1  乱码处理
        req.setCharacterEncoding(StandardCharsets.UTF_8.toString());
        resp.setCharacterEncoding(StandardCharsets.UTF_8.toString());
        //2  得到前端数据
        String name = req.getParameter("name");
        String password = req.getParameter("password");
        String code = req.getParameter("code");
        String sessionCode = String.valueOf(req.getSession().getAttribute("vCode"));
        //3  封装到model
        UserVO userVO = UserVO.builder()
                .name(name)
                .password(password)
                .code(code)
                .sessionCode(sessionCode)
                .build();
        //4  将对象传递到服务逻辑层
        UserService userService = new UserServiceImpl();

        //5  得到服务逻辑层的返回值
        ResultDTO obj = userService.login(userVO);

        //6  将结果返回给web前端
        resp.getWriter().println(JSONObject.toJSONString(obj));
    }
}

UserService类

public class UserServiceImpl implements UserService {
    @Override
    public ResultDTO login(UserVO userVO) {
        ResultDTO resultDTO = new ResultDTO();
        if (userVO.getCode().equals(userVO.getSessionCode())) {
            UserModel userModel = new UserModel();
            userModel = ObjCopy.copy(userVO, UserModel.class);
            String up = userModel.getPassword();
            String down = Md5.encoderByMd5(up);
            userModel.setPassword(down);
            UserDao userDao = new UserDaoImpl();
            UserModel model = userDao.findByUsernameAndPassword(userModel);
            if (model != null) {
                resultDTO.setCode(1);
                resultDTO.setMsg("success");
            } else {
                resultDTO.setCode(0);
                resultDTO.setMsg("error");
            }
        } else {
            resultDTO.setCode(-1);
            resultDTO.setMsg("error-code");
        }
        return resultDTO;
    }
}

UserDao类

    @Override
    public UserModel findByUsernameAndPassword(UserModel userModel) {
        String sql = "select * from user where name='" + userModel.getName()+ "' and password='" + userModel.getPassword() + "'";
        ResultSet query = JDBC.query(sql);
        UserModel model = null;
        try {
            while (query.next()) {
                model = new UserModel();
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return model;
    }
}

其中采用了接口的形式实现Dao与Service的代码,使得代码看起来不那么臃肿

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值