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 證書路徑。

載入中......
此文章數據所有權由區塊鏈加密技術和智能合約保障僅歸創作者所有。