您的当前位置:首页VUE前端cookie简单操作实例分享
广告

VUE前端cookie简单操作实例分享

2023-11-30 来源:吉希宠物网

本文主要为大家详细介绍了VUE前端cookie简单操作代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

如下是简单cookie操作,当前仅限前端实例,具体内容如下

要注意的有两点:

1、cookie内容存贮的名称2、删除cookie是通过设置过期为过去时间实现的

<body><p id="app"> <button @click="clearCookie()"> 清除cookie </button></p></body><script> let app = new Vue({ el: "#app", data: { }, created: function () { this.checkCookie(); }, methods: { //设置cookie setCookie: function (cname, cvalue, exdays) { var d = new Date(); d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000)); var expires = "expires=" + d.toUTCString(); console.info(cname + "=" + cvalue + "; " + expires); document.cookie = cname + "=" + cvalue + "; " + expires; console.info(document.cookie); }, //获取cookie getCookie: function (cname) { var name = cname + "="; var ca = document.cookie.split(';'); for (var i = 0; i < ca.length; i++) { var c = ca[i]; while (c.charAt(0) == ' ') c = c.substring(1); if (c.indexOf(name) != -1) return c.substring(name.length, c.length); } return ""; }, //清除cookie clearCookie: function () { this.setCookie("username", "", -1); }, checkCookie: function () { var user = this.getCookie("username"); if (user != "") { alert("Welcome again " + user); } else { user = prompt("Please enter your name:", ""); if (user != "" && user != null) { this.setCookie("username", user, 365); } } } } })</script>

小编还为您整理了以下内容,可能对您也有帮助:

vue 使用 cookie

vue-cookie

第一步:安装vue-cookie

npm install vue-cookie --save

第二步:在 mian.js 引入和通过 Vue.use() 明确地安装

在 main.js 中引入

// require es5 方法

var Vue = require('vue')

Vue.use(require('vue-cookie')) // 挂在在全局了

// es6 方法

import Vue from 'Vue'

import VueCookie from 'vue-cookie'

Vue.use(VueCookie)  // 挂在在全局了

组件中设置一个cookie

// 组件中直接使用 来设置cookie

this.$cookie.set('test', 'Hello world!', 1);

获取一个cookie

// 组件中获取方式

this.$cookie.get('test');      // return value

删除一个cookie

// 删除 cookie

this.$cookie.delete('test');

警告

$ cookie关键名称不能设置为['expires','max-age','path','domain','secure']

vue 使用 cookie

vue-cookie

第一步:安装vue-cookie

npm install vue-cookie --save

第二步:在 mian.js 引入和通过 Vue.use() 明确地安装

在 main.js 中引入

// require es5 方法

var Vue = require('vue')

Vue.use(require('vue-cookie')) // 挂在在全局了

// es6 方法

import Vue from 'Vue'

import VueCookie from 'vue-cookie'

Vue.use(VueCookie)  // 挂在在全局了

组件中设置一个cookie

// 组件中直接使用 来设置cookie

this.$cookie.set('test', 'Hello world!', 1);

获取一个cookie

// 组件中获取方式

this.$cookie.get('test');      // return value

删除一个cookie

// 删除 cookie

this.$cookie.delete('test');

警告

$ cookie关键名称不能设置为['expires','max-age','path','domain','secure']

Web前端新手应该了解的Cookie知识!

今天小编要跟大家分享的文章是关于Web前端新手应该了解的Cookie知识。正准备学习Web前端知识和准备从事Web

前端工作的小伙伴怎么能不了解Cookie。今天小编就为大家带来了这篇文章,让我们一起来看一看Web前端新手应该了解的Cookie知识。

一、Cookie的出现

浏览器和服务器之间的通信少不了HTTP协议,但是因为HTTP协议是无状态的,所以服务器并不知道上一次浏览器做了什么样的操作,这样严重阻碍了交互式Web

应用程序的实现。

针对上述的问题,网景公司的程序员创造了Cookie。

二、Cookie的传输

服务器端在实现Cookie标准的过程中,需要对任意HTTP请求发送Set-CookieHTTP头作为响应的一部分:

1.Set-Cookie:name=value;expires=Tue,03-Sep-201914:10:21GMT;path=/;

domain=.#;

浏览器端会存储这样的Cookie,并且为之后的每个请求添加CookieHTTP请求头发送回服务器:

1.Cookie:name=value

服务器通过验证Cookie值,来判断浏览器发送请求属于哪一个用户。

三、浏览器中的Cookie

浏览器中的Cookie主要由以下几部分组成:

·名称:Cookie唯一的名称,必须经过URL编码处理。(同名会出现覆盖的情况)

·值:必须经过URL编码处理。

·域(domain):默认情况下cookie在当前域下有效,你也可以设置该值来确保对其子域是否有效。

·路径(path):指定Cookie在哪些路径下有效,默认是当前路径下。

·

失效时间(expires):默认情况下,浏览器会话结束时会自动删除Cookie;也可以设置一个GMT格式的日期,指定具体的删除日期;如果设置的日期为以前的日期,那么Cookie会立即删除。

·安全标志(secure):指定之后只允许Cookie发送给https协议。

浏览器在发送请求时,只会将名称与值添加到请求头的Cookie字段中,发送给服务端。

浏览器提供了一个非常蹩脚的API来操作Cookie:

1.document.cookie

通过上述方法可以对该Cookie进行写操作,每一次只能写入一条Cookie字符串:

1.document.cookie='a=1;secure;path=/'

通过该方法还可以进行Cookie的读操作:

1.document.cookie//"a=1"

由于上述方法操作Cookie非常的不直观,一般都会写一些函数来简化Cookie读取、设置和删除操作。

对于Cookie的设置操作中,需要以下几点:

对于名称和值进行URL编码处理,也就是采用JavaScript中的encodeURIComponent()方法;

expires要求传入GMT格式的日期,需要处理为更易书写的方式,比如:设置秒数的方式;注意只有的属性名的secure;

每一段信息需要采用分号加空格。

1.functionsetCookie(key,value,attributes){

2.if(typeofdocument==='undefined'){

3.return

4.}

5.attributes=Object.assign({},{

6.path:'/'

7.},attributes)

8.

9.let{domain,path,expires,secure}=attributes

10.

11.if(typeofexpires==='number'){

12.expires=newDate(Date.now()+expires*1000)

13.}

14.if(expiresinstanceofDate){

15.expires=expires.toUTCString()

16.}else{

17.expires=''

18.}

19.

20.key=encodeURIComponent(key)

21.value=encodeURIComponent(value)

22.

23.letcookieStr=`${key}=${value}`

24.

25.if(domain){

26.cookieStr+=`;domain=${domain}`

27.}

28.

29.if(path){

30.cookieStr+=`;path=${path}`

31.}

32.

33.if(expires){

34.cookieStr+=`;expires=${expires}`

35.}

36.

37.if(secure){

38.cookieStr+=`;secure`

39.}

40.

41.return(document.cookie=cookieStr)

42.}

Cookie的读操作需要注意的是将名称与值进行URL解码处理,也就是调用JavaScript中的decodeURIComponent()方法:

1.functiongetCookie(name){

2.if(typeofdocument==='undefined'){

3.return

4.}

5.letcookies=[]

6.letjar={}

7.document.cookie&&(cookies=document.cookie.split(';'))

8.

9.for(leti=0,max=cookies.length;i10.let[key,value]=cookies[i].split('=')

11.key=decodeURIComponent(key)

12.value=decodeURIComponent(value)

13.jar[key]=value

14.if(key===name){

15.break

16.}

17.}

18.

19.returnname?jar[name]:jar

20.}

最后一个清除的方法就更加简单了,只要将失效日期(expires)设置为过去的日期即可:

1.functionremoveCookie(key){

2.setCookie(key,'',{expires:-1})

3.}

介绍Cookie基本操作的封装之后,还需要了解浏览器为了Cookie不会被恶意使用,规定了Cookie所占磁盘空间的大小以及每个域名下Cookie的个数。

四、服务端的Cookie

相比较浏览器端,服务端执行Cookie的写操作时,是将拼接好的Cookie字符串放入响应头的Set-Cookie字段中;执行Cookie的读操作时,则是解析HTTP请求头字段Cookie中的键值对。

与浏览器最大的不同,在于服务端对于Cookie的安全性操碎了心

signed

当设置signed=true时,服务端会对该条Cookie字符串生成两个Set-Cookie响应头字段:

1.Set-Cookie:lastTime=2019-03-05T14:31:05.543Z;path=/;httponly

2.Set-Cookie:lastTime.sig=URXREOYTtMnGm0b7qCYFJ2Db400;path=/;

httponly

这里通过再发送一条以.sig为后缀的名称以及对值进行加密的Cookie,来验证该条Cookie是否在传输的过程中被篡改。

httpOnly

服务端Set-Cookie字段中新增httpOnly属性,当服务端在返回的Cookie信息中含有httpOnly字段时,开发者是不能通过JavaScript来操纵该条Cookie字符串的。

这样做的好处主要在于面对XSS(Cross-sitescripting)攻击时,黑客无法拿到设置httpOnly字段的Cookie信息。

此时,你会发现localStorage相比较Cookie,在XSS攻击的防御上就略逊一筹了。sameSite

在介绍这个新属性之前,首先你需要明白:当用户从#发起#的请求也会携带上Cookie,而从#携带过来的Cookie称为第三方Cookie。

虽然第三方Cookie有一些好处,但是给CSRF(Cross-siterequestforgrey)攻击的机会。

为了从根源上解决CSRF攻击,sameSite属性便闪亮登场了,它的取值有以下几种:

·

strict:浏览器在任何跨域请求中都不会携带Cookie,这样可以有效的防御CSRF攻击,但是对于有多个子域名的网站采用主域名存储用户登录信息的场景,每个子域名都需要用户重新登录,造成用户体验非常的差。

·lax:相比较strict,它允许从三方网站跳转过来的时候使用Cookie。

为了方便大家理解sameSite的实际效果,可以看这个例子:

1.//#服务端会在访问页面时返回如下Cookie

2.cookies.set('foo','aaaaa')

3.cookies.set('bar','bbbbb')

4.cookies.set('name','cccccc')

5.

6.//#服务端会在访问页面时返回如下Cookie

7.cookies.set('foo','a',{sameSite:'strict'})

8.cookies.set('bar','b',{sameSite:'lax'})

9.cookies.set('baz','c')

如何现在用户在#中点击链接跳转到#,它的请求头是这样的:

1.RequestHeaders

2.

3.Cookie:bar=b;baz=c

五、网站性能优化

Cookie在服务端和浏览器的通信中,主要依靠HTTP的响应头和请求头传输的,所以Cookie会占据一定的带宽。

前面提到浏览器会为每一次HTPP请求自动携带上Cookie信息,但是对于同站内的静态资源,服务器并不需要处理其携带的Cookie,这无形中便浪费了带宽。

在最佳实践中,一般都会将静态资源部署到的域名上,从而可以避免无效Cookie的影响。

以上就是小编今天为大家分享的关于Web前端新手应该了解的Cookie知识,希望本篇文章能够对正在从事Web前端工作和准备从事Web

前端学习的小伙伴们有所帮助。想要了解更多Web前端相关知识记得关注北大青鸟Web培训官网!

作者|descire

来源|#/article/286535

*声明:内容与图片均来源于网络(部分内容有修改),版权归原作者所有,如来源信息有误或侵犯权益,请联系我们删除或授权事宜

vue+cookie什么时候可以共享

什么时候可以分享vue获取cookie,如何设置cookie?要设置cookie的文件名cookieUtils.js///* * * *设置cookie *名称cookie *值cookie *到期时间cookie */导出常量设置cookie = function(name,value,day) {if (day!== 0) {//当设置的时间等于0时,不设置expires属性,浏览器关闭后cookie删除var curDate = new Date();var curt amp = curdate . gettime();var curWeeHours =新日期(curDate.toLocaleDateString())。getTime()-1;var passed tamp = curt amp-curweehors;var left tamp = 24 * 60 * 60 * 1000-passed tamp;var left time = new Date();left time . settime(left tamp+curt amp);document . cookie = name+" = "+escape(value)+";expires = "+left time . togmtstring();} else { document . cookie = name+" = "+escape(value);} }/* * * Get cookie */export const Get cookie = function(name){ var arr;var reg =新RegExp("(^| )" +姓名+" =([^;]*)(;|$)");if (arr = document.cookie.match(r

吉希宠物网还为您提供以下相关内容希望对您有帮助:

vue项目开发中什么时候用cookie什么时候用sessionstorage?

1,首先加载模块 npm i js-cookie -S 2,在使用cookie的页面上进行引入 import Cookies from 'js-cookie'3,使用方法 创建一个在整个网站上有效的Cookie Cookies.set('name', 'value');创建一个从现在起7天后过期的c...

登录、注册及cookie

1.1注册成功直接跳转到登录页 cookie.js为公共方法,用于cookie的存储、获取及删除 home.vue为用户登录成功之后的主页 login.vue为登录注册页 main.vue为后台管理页 项目整体文件结构如下 cookie.js为公共方法,用于cookie的存...

vue中token存入cookie

1.npm i js-cookie //安装 2.import Cookies from 'js-cookie' //引用 // 存入cookie:Cookies.set('token','value')// 获取cookie:Cookies.get('token')//删除cookie:Cookies.remove('token')

js获取cookie里面的token

1. 最近得到一个新需求,需要在后台管理页面加上用户权限控制,通过后台放在cookie里面的token进行判断;2. 获取cookie里面的token:    2.1 我们在用vue.js里面的index.html写一个全局的函数:   ...

vue前端cookie如何读取到中文

//设置cookie,增加到vue实例方便全局调用 export function setCookie (c_name, value, expiredays) { var exdate = new Date();exdate.setDate(exdate.getDate() + expiredays);document.cookie = c_name + "=" + ...

一篇文章带你走进cookie,session,Token的世界

实际上cookie不能跨站(同源策略)被取出,因此可以避免 csrf 攻击。(适用于 ajax请求或者 api请求,可以方便的设置 auth头)5、Token处理过期时间 在我的vue项目中,我将Token存储在了localStorage中,有处理过Token过期,我...

怎样让cookie自动获取和过期自动更新

1,在线获取cookie采用selenium + PhantomJS 模拟浏览器登录,获取cookie;cookies一般会有多个,逐个将cookie存入以.weibo后缀的文件。def get_cookie_from_network(): from selenium import webdriver url_login = 'http://...

vue项目cookie问题,线上同域可以,但本机代理方式不行

跨域才可以带过去。原因:cookie只能在自已域设置cookie,所以本地和服务端是不同域,无法得到。所以要使用第一种方式得到cookie的值,然后在本地域localhost设置cookie,然后再设置axios可以进行跨域发送,这样来解决问题。

vue cookie 插件怎么用

在HTTP协议的定义中,采用了一种机制来记录客户端和服务器端交互的信息,这种机制被称为cookie,cookie规范定义了服务器和客户端交互信息的格式、生存期、使用范围、安全性。在JavaScript中可以通过 document.cookie 来读取或设置...

vue项目中每次发送请求set-cookie都发生变化,导致验证码无法通过 前 ...

两种可能,一是http request中没有携带之前发给你的cookie,导致后端总认为是新的端来请求,因此set-cookie总是新的。二是服务端自己实现得有问题。一般来说第一种可能性更高,你的截图没发全,看下http request中有没有...

Top