JavaWeb25(SMBMS项目搭建02)

登录功能实现

登录功能流程图

在这里插入图片描述

1.编写登陆界面并设置为首页

<%@ page language="java" contentType="text/html; charset=UTF-8"
         pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <title>系统登录 - 超市订单管理系统</title>
    <link type="text/css" rel="stylesheet" href="${pageContext.request.contextPath }/css/style.css" />
    <script type="text/javascript">
        /* if(top.location!=self.location){
              top.location=self.location;
         } */
    </script>
</head>
<body class="login_bg">
<section class="loginBox">
    <header class="loginHeader">
        <h1>超市订单管理系统</h1>
    </header>
    <section class="loginCont">
        <form class="loginForm" action="${pageContext.request.contextPath }/login.do"  name="actionForm" id="actionForm"  method="post" >
            <div class="info">${error}</div>
            <div class="inputbox">
                <label for="userCode">用户名:</label>
                <input type="text" class="input-text" id="userCode" name="userCode" placeholder="请输入用户名" required/>
            </div>
            <div class="inputbox">
                <label for="userPassword">密码:</label>
                <input type="password" id="userPassword" name="userPassword" placeholder="请输入密码" required/>
            </div>
            <div class="subBtn">

                <input type="submit" value="登录"/>
                <input type="reset" value="重置"/>
            </div>
        </form>
    </section>
</section>
</body>
</html>

将login.jsp设置为首页
在web.xml中将其设置为欢迎页

    <welcome-file-list>
        <welcome-file>login.jsp</welcome-file>
    </welcome-file-list>

2.编写Dao层用户登陆的接口

package com.hao.dao.user;

import com.hao.pojo.User;

import java.sql.Connection;
import java.sql.SQLException;

public interface UserDao {
    
    
    //得到要登陆的用户
    public User getLoginUser(Connection connection, String userCode) throws SQLException;
}

3.编写Dao层用户登录接口的实现类

package com.hao.dao.user;

import com.hao.dao.BaseDao;
import com.hao.pojo.User;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

//实现接口的方法
public class UserDaoImpl implements UserDao {
    
    
//得到要登陆的用户
    public User getLoginUser(Connection connection, String userCode) throws SQLException {
    
    
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        User user = null ;
        if (connection!=null){
    
    
            String sql = "select * from smbms_user where userCode=?";
            Object[] params ={
    
    userCode};

                resultSet= BaseDao.execute(connection, preparedStatement, resultSet, sql, params);
                if (resultSet.next()){
    
    
                    user = new User();
                    user.setId(resultSet.getInt("id"));
                    user.setUserCode(resultSet.getString("userCode"));
                    user.setUserName(resultSet.getString("userName"));
                    user.setUserPassword(resultSet.getString("userPassword"));
                    user.setGender(resultSet.getInt("gender"));
                    user.setBirthday(resultSet.getDate("birthday"));
                    user.setPhone(resultSet.getString("phone"));
                    user.setAddress(resultSet.getString("address"));
                    user.setUserRole(resultSet.getInt("userRole"));
                    user.setCreateBy(resultSet.getInt("createdBy"));
                    user.setCreateDate(resultSet.getDate("creationDate"));
                    user.setModifyBy(resultSet.getInt("modifyBy"));
                    user.setModifyDate(resultSet.getDate("modifyDate"));
                    BaseDao.closeResources(null,preparedStatement,resultSet);
                }
            }
        return user;
        }
}

4.业务层接口

package com.hao.service.user;

import com.hao.pojo.User;

public interface UserService {
    
    
    public User login(String userCode,String password);
}

5.业务层接口实现类

package com.hao.service.user;

import com.hao.dao.BaseDao;
import com.hao.dao.user.UserDao;
import com.hao.dao.user.UserDaoImpl;
import com.hao.pojo.User;
import org.junit.Test;

import java.sql.Connection;
import java.sql.SQLException;

public class UserServiceImpl implements UserService{
    
    
    //业务层都会调用Dao层,所以要引入Dao层;
    private UserDao userDao;
    public UserServiceImpl(){
    
    
        userDao=new UserDaoImpl();
    }
    public User login(String userCode, String password) {
    
    
        Connection connection = null;
        User user = null;
        try {
    
    
            connection = BaseDao.getConnection();
            //通过业务层调用对应的具体数据库操作
            user=userDao.getLoginUser(connection,userCode);
        } catch (SQLException throwables) {
    
    
            throwables.printStackTrace();
        }finally {
    
    
            BaseDao.closeResources(connection,null,null);
        }
        return user;
    }

6.编写Servlet

package com.hao.servlet.user;

import com.hao.pojo.User;
import com.hao.service.user.UserServiceImpl;
import com.hao.util.Constants;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

public class LoginServlet extends HttpServlet {
    
    
   //Servlet:控制层,需要调用业务层代码
   @Override
   protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    
    
       doPost(req, resp);
   }

   @Override
   protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
    
    
       //获取用户名和密码
       //根据前端的name,输入关键字
       String userCode = req.getParameter("userCode");
       String userPassword = req.getParameter("userPassword");
       UserServiceImpl userService = new UserServiceImpl();
       User user = userService.login(userCode,userPassword);//将用户查出,如果数据库中没有,则为null
       if (user!=null){
    
    //数据库中有这个人
           //把用户信息存入session
           req.getSession().setAttribute(Constants.USER_SESSION,user);
           //跳转到主页
           resp.sendRedirect("jsp/frame.jsp");
       }else {
    
    //返回登录界面 数据库中没有该用户 或者账号密码错误
           req.setAttribute("error","用户名或密码错误");
           req.getRequestDispatcher("login.jsp").forward(req,resp);
       }


   }
}

在web.xml中注册

<!--    Servlet-->
    <servlet>
        <servlet-name>ServletLogin</servlet-name>
        <servlet-class>com.hao.servlet.user.LoginServlet</servlet-class>
    </servlet>
    <servlet-mapping>
        <servlet-name>ServletLogin</servlet-name>
        <url-pattern>/login.do</url-pattern>
    </servlet-mapping>

测试访问

在这里插入图片描述

输入正确账号密码后

在这里插入图片描述
时间乱码 后面加个过滤器再处理

输入错误账号密码后

在这里插入图片描述
登录框架基本完成

猜你喜欢

转载自blog.csdn.net/qq_51224492/article/details/119951721