国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

node.js - koa 無法將cookie寫入到客戶端

瀏覽:129日期:2024-07-30 14:25:05

問題描述

登錄接口在 api.site.com 下,登錄之后會把用戶的access_token 以cookie 的方式往 site.com 這個域名下寫,但是刷新頁面之后在請求頭里面看不到cookie,this.cookies.get()也是undefined,說明沒有寫成功。

使用的是本地開發(fā)環(huán)境,api.site.com 和 www.site.com 實際上都是 localhost(127.0.0.1),改的host實現(xiàn)的

代碼如下:

if(validateEmail && validateUsername) { let [User] = yield this.db.query(sql, user); let id = User.id const token = yield user.generateAccessToken(id); this.cookies.set(’access_token’, token, {domain: ’.site.com’ }) this.body = User;}

求大神支招

更新

整了個 nginx 代理,問題依然存在

可以在response header 里面看到服務(wù)器端有寫入的 set-cookiesnode.js - koa 無法將cookie寫入到客戶端

但是在瀏覽器的cookies 里面看不到,頁面請求也沒有攜帶這個cookie

問題解答

回答1:

這兩天搜遍了google,so,尼瑪終于找到問題了,覺得非常有必要自己記錄一下。全都是因為這個鬼東西 Request.credentials

The credentials read-only property of the Request interface indicates whether the user agent should send cookies from the other domain in the case of cross-origin requests. This is similar to XHR’s withCredentials flag, but with three available values (instead of two):omit: Never send cookies.same-origin: Only send cookies if the URL is on the same origin as the calling script.include: Always send cookies, even for cross-origin calls.

當我們在發(fā)送跨域請求時,request 的 credentials屬性表示是否允許其他域發(fā)送cookie,該屬性有3個值:omit: 默認屬性,不允許其他域發(fā)送cookiesame-origin: 只允許同域發(fā)送cookieinclude: 總是允許發(fā)送cookie

所以必須在發(fā)送post請求時加上 credentials: include,使用jq的話就是

$.ajax({url: ’http://api.site.com/users’,type: ’POST’,data: postData,xhrFields: { withCredentials: true},success: function (data) { console.log(data)} })

同時在服務(wù)端必須加上:

‘Access-Control-Allow-Credentials’:true

這個問題困擾了好多天,還是讀書太少。。。

回答2:

用token

回答3:

先用瀏覽器F12看一下cookies里面確定有了你放的token

回答4:

朋友我跟你同樣的問題,后臺代碼是

this.cookies.set(’c’, ’3’,{domain:’localhost’,httpOnly:true);

前臺同樣是在response Headers 里面能看到Set-Cookies

你是說后臺

this.cookies.set(’c’, ’3’,{domain:’localhost’,httpOnly:true,’Access-Control-Allow-Credentials’:true})

這樣子改嗎?前端請求怎么辦?我的前端請求是這個樣子的:

$.post('http://localhost:8080/user/userlogin?username='+username+'&password='+password,function(data,status){ alert('Data: ' + data.toString()+ 'nStatus: ' + status); let userinfo = data[0]; $('#txtUsername').html(userinfo.username); $('#txtp').show();});

需要怎么調(diào)整?

相關(guān)文章:
主站蜘蛛池模板: 三级国产在线观看 | 成人免费观看永久24小时 | 性欧美精品| 中日韩一区二区三区 | 日本一级大毛片a一 | 久久精品国产99国产精品亚洲 | 久久免费观看视频 | 久久精品国产精品青草不卡 | 美女毛片视频 | 一级做a爱片久久毛片 | 日韩精品无码一区二区三区 | 欧美成人免费观看的 | 国产天堂 | 97久久天天综合色天天综合色 | 2022年国产精品久久久久 | 国产 日韩 欧美 在线 | 国产伦码精品一区二区 | 日韩欧美综合 | 亚洲综合一区二区精品久久 | 真实的国产乱xxxx | 欧美三级 欧美一级 | 日本黄页免费 | 国产精品99久久免费观看 | 欧美丰满大乳大屁股毛片 | 一级做a爰片久久毛片苍井优 | 高清精品一区二区三区一区 | 女人张开腿男人捅 | 亚洲精品国产三级在线观看 | 黄色毛片免费 | 国产精品成aⅴ人片在线观看 | 中文字幕精品一区二区三区视频 | 亚洲人免费视频 | 国产香蕉98碰碰久久人人 | 狠狠久久综合 | 6080伦理久久精品亚洲 | 欧美一级毛片一级 | 亚洲男女网站 | 亚洲深夜视频 | 韩国啪啪网站 | 欧美成人自拍 | 一本伊大人香蕉高清在线观看 |