AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 1096429
Accepted
nikc.org
nikc.org
Asked: 2022-03-18 14:14:20 +0800 CST2022-03-18 14:14:20 +0800 CST 2022-03-18 14:14:20 +0800 CST

更新 Varnish ESI 的请求 cookie,包括来自初始 `beresp` 的请求

  • 772

我有一个以 Varnish 服务器为前端的应用程序。部分页面使用 ESI 包含呈现。

我的问题是上游响应包含一个加密的会话 cookie,其中包含一个 CSRF 令牌(根本没有服务器端会话存储)。

对于初始请求(请求中没有 cookie),ESI 请求将不包含由上游服务器的第一个响应设置的 cookie。

我已经尝试req.http.Cookie在vcl_deliver钩子中设置,因为它是请求流中我发现两者都可以读写的唯一req位置res。但是,使用 varnishlog 查看请求会发现 ESI 请求不受影响并且不包含 cookie。

我已尽我所能浏览文档,但找不到任何远程有用的东西。

是否有可能实现我想要的,即更新req以使 ESI 请求包含初始上游响应返回的 cookie?

varnish
  • 0 0 个回答
  • 39 Views

0 个回答

  • Voted
  1. Best Answer
    Thijs Feryn
    2022-03-19T02:23:48+08:002022-03-19T02:23:48+08:00

    我们需要明确区分包含标头的请求和包含Cookie标头的响应Set-Cookie。

    假设 CSRF 令牌是通过父响应的标头设置的,您可能希望通过ESI 子请求中的请求标头Set-Cookie访问该值。Cookie

    假设 Cookie 标头已经包含 CSRF 令牌

    该req_top.http.Cookie变量可以访问父请求的 cookie,但在解析 ESI 占位符的位置req_top无法访问。vcl_backend_response

    您可以使用以下 VCL 片段绕过此限制:

    sub vcl_recv {
        if (req.esi_level > 0 ) {
            set req.http.X-Parent-Cookie = req_top.http.Cookie;
        }
    }
    

    这将启用在throughX-Parent-Cookie中可用的标头。vcl_backend_responsebereq.http.X-Parent-Cookie

    假设 Cookie 标头尚未包含 CSRF 令牌

    假设它req_top.http.Cookie还不包含 CSRF 令牌的值是现实的,因为在处理 ESI 子请求时,Cookie客户端尚未设置标头。

    我能想到的唯一解决方案是将父Set-Cookie值存储在变量中。Varnish 本身不支持变量,需要安装官方的https://github.com/varnish/varnish-modules。

    您必须从源代码编译它。

    有关API 和代码示例,请参阅https://github.com/varnish/varnish-modules/blob/master/src/vmod_var.vcc 。vmod_var

    • 1

相关问题

  • 清漆配置仅缓存未登录用户

  • Varnish 缓存如何处理不同的域?

  • 缩放大文件下载?

  • Gzip 与反向代理缓存

  • 在 Windows XP 主机上使用虚拟化 linux 来宾评估 Varnish 的最简单方法是什么?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve