Cloudflare Worker OpenAI-Proxy

创建Worker服务->Deploy->Edit Code,代码如下

// 是否拒绝所有无 Origin 请求
const ALLOW_NO_ORIGIN = false;
// 允许的Origin列表
const ALLOWED_ORIGIN = [/^https?:\/\/.*\.example\.com$/, /^https?:\/\/test\.com$/];
const validateOrigin = (req) => {
  const origin = req.headers.get('Origin')
  if (origin) {
    for (let i = 0; i < ALLOWED_ORIGIN.length; i++) {
      if (ALLOWED_ORIGIN[i].exec(origin)) {
        return true
      }
    }
  }
  return ALLOW_NO_ORIGIN
}
export default {
  async fetch(request) {
    if (validateOrigin(request)) {
      const requestUrl = new URL(request.url)
      requestUrl.host = "api.openai.com"
      request = new Request(requestUrl, request)
      //如需前端发送API Key,注释掉下面三行
      if(!request.headers.get('Authorization')){
        request.headers.set('Authorization', 'Bearer sk-your-token')
      }
      return await fetch(request)
    } else {
      return new Response('[CloudFlare Workers] REQUEST NOT ALLOWED', {status: 403});
    }
  }
}

默认配置允许源域名是*.example.com或test.com的请求正常反代,修改ALLOWED_ORIGIN更改允许源域名列表

如修改ALLOW_NO_ORIGIN为true,则不检查源域名,所有请求都正常反代。

注意:默认worker域名国内被干扰,点击触发器->添加自定义域,添加CF里正常使用的域名访问worker.

来源:https://github.com/xqdoo00o/openai-proxy

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

给TA打赏
共{{data.count}}人
人已打赏
杂七杂八

DEBIAN系统装好后必做的

2023-10-17 12:59:34

杂七杂八

给自己的纯html页面加密

2023-10-25 11:44:16