【Java】【cookie和session】通過session實(shí)現(xiàn)登陸

  1. com.stu.demo.Entity
package com.stu.com.stu.entity;

public class User {
private String uid;
private String pwd;

public String getUid() {
    return uid;
}

public void setUid(String uid) {
    this.uid = uid;
}

public String getPwd() {
    return pwd;
}

public void setPwd(String pwd) {
    this.pwd = pwd;
}

@Override
public String toString() {
    return "User{" +
                   "uid='" + uid + '\'' +
                   ", pwd='" + pwd + '\'' +
                   '}';
}

@Override
public boolean equals(Object o) {
    if (this == o) return true;
    if (o == null || getClass() != o.getClass()) return false;

    User user = (User) o;

    if (uid != null ? !uid.equals(user.uid) : user.uid != null) return false;
    return pwd != null ? pwd.equals(user.pwd) : user.pwd == null;

}

@Override
public int hashCode() {
    int result = uid != null ? uid.hashCode() : 0;
    result = 31 * result + (pwd != null ? pwd.hashCode() : 0);
    return result;
}
}

  1. com.stu.demo.Login
package com.stu.demo;

import com.stu.com.stu.entity.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 javax.servlet.http.HttpSession;
import java.io.IOException;
import java.io.PrintWriter;

@WebServlet(name = "LoginServlet")
public class LoginServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    
}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    request.setCharacterEncoding("utf-8");
    response.setContentType("text/html; charset=utf-8");
    PrintWriter out = response.getWriter();
    HttpSession session = request.getSession();

    // 讀取session
    User user = (User) session.getAttribute("user");
    if (user != null) {
        System.out.println(user);
        out.print("<h1>已經(jīng)登陸</h1><br>");
        out.print("<a href='" + request.getContextPath() + "/doLogin'>退出登陸</a>");
    } else {
        out.print("<form action='/doLogin' method='post'>");
        out.print("<label>賬號(hào):<input type='text' placeholder='賬號(hào)' name='uid'></label><br>");
        out.print("<label>密碼:<input type='password' placeholder='密碼' name='pwd'></label><br>");
        out.print("<button>登陸</button><br>");
        out.print("</form>");
    }
}
}

  1. com.stu.demo.DoLogin
package com.stu.demo;

import com.stu.com.stu.entity.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 javax.servlet.http.HttpSession;
import java.io.IOException;
import java.io.PrintWriter;

@WebServlet(name = "DoLoginServlet")
public class DoLoginServlet extends HttpServlet {
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    request.setCharacterEncoding("utf-8");
    response.setContentType("text/html; charset=utf-8");
    PrintWriter out = response.getWriter();
    HttpSession session = request.getSession();
    
    // 獲取賬號(hào)密碼
    String uid = request.getParameter("uid");
    String pwd = request.getParameter("pwd");
    if (uid.equals("123") && pwd.equals("321")) {
        // 登陸成功,將用戶信息保存到session
        User user = new User();
        user.setUid(uid);
        user.setPwd(pwd);
        session.setAttribute("user", user);
        session.setMaxInactiveInterval(60 * 15);
        out.print("<h1>登陸成功</h1>");
    } else {
        // 登陸失敗
        out.print("<h1>賬號(hào)或密碼不匹配</h1>");
        response.setHeader("refresh", "2;url=" + request.getContextPath() + "/login");
    }
}

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    request.setCharacterEncoding("utf-8");
    response.setContentType("text/html; charset=utf-8");
    PrintWriter out = response.getWriter();
    HttpSession session = request.getSession();
    
    // 清除session
    session.removeAttribute("user");
    // 或使用(刪除整個(gè)session)
    // session.invalidate();
    out.print("<h1>退出成功</h1>");
    response.setHeader("refresh", "2;url=" + request.getContextPath() + "/login");
}
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一套完整的登陸注冊(cè)業(yè)務(wù)邏輯 準(zhǔn)備部分基礎(chǔ)工具類Basepackage com.jericho.tools;impo...
    JerichoPH閱讀 2,550評(píng)論 0 9
  • 本文包括:1、Filter簡(jiǎn)介2、Filter是如何實(shí)現(xiàn)攔截的?3、Filter開發(fā)入門4、Filter的生命周期...
    廖少少閱讀 7,523評(píng)論 3 56
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語(yǔ)法,類相關(guān)的語(yǔ)法,內(nèi)部類的語(yǔ)法,繼承相關(guān)的語(yǔ)法,異常的語(yǔ)法,線程的語(yǔ)...
    子非魚_t_閱讀 34,728評(píng)論 18 399
  • 本文包括:1、Listener簡(jiǎn)介2、Servlet監(jiān)聽器3、監(jiān)聽三個(gè)域?qū)ο髣?chuàng)建和銷毀的事件監(jiān)聽器4、監(jiān)聽三個(gè)域?qū)?..
    廖少少閱讀 6,653評(píng)論 6 28
  • 本文包括:1、什么是自動(dòng)登錄?2、簡(jiǎn)書自動(dòng)登錄流程3、實(shí)現(xiàn)自動(dòng)登錄4、用戶注銷 1、什么是自動(dòng)登錄? 就拿簡(jiǎn)書做例...
    廖少少閱讀 6,212評(píng)論 1 27

友情鏈接更多精彩內(nèi)容