banner
Bai

Bai

写代码菜的一批 🤣
twitter
telegram
tg_channel
pixiv
github
bilibili
whatsapp

CloudFlare Worker逆プロキシOpenai

主要解決被官網攔截和國內不能訪問慢的問題#

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

async function fetchAndApply(request) {

    let response = null;
    let method = request.method;


    let url = new URL(request.url);
    let url_hostname = url.hostname;
    url.protocol = 'https:';
    url.host = 'api.openai.com';


    let request_headers = request.headers;
    let new_request_headers = new Headers(request_headers);
    new_request_headers.set('Host', url.host);
    new_request_headers.set('Referer', url.protocol + '//' + url_hostname);

   
   
    let original_response = await fetch(url.href, {
        method: method,
        headers: new_request_headers,
        body: request.body
    })
  

    let original_response_clone = original_response.clone();
    let original_text = null;
    let response_headers = original_response.headers;
    let new_response_headers = new Headers(response_headers);
    let status = original_response.status;

    new_response_headers.set('Cache-Control', 'no-store');
    new_response_headers.set('access-control-allow-origin', '*');
    new_response_headers.set('access-control-allow-credentials', true);
    new_response_headers.delete('content-security-policy');
    new_response_headers.delete('content-security-policy-report-only');
    new_response_headers.delete('clear-site-data');

    original_text = original_response_clone.body
    response = new Response(original_text, {
        status,
        headers: new_response_headers
    })

    return response

}

** 虽然可以实现,但会导致账号被封建议使用自己的 vps 反向代理 **

Nginx 配置反向代理#

  1. 打开 Nginx 配置文件(通常是 /etc/nginx/nginx.conf)。
  2. 在 http 块内添加以下代码:
server {
    listen 80;
    server_name yourdomain.com; # 替换为您自己的域名

    location / {
        return 301 https://$host$request_uri;
    }
}

server {
    listen 443 ssl;
    server_name yourdomain.com; # 替换为您自己的域名

    ssl_certificate /path/to/your/certificate.crt;
    ssl_certificate_key /path/to/your/certificate.key;

    location / {
        proxy_pass https://api.openai.com;
         proxy_set_header Host api.openai.com;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        add_header 'Access-Control-Allow-Origin' '*';
        add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
       add_header 'Cache-Control' 'no-store';
    }
}

兩個 server,一個監聽 80 端口,用於將所有 HTTP 請求重定向到 HTTPS;另一個監聽 443 端口並啟用 SSL,用於處理 HTTPS 請求。我們使用 location / 定義了一個代理伺服器,當用戶請求該目錄時,Nginx 將會將其轉發到 https://api.openai.com。

請注意替換 yourdomain.com 為您自己的域名,並將 /path/to/your/certificate.crt 和 /path/to/your/certificate.key 替換為您的 SSL 證書路徑。

読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。