专业汉语词典知识平台,分享汉字词语知识、历史文学知识解答!

励北网
励北网

什么是cookie,cookie有什么用,cookie详解

来源:小易整编  作者:小易  发布时间:2023-03-03 03:11
摘要:什么是cookie,cookie有什么用,cookie详解Cookie是什么cookie的中文翻译是曲奇,小甜饼的意思。cookie其实就是一些数据信息,类型为“小型文本文件”,存储于电脑上的文本文件中。Cookie有什么用我们想象一个场景...
  • getValue():得到cookie保存的值

  • getName():获取cookie的名字

  • setMaxAge(int expiry):设置cookie的有效期,默认为-1。这个如果设置负数,表示客服端关闭,cookie就会删除。0表示马上删除。正数表示有效时间,单位是秒。

  • setPath(String uri):设置cookie的作用域

HttpServletRequest和HttpServletResponse对Cookie进行操作的常见方法

  • response.addCookie(Cookie cookie):将cookie给客户端进行保存

  • resquest.getCookies():得到客服端传过来的所有cookie对象

Cookie应用实例

我们使用cookie来实现一个功能,就是当用户登录成功后,我们在下次登录时就自动填入用户名和密码。这个功能我们使用cookie和jsp页面来完成(用html页面也可以,只不过要使用javascript,有点麻烦,所以就使用jsp进行演示)

我们首先写一个简单的jsp页面,就是一个登录页面

JSP页面

<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %> <html>  <head>    <title>登录</title>  </head>  <body>  <form action="${pageContext.request.contextPath}/main" method="post">    用户名:<input type="text" name="username" value="<%=request.getAttribute("username")%>"><br/>    密 码:<input type="password" name="password" value="<%=request.getAttribute("password")%>"><br/>    <input type="submit" value="登录">  </form>  </body> </html>

请求转发页面,我们是通过访问Servlet转发到jsp页面的,而不是直接访问。

import javax.servlet.*; import javax.servlet.annotation.WebServlet; import javax.servlet.http.*; import java.io.IOException; @WebServlet("/cookieLogin") public class CookieLogin extends HttpServlet {    @Override    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {        //设置默认值        request.setAttribute("username","");        request.setAttribute("password","");        //得到所有cookie        Cookie[] cookies = request.getCookies();        //对所有cookie进行遍历        for (Cookie cookie : cookies) {            //得到存储用户名和密码的cookie并且存入request域中            if ("username".equals(cookie.getName())){                String value = cookie.getValue();                request.setAttribute("username",value);            }            if("password".equals(cookie.getName())){                String value = cookie.getValue();                request.setAttribute("password",value);            }        }        //转发到login.jsp页面        request.getRequestDispatcher("/login.jsp").forward(request,response);    }    @Override    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {        this.doGet(request, response);    } }

登录成功后的首页

import javax.servlet.*; import javax.servlet.annotation.WebServlet; import javax.servlet.http.*; import java.io.IOException; @WebServlet("/main") public class MainServlet extends HttpServlet {    @Override    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {        //设置响应类型        response.setContentType("text/html;charset=utf-8");        //得到用户名和密码        String username = request.getParameter("username");        String password = request.getParameter("password");        //判断是否登录成功        if ("root".equals(username) && "root".equals(password)) {            //编写cookie            Cookie usernameCookie = new Cookie("username", username);            Cookie passwordCookie = new Cookie("password", password);            //设置有效时间,我这里设置3天有效            usernameCookie.setMaxAge(60 * 60 * 24 * 3);            passwordCookie.setMaxAge(60 * 60 * 24 * 3);            //存入客户端            response.addCookie(usernameCookie);            response.addCookie(passwordCookie);            //返回提示            response.getWriter().write("<h1>登录成功~~~~</h1>");        }else {            response.getWriter().write("<h1>登录失败....</h1>");        }    }    @Override    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {        this.doGet(request, response);    } }

下面我们来进行测试一下,首先访问http://localhost:8080/cs/cookieLogin,我们这里设置的虚拟路径是cs,下面是我们访问cookieLogin显示的页面。发现确实没有自动填写,因为我们还没有登录。游览器中也没有存有用户名和密码的cookie

输入正确的账号和密码进行登录。也就是账号和密码都输入root,页面显示登录成功

下面我们来查看游览器是否存储了用户名和密码的cookie

游览器确实存储了cookie,没有问题,接下来,我们关闭游览器后重新访问登录页面。

我们一访问登录页面,用户名和密码就自动填写了,成功实现了功能

总结

Cookie就是一些数据,用于存储服务器返回给客服端的信息,客户端进行保存。在下一次访问该网站时,客户端会将保存的cookie一同发给服务器,服务器再利用cookie进行一些操作。利用cookie我们就可以实现自动登录,保存游览历史,身份验证等功能。


本文地址:百科问答频道 https://www.neebe.cn/wenda/910817_2.html,易企推百科一个免费的知识分享平台,本站部分文章来网络分享,本着互联网分享的精神,如有涉及到您的权益,请联系我们删除,谢谢!

共2页 1 2 当前是最后一页

百科问答
小编:小易整编
相关文章相关阅读
  • 销售额是什么意思?

    销售额是什么意思?

    销售额是指商业企业的一项关键指标,代表企业在一定时期内的营业额,它实时反映企业经营活动的情况,是衡量企业经营能力和效益的重要指标。销售额可以有多种形式,如零售销售额、批发销售额和出口销售额等。销售额的计算方法很简单,即:销售额=销售数量...

  • iTools是什么意思?

    iTools是什么意思?

    iTools是一款功能强大的苹果设备管理工具。它为苹果设备用户提供了便捷的设备管理功能,包括文件传输、备份还原、应用程序管理、屏幕截图、屏幕录制、音乐管理、视频管理等多种功能,而且支持所有的i系列设备,例如iPod、iPhone和iPad...

  • 无损分区工具是什么意思?

    无损分区工具是什么意思?

    无损分区工具是一种硬盘分区方式,是指在分区时保持原有数据不受损坏的一种分区技术,这种分区技术称为“无损分区”。无损分区可以保护硬盘上的数据,在分区时不会破坏硬盘上的任何数据。而且,在数据安全性上也有一定的优势,因为它不会破坏的数据,因此可...

  • 消费凭证是什么意思?

    消费凭证是什么意思?

    消费凭证是指一种书面的证明凭证,当消费者购买商品或服务时,商家会向其提供消费凭证,凭此凭证可以证明消费者购买了特定的商品或服务,以及在这次购买中耗费的钱财数额。消费凭证是一种用于表示购买交易的依据,是为消费者提供全面鉴证的凭证。它可以表明...

  • DSM系统是什么意思?

    DSM系统是什么意思?

    DSM是一种新晋的分布式、可扩展的模块化系统。它是以无服务器、全节点一致性的系统架构为基础,采用多进程系统将服务、运维功能以模块化的方式集合到一起而不会配置服务的的系统设计模型。DSM的核心特点在于采用了一致性的分布式架构,模块化的结构,...

  • 裸金属是什么意思?

    裸金属是什么意思?

    简而言之,裸金属是指被提取出来,没有被添加任何基材的未加工金属。它是将矿石熔化下去后提炼出来的金属,用来做各种活动和企业的原材料。裸金属通常是一种切削或加工的未经热处理的金属。裸金属一般不经过任何表面处理,以自身属性状态出售。它不会涂以油...

  • CVSS是什么意思?

    CVSS是什么意思?

    CVSS(CommonVulnerabilityScoringSystem,中文译名“公共漏洞评分系统”)是一种漏洞分级和评分系统,是由美国国家信息安全标准研究所(NIST)推行的一套机制,它利用特定的参数来构建一个漏洞评级分类体系...

  • 键盘接口是什么意思?

    键盘接口是什么意思?

    键盘接口一般是用于挂接键盘的接口。它也称为键盘插座或键盘接头,它是一个连接键盘和计算机系统之间的重要硬件部件。键盘接口可以用来接收键盘上发出信号,以便在主板上发出完整的指令。键盘接口可以分为有线和无线两种,有线键盘接口是指采用插孔的连接方...

  • 周排行
  • 月排行
  • 年排行

精彩推荐