Karena beberapa keputusan desain yang mengerikan, kami memiliki aplikasi yang tidak dapat menanggapi permintaan HEAD HTTP (Pengembalian 'Metode Tidak Diizinkan'). Memodifikasi perangkat lunak untuk mengembalikan permintaan KEPALA dengan benar akan sulit, bukan tidak mungkin tetapi kerja ekstra. Aplikasi ini berada di belakang proxy NGINX, saya bertanya-tanya apakah ada cara untuk mendapatkan NGINX untuk mengonversi permintaan HEAD yang diterima dari klien menjadi permintaan GET ke back-end, kemudian membuang respons kecuali untuk header dan mengirimkannya kembali ke klien seolah-olah server aplikasi kami dapat menanggapi permintaan HEAD.
Konfigurasi saat ini (cukup standar)
upstream ourupstream{
server unix:/var/apps/sockets/ourapp.socket.thread1
server unix:/var/apps/sockets/ourapp.socket.thread2
server unix:/var/apps/sockets/ourapp.socket.thread3
[like 20 of these]
}
server {
listen 1.2.3.4:80;
server_name ourapp;
access_log /var/apps/logs/ourapp.nginx.plog proxy;
error_log /var/apps/logs/ourapp.nginx.elog info;
gzip on;
gzip_types text/plain text/html;
proxy_intercept_errors on;
proxy_connect_timeout 10;
proxy_send_timeout 10;
proxy_read_timeout 10;
proxy_next_upstream error timeout;
client_max_body_size 2m;
error_page 404 /static/404.html;
error_page 500 501 502 503 504 =500 /static/500.html;
location / {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://ourupstream/;
}
location /static/ {
root /var/apps/global/;
}
}
Jawaban:
Karena Anda menggunakan proxy_pass, saya pikir Anda harus menggunakan penyalahgunaan error_page (dan karena Anda sudah menggunakan error_pages, Anda juga harus mengaktifkan halaman kesalahan rekursif). Saya pikir ini akan bekerja untuk Anda:
sumber