运用Servlet+JSP+MySQL+JDBCTempleat+Duird+BeanUtilS+tomcat技术。实现用户信息的增删改查操作。续(登录部分)

学习目标:

运用Servlet+JSP+MySQL+JDBCTempleat+Duird+BeanUtilS+tomcat技术。实现用户信息的增删改查操作(登录功能及界面实现)。


步骤:

1.根据login.jsp界面的表单提交到的action值写对应的loginServlet的实现

在这里插入图片描述

2.保证数据库中有用于登录的username和password对应的列,并更新到对应的entity/domain中的实体类中,添加对应的get和set方法.

3.编写LoginServlet
package com.fjut.webCRUD.web.servlet;

import com.fjut.webCRUD.entity.User;
import com.fjut.webCRUD.service.IUserService;
import com.fjut.webCRUD.service.impl.UserServiceImpl;
import org.apache.commons.beanutils.BeanUtils;

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;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.util.Map;

@WebServlet("/loginServlet")
public class LoginServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1.设置编码
        request.setCharacterEncoding("utf-8");

        //2.获取数据
        //2.1获取用户填写验证码
        String verifycode = request.getParameter("verifycode");         //用的是<input type="text" name="verifycode" class="form-control" id="verifycode" placeholder="请输入验证码" style="width: 120px;"/>中的name属性的值

        //3.验证码校验
        HttpSession session = request.getSession();
        String checkcode_server = (String) session.getAttribute("CHECKCODE_SERVER");
        session.removeAttribute("CHECKCODE_SERVER");//确保验证码一次性
        if(!checkcode_server.equalsIgnoreCase(verifycode)){     //判断验证码信息不区分大小写
            //验证码不正确
            //提示信息
            request.setAttribute("login_msg","验证码错误!");
            //跳转登录页面
            request.getRequestDispatcher("/login.jsp").forward(request,response);

            return;
        }

        Map<String, String[]> map = request.getParameterMap();
        //4.封装User对象
        User user = new User();
        try {
            BeanUtils.populate(user,map);           //将获取到的username和password封装到对象里面
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            e.printStackTrace();
        }


        //5.调用Service查询
        IUserService service = new UserServiceImpl();
        User loginUser = service.login(user);
        //6.判断是否登录成功
        if(loginUser != null){
            //登录成功
            //将用户存入session
            session.setAttribute("user",loginUser);
            //跳转页面
            response.sendRedirect(request.getContextPath()+"/index.jsp");
        }else{
            //登录失败
            //提示信息
            request.setAttribute("login_msg","用户名或密码错误!");
            //跳转登录页面
            request.getRequestDispatcher("/login.jsp").forward(request,response);

        }

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }
}

小总结:
LoginServlet编写的逻辑:
1.设置编码(防止乱码)

在这里插入图片描述

2.获取login.jsp界面的数据(小细节:先获取验证码,判断验证码是否正确,如果验证码不正确,就不需要去到数据库中查询对应的登录数据.可以很大节省时间).

在这里插入图片描述

3.如果验证码正确, 将login.jsp界面的用户名和密码信息封装进用户类中.

在这里插入图片描述

4.用封装的信息去service层中调用查询登录信息是否存在(只需要返回是否存在即可).具体查询过程调用dao层的查询方法.

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

5.为了登录进去后显示(“xxx,欢迎您”)的相关显示需要,(一次会话的多次请求)我们将查询到的用户数据存入session中传到对应界面,

在这里插入图片描述

6.中login.jsp中若需要展示(验证码错误/用户名或密码错误的相关信息)则需要设置login.jsp中对应的值.

      6.1用户名或密码错误.

在这里插入图片描述
      6.2验证码错误

在这里插入图片描述


总结:

web项目实现登录的过程:

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值