jsp基础之--使用Session完成简单的登陆操作

 项目地址:https://gitee.com/martinHuang/jsp-basic-LoginDemo

今天来说说Session,Session也叫实域,能够保存一些信息,并且再页面跳转的时候不会丢失,常用作登陆,可以保存已经登陆用户的信息。今天就利用Session在不连接数据库的情况下实现简单的登陆操作。

  在jsp中,session被作为一个独立的接口存在,叫做HttpSession

  我们要用到的是设置Session,设置Session的过期时间,获取Session的值,移除Session,分别对应以下方法

jsp基础之--使用Session完成简单的登陆操作_第1张图片

setAttribute表示设置Session,第一个参数是Session的名称,第二个是其值,注意,要是一个对象。红框的意思是说,如果有两个同名的Session,先创建的将被后创建的覆盖

jsp基础之--使用Session完成简单的登陆操作_第2张图片

setMaxInactiveInterval表示设置Session的最大失效时间,就是说设置存活多少时间后失效,后面的参数是一个int值,以秒为单位

jsp基础之--使用Session完成简单的登陆操作_第3张图片

getAttribute表示获取Session的值,后面的参数是一个String值,表示要获取的Session名称,该方法返回一个Object对象,如果该Session不存在,返回null

  jsp基础之--使用Session完成简单的登陆操作_第4张图片

  removeAttribute表示移除Session,后面的参数是一个String值,表示要移除的Session名称

现在让我们开始吧~

1、新建一个Dynamic Web Project,名叫login_logout

jsp基础之--使用Session完成简单的登陆操作_第5张图片

2、在工程名点右键,新建一个类,名为login,来执行登陆操作

jsp基础之--使用Session完成简单的登陆操作_第6张图片

login.java内容如下

package login_logout;
public class login 
{
	public boolean Login(String name , String password)
	{
		if(name.equals("abc") && password.equals("123456"))
		{
			return true;
		}
		else
		{
			return false;
		}
	}
}

login方法的作用是比对用户名和密码和预设的是否一致,一致返回true,不一致返回false

3、在WebContent下新建login.jsp页面,这个就是用户看到的第一屏页面了

      login.jsp页面内容如下

    

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>




简单的登陆界面


   





jsp基础之--使用Session完成简单的登陆操作_第7张图片

4、在WebContent文件夹下新建文件夹,叫jspCode,在该文件夹下新建login_code.jsp文件,login_code.jsp文件内容如下

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<%@ page import="login_logout.*" %>
<% 
   login in = new login();
   String name = request.getParameter("user");
   String pass = request.getParameter("password");
   boolean isLoginSucc = in.Login(name, pass);
   if(isLoginSucc)
   {
	   out.println("");
	   session.setAttribute("user", name);
	   session.setMaxInactiveInterval(60);
   }
   else
   {
	   out.println("");
   }
%>

这里就用到了前面说的设置session的值,设置存活时间的方法了,这里我设置为1分钟

5、在WebContent目录下新建index.jsp页面,为用户登陆成功后所看到的页面,代码如下

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>




欢迎


  <%
    if(session.getAttribute("user") == null)
    {
    	out.println("");
    	return;
    }
    Object user = session.getAttribute("user");
    out.println("欢迎"+user);
  %>
  

6、在前面创建好的jspCode文件夹下新建logout.jsp文件,用于登出操作,内容如下

  

<%@ page language="java" contentType="text/html; charset=utf-8"
    pageEncoding="utf-8"%>
<%
  session.removeAttribute("user");
  out.println("");
%>

这里用到了移除session的方法

7、测试运行

jsp基础之--使用Session完成简单的登陆操作_第8张图片

输入预置的用户名和密码,显示登陆成功,并跳转页面

jsp基础之--使用Session完成简单的登陆操作_第9张图片

jsp基础之--使用Session完成简单的登陆操作_第10张图片

点击登出也正常登出

jsp基础之--使用Session完成简单的登陆操作_第11张图片

重新登陆等待1分钟后刷新页面

jsp基础之--使用Session完成简单的登陆操作_第12张图片

jsp基础之--使用Session完成简单的登陆操作_第13张图片

成功失效了~

回到登陆界面,输入错误的用户名和密码

jsp基础之--使用Session完成简单的登陆操作_第14张图片

jsp基础之--使用Session完成简单的登陆操作_第15张图片

OK~

最后的文件目录如下

jsp基础之--使用Session完成简单的登陆操作_第16张图片

呃...本人学生党,如果讲的不好,讲的啰嗦的话还请大家多多包含~

你可能感兴趣的:(jsp基础)