ClownLift 2019-07-14 16:32 采纳率: 0%
浏览 262

我搞不清楚到底错哪了,请指教

package login.servlet;

import login.dao.UserDao;
import login.domain.User;

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 java.io.IOException;

/**

  • @description 登录请求处理类
  • @author WANGZIC
    */
    @WebServlet("/LoginServlet")
    public class LoginServlet extends HttpServlet {

    private static final long serialVersionUID = 1L;

    @Override
    public void doPost(HttpServletRequest request, HttpServletResponse response)
    throws ServletException, IOException {
    request.setCharacterEncoding("utf-8");
    response.setContentType("text/html;charset=utf-8");
    //接收表单信息
    String username = request.getParameter("username");
    String password = request.getParameter("password");
    String verifyc = request.getParameter("verifycode");
    //设置回显
    request.setAttribute("username", username);
    request.setAttribute("password", password);
    request.setAttribute("verifycode", verifyc);
    //获取验证码
    String svc =(String) request.getSession().getAttribute("sessionverify");
    //根据用户名查询用户
    User user =new UserDao().selectByUsername(username);
    if(!svc.equalsIgnoreCase(verifyc)){
    request.setAttribute("loginError", "* 验证码错误");
    request.getRequestDispatcher(request.getContextPath()+"/login.jsp").forward(request, response);
    return;
    }
    if(user!=null){
    if(user.getPassword().equals(password)){
    request.getSession().setAttribute("user", user);
    response.sendRedirect("index.jsp");
    }else {
    request.setAttribute("loginError", "* 密码错误");
    request.getRequestDispatcher(request.getContextPath()+"/login.jsp").forward(request, response);
    }
    }else {
    request.setAttribute("loginError", "* 用户不存在");
    request.getRequestDispatcher(request.getContextPath()+"/login.jsp").forward(request, response);
    }

    }

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

}

package login.servlet;

import login.dao.UserDao;
import login.domain.User;

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 java.io.IOException;

/**
 * @description 注册请求处理类
 * @author WANGZIC
 */
@WebServlet("/RegistServlet")
public class RegistServlet extends HttpServlet {

    private static final long serialVersionUID = 1L;

    @Override
    public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        request.setCharacterEncoding("utf-8");
        response.setContentType("text/html;charset=utf-8");
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        String rpsw = request.getParameter("rpsw");
        if(username==null||username.trim().isEmpty()){
            request.setAttribute("registError", "用户名不能为空");
            request.getRequestDispatcher(request.getContextPath()+"/regist.jsp").forward(request, response);
            return;
        }
        if(password==null||password.trim().isEmpty()){
            request.setAttribute("registError", "密码不能为空");
            request.getRequestDispatcher(request.getContextPath()+"/regist.jsp").forward(request, response);
            return;
        }
        if(!password.equals(rpsw)){
            request.setAttribute("registError", "密码不一致");
            request.getRequestDispatcher(request.getContextPath()+"/regist.jsp").forward(request, response);
            return;
        }
        UserDao dao = new UserDao();
        User user =new User();
        user.setUsername(username);
        user.setPassword(password);
        boolean res = dao.insert(user);
        if(res){
            response.sendRedirect(request.getContextPath()+"/index.jsp");
        }else {
            request.setAttribute("registError", "注册失败,该用户名已存在");
            request.getRequestDispatcher(request.getContextPath()+"/regist.jsp").forward(request, response);
        }
    }

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


  • 写回答

1条回答

  • threenewbee 2019-07-15 09:12
    关注

    这种又有表单,又有数据库的程序,建议你调试,或者在关键的地方输出变量,来判断问题在哪里
    比如在dopost里输出username
    如果什么都没有输出,说明根本没有执行,检查网页
    输出的如果不正确,检查参数有没有传入
    如果正确,那么显然就是数据库的问题。

    评论

报告相同问题?

悬赏问题

  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题