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