当前位置: 首页 > article >正文

【客户端开发】electron 中无法使用 js-cookie 的问题

产生问题的原因

谷歌浏览器升级之后,出于安全考虑,cookie的SameSite属性默认值由None变为Lax,对于跨域的请求,禁止携带cookie。electron内核是chromium内核,所以也会有这个限制。

Cookie的SameSite属性用来限制第三方 Cookie,从而减少安全风险。它可以设置三个值:Strict、Lax、None

解决方法

基于上述原因,主要有两个解决方案,两个方案的本质其实都是将cookie的SameSite属性设置成None;

服务端设置

我们可以在nginx对应的location请求拦截中改变cookie属性,操作示例如下:

location /api {  
  proxy_pass http://**api/**/api;  
  proxy_set_header X-Real-IP $remote_addr;  
  proxy_set_header X-Scheme $scheme;  
  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  
  proxy_set_header Host $http_host;  
  #proxy_cookie_path /***/api /api;  
  # 解决谷歌浏览器升级后cookie跨域丢失问题  
  proxy_cookie_path /***/api "/api; httponly; SameSite=None";Secure
 }

客户端本地设置(推荐)

elctron 提供了一个可以设置cookie的方法,代码示例如下:

useCookie.js

const { app, session } = require('electron');

/**
 * electron15 后,跨域cookie无法携带,
 * 以下为解决办法
 */
function useCookie() {
    app.whenReady().then(() => {
        const filter = { urls: ['https://*/*'] };
        session.defaultSession.webRequest.onHeadersReceived(filter, (details, callback) => {
            if (details.responseHeaders && details.responseHeaders['Set-Cookie']) {
                for (let i = 0; i < details.responseHeaders['Set-Cookie'].length; i++) {
                    details.responseHeaders['Set-Cookie'][i] += ';SameSite=None;Secure';
                }
            }
            callback({ responseHeaders: details.responseHeaders });
        });
    });
}

module.exports = {
    useCookie,
};

main.js

const { useCookie } = require('./useCookie');
useCookie();

采用浏览器本地存储来存储(推荐)

不要使用 cookie 来存储 token 等信息,采用浏览器的 localStorage 和 seesionStorage 来存储

/** 统一处理 Cookie */

const CacheKey = {
  TOKEN: 'Student-Token',
}
// import Cookies from 'js-cookie'

export const getToken = () => {
  // return Cookies.get(CacheKey.TOKEN)
  return sessionStorage.getItem(CacheKey.TOKEN)
}
export const setToken = (token: string) => {
  // Cookies.set(CacheKey.TOKEN, token)
  sessionStorage.setItem(CacheKey.TOKEN, token)
}
export const removeToken = () => {
  // Cookies.remove(CacheKey.TOKEN)
  sessionStorage.removeItem(CacheKey.TOKEN)
}

参考

electron 升级后,无法携带cookie的问题
electron-vue中使用js-cookie遇到的问题


http://www.kler.cn/a/374361.html

相关文章:

  • Spark的集群环境部署
  • 【Redis】浅析Redis大Key
  • NEEP-EN2-2017-Section4PartA
  • 练习LabVIEW第二十八题
  • STM32F103C8T6 IO 操作
  • 【游戏引擎之路】登神长阶(十一)——C++大师教程:真正的大师,永远保持一颗学徒的心
  • 基于单片机的家用电器电能测量仪设计
  • ElSelect 组件的 onChange 和 onInput 事件的区别
  • 三菱FX5UPLC 安全功能
  • EMQX MQTT消息服务器安装内网穿透配置WS公网地址远程连接
  • C# 编程基础:深入解析构造函数与析构函数
  • ClickHouse 5节点集群安装
  • node.js_npm : 无法加载文件 D:\Program Files\nodejs\npm.ps1
  • 深入了解 Three.js 中的材质与光照
  • 信捷 PLC C语言 简易绝对运动函数BMC_A_DRVA_BODY在POU FC中的使用
  • C++初阶教程——类与对象(中篇)
  • 2024年NSSCTF秋季招新赛-WEB
  • 算法笔记:Day-06(矩阵的顺时针遍历,特定顺序遍历,二维数组的变换)
  • 身份证人像照片验真 API 对接说明
  • Unity发布微信小程序-实战问题汇总
  • 数智驱动,纷享销客助力万东医疗实现精细化管理
  • ZYNQ AXI_Timer 中断
  • 从0学习React(9)
  • 100种算法【Python版】第32篇——Lucas-Lehmer测试
  • 【gRPC】什么是RPC——介绍一下RPC
  • HBM MM CDM HMM ESD TVS 浪涌