首页 > 其他分享 >JSP改造Cookie案例以及Session的快速入门

JSP改造Cookie案例以及Session的快速入门

时间:2022-12-11 20:15:17浏览次数:50  
标签:cookie name Session request value session Cookie date JSP

JSP改造Cookie案例以及Session的快速入门

<%@ page import="java.util.Date" %>
<%@ page import="java.text.SimpleDateFormat" %>
<%@ page import="java.net.URLEncoder" %>
<%@ page import="java.net.URLDecoder" %>
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>itcast</title>
</head>
<body>

<%

    //1..获取所有的Cookie
    Cookie[] cookies = request.getCookies();
    boolean flag = false;//没有cookie为lastTime

    //2.遍历Cookie数组
    if (cookies != null && cookies.length > 0){
        for (Cookie cookie : cookies) {
            //3.获取cookie的名称
            String name = cookie.getName();
            //4.判断名称是否是:lastTime
            if ("lastTime".equals(name)){
                //有该cookie,不是第一次访问
                flag = true;//有lastTime的cookie
                //设置Cookie的value
                //获取当前时间的字符串,重新设置Cookie的值,重新发送cookie
                Date date = new Date();
                SimpleDateFormat format = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");//更改为中国格式的时间
                String str_date = format.format(date);

                //URL编码
                System.out.println("编码前:"+str_date);
                str_date = URLEncoder.encode(str_date, "UTF-8");
                System.out.println("编码后:"+str_date);

                cookie.setValue(str_date);
                //设置cookie存活时间
                cookie.setMaxAge(60 * 60 * 24 * 30);//一个月

                response.addCookie(cookie);//发送cookie

                //响应数据
                //获取cookie的value,时间
                String value = cookie.getValue();
                System.out.println("解码前:"+value);
                //URL解码
                value = URLDecoder.decode(value, "utf-8");
                System.out.println("解码后:"+value);

%>

                <h1>欢迎回来,您上次访问时间为:<%=value%>></h1>

<%


                //找到直接停止
                break;
            }
        }
    }

    if (cookies == null || cookies.length == 0 || flag == false ){
        //没有,第一次访问

        //设置Cookie的value
        //获取当前时间的字符串,重新设置Cookie的值,重新发送cookie
        Date date = new Date();
        SimpleDateFormat format = new SimpleDateFormat("yyyy年MM月dd日 HH:mm:ss");//更改为中国格式的时间
        String str_date = format.format(date);

        //URL编码
        System.out.println("编码前:"+str_date);
        str_date = URLEncoder.encode(str_date, "UTF-8");
        System.out.println("编码后:"+str_date);

        Cookie cookie = new Cookie("lastTime", str_date);
        //设置cookie存活时间
        cookie.setMaxAge(60 * 60 * 24 * 30);//一个月
        response.addCookie(cookie);//发送cookie

%>
        <h1>您好,欢迎您首次访问</h1>
<%
    }
%>
</body>
</html>

 

Session的快速入门

概念:服务器端会话技术,在一次会话的多次请求间共享数据,将数据保存在服务器端的对象中,HttpSession

快速入门:

  1.获取Session对象

HttpSession session = request.getSession();

  2.使用HttpSession对象:

    Object getAttribute(String name)

    void setAttribute(String name,Object value)

    void removeAttribute(String name)

session存储数据:

@WebServlet(name = "SessionDemo1", value = "/SessionDemo1")
public class SessionDemo1 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //使用Session共享数据

        //1.获取session
        HttpSession session = request.getSession();
        //2.存储数据
        session.setAttribute("msg", "hello session");
    }
}

 

session获取数据

@WebServlet(name = "SessionDemo2", value = "/SessionDemo2")
public class SessionDemo2 extends HttpServlet {
    @Override
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }

    @Override
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //使用Session共享数据

        //1.获取session
        HttpSession session = request.getSession();
        //2.获取数据
        Object msg = session.getAttribute("msg");
        System.out.println(msg);

    }
}

 

标签:cookie,name,Session,request,value,session,Cookie,date,JSP
From: https://www.cnblogs.com/qihaokuan/p/16974300.html

相关文章

  • vue无法获取flask设置的cookie
    最近在使用vue3开发基于flask后端的前后端分离项目时候,设置路由守卫时一直无法获取到登录后的cookie中session值但是在浏览器中却可以看到cookie先上代码router.befor......
  • JSP的脚本以及JSP的入门学习
    JSP的脚本以及JSP的入门学习JSP的脚本:JSP定义java代码方式1.<%代码%>:定义的java代码,在service方法中,service方法中可以定义什么,该脚本中就可以定义什么,2.<%!......
  • JSP_概念以及原理
    JSP_概念以及原理 概念:JSP(JavaServlerPages):其本质就是一个Servlet 。一般将Servlet和jsp结合使用,servlet负责业务,jsp负责显示。可以理解为:一个特殊的页面,其中既......
  • cookie&session使用方式
    cookie:数据存在客户端(浏览器),长期储存session:数据存在服务器,默认保存30分钟cookie使用方式:  1.创建cookie对象并用response发送Cookiecookie=newCookie("us......
  • Cookie分析以及案例
    Cookie分析以及案例案例:记住上一次访问时间1.需求:1.访问一个Servlet,如果是第一次访问,则提示:您好,欢迎您首次访问。 2.如果不是第一次访问,则提示:......
  • Django只session
    1.session流程2.添加sessiondefindex(request):#添加sessionrequest.session["set_session"]="defaulit001"returnHttpResponse("测试效能")设置s......
  • Cookie共享以及Cookie的特点和作用
    Cookie共享以及Cookie的特点和作用Cookie共享问题:假设在一个tomcat服务器中,部署了多个web项目,那么在这些web项目中cookie能不能共享?默认情况下cookie不能共......
  • Django之Cookies
    一cookies简述Cookie的由来大家都知道HTTP协议是无状态的。无状态的意思是每次请求都是独立的,它的执行情况和结果与前面的请求和之后的请求都无直接关系,它不会受前面的请......
  • Cookie存活时间以及Cookie存储中文
    Cookie存活时间以及Cookie存储中文 cookie在浏览器中保存多长时间:1.默认情况下,当浏览器关闭后,Cookie数据被销毁2.持久化存储:setMaxAge(int seconds)......
  • java-net-php-python-jsp大学生兼职管理系统计算机毕业设计程序
    OverridetheentrypointofanimageIntroducedinGitLabandGitLabRunner9.4.Readmoreaboutthe extendedconfigurationoptions.Beforeexplainingtheav......