愿所有的美好和期待都能如约而至

CloudFlare工作人员-检查Cookie、添加标头、设置Cookie

发布时间:  来源:互联网  作者:匿名  标签:Add Headers cloudflare cloudflare-workers cookies error CloudFlare Workers - Che  热度:37.5℃

本文介绍了CloudFlare工作人员-检查Cookie、添加标头、设置Cookie的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我只想通过CloudFlare workers为第一次访问者动态添加http-Header。例如,这些标题:

Link: </path/to/file.css>; rel=preload; as=style; nopush
Link: </path/to/script.js>; rel=preload; as=script; nopush

因此,我需要在CloudFlare Worker中通过JavaScript实现以下内容:

  1. 检查客户端上是否存在特定Cookie。
  2. 如果Cookie不存在,则添加http-Header,然后设置特定的Cookie。
  3. 如果Cookie确实存在,则不执行任何操作。

您可以使用代码here。

以下是CF博客中的一个通用示例(涉及Cookie和Header):

// A Service Worker which skips cache if the request contains
// a cookie.
addEventListener('fetch', event => {
  let request = event.request
  if (request.headers.has('Cookie')) {
    // Cookie present. Add Cache-Control: no-cache.
    let newHeaders = new Headers(request.headers)
    newHeaders.set('Cache-Control', 'no-cache')
    event.respondWith(fetch(request, {headers: newHeaders}))
  }

  // Use default behavior.
  return
})

推荐答案

以下是一个Cloudflare工作器,它实现了您所描述的内容:

addEventListener('fetch', event => {
  event.respondWith(handle(event.request))
})

async function handle(request) {
  // Check for cookie.
  let cookies = request.headers.get('Cookie') || ""
  if (cookies.includes("returning=true")) {
    // User has been here before. Just pass request through.
    return fetch(request)
  }

  // Forward request to origin, get response.
  let response = await fetch(request)

  // Copy Response object so that we can edit headers.
  response = new Response(response.body, response)

  // Add headers.
  response.headers.append("Link",
      "</path/to/file.css>; rel=preload; as=style; nopush")
  response.headers.append("Link",
      "</path/to/script.js>; rel=preload; as=script; nopush")

  // Set cookie so that we don't add the headers
  // next time.
  response.headers.set("Set-Cookie", "returning=true")

  // Return on to client.
  return response
}

这篇关于CloudFlare工作人员-检查Cookie、添加标头、设置Cookie的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,

勇敢去编程!

勇敢的热爱编程,未来的你一定会大放异彩,未来的生活一定会因编程更好!

TOP