以下是gist.github.com支援reverse proxied APIs的範例:5 O+ H4 R2 `+ F8 f) x4 N7 }9 m1 j7 a& P
8 t! b4 {- {; z6 y$ v9 I
$ {( ~" T u5 X# d/ t. s# CORS header support
' N% C9 M' E" E3 y7 r4 X( y9 u: o#
# y. O& X2 |! y o6 v ^/ E, T# One way to use this is by placing it into a file called "cors_support"
3 @% Y# F n) X9 `. k# under your Nginx configuration directory and placing the following. u! D! v0 o+ \$ S$ U4 R, m5 n" [
# statement inside your **location** block(s):9 H& l6 z! C7 j5 n9 B6 y6 l
#
( J" q; c1 {( Z6 m* O6 r# include cors_support;
4 y% D' {3 D" i$ i8 ~" h4 D#- X+ ~1 `: I7 c& N( Q( L0 K
# As of Nginx 1.7.5, add_header supports an "always" parameter which7 @+ ?) t- e( P% b: J
# allows CORS to work if the backend returns 4xx or 5xx status code.
0 @6 s: R# I( d# s, `6 k+ R, F2 d. \#
8 r* f* F4 a* s# For more information on CORS, please see: http://enable-cors.org/
: w9 L% s4 A/ ~2 a8 {- F! \# Forked from this Gist: https://gist.github.com/michiel/10646407 G3 e% M y# o. e- f! n# S- M
# d- q3 w* X+ a' Q$ t7 E4 L
$ ?0 ~7 ]# o8 d4 k4 f* Qset $cors '';$ @* K" W3 Y* T4 k6 _; [8 Q
if ($http_origin ~ '^https?://(localhost|www\.yourdomain\.com|www\.yourotherdomain\.com)$') {+ i2 E! [, J) l
set $cors 'true';
0 W& S8 q/ T7 n+ Q& m2 U; m( P9 n}
( m! r2 K! Q8 s$ {0 q
1 b. a+ q- u: V; m) xif ($cors = 'true') {
2 P% r2 p. b) ^3 B8 }. } add_header 'Access-Control-Allow-Origin' "$http_origin" always;
6 ~1 K# U% H9 E7 c5 m; y& v add_header 'Access-Control-Allow-Credentials' 'true' always;( `5 l' ]' K3 l; C) z7 |+ ~2 {
add_header 'Access-Control-Allow-Methods' 'GET, POST, PUT, DELETE, OPTIONS' always;; f( R8 M' A1 U* x, [
add_header 'Access-Control-Allow-Headers' 'Accept,Authorization,Cache-Control,Content-Type,DNT,If-Modified-Since,Keep-Alive,Origin,User-Agent,X-Requested-With' always;
& w0 ~; z) r1 r # required to be able to read Authorization header in frontend
( {4 O; \3 I+ y; h; C$ v% Z1 Z& e( p a #add_header 'Access-Control-Expose-Headers' 'Authorization' always;
6 P% N0 h- a) X" a8 V* p" k# U4 [}6 s; o* M! u2 I) Z& e+ H0 _8 i
( K! F$ ~' t0 o4 c/ x; u
if ($request_method = 'OPTIONS') {- o& Z `- ?3 H x2 A" P. U4 X* @
# Tell client that this pre-flight info is valid for 20 days
j w# C7 V4 z6 A4 H q add_header 'Access-Control-Max-Age' 1728000;
7 X! F! G4 g2 B" u& k1 n add_header 'Content-Type' 'text/plain charset=UTF-8';; H# v3 Z/ Y# n
add_header 'Content-Length' 0;
: t7 Q8 D4 Q; N* _9 U return 204;5 g5 ?% G4 T: E L, Q) k
} https://gist.github.com/Stanback/7145487#file-nginx-conf 的討論範例:- l7 U9 L! o1 o8 b. u4 O7 E6 j
if ( $request_method !~ ^(GET|POST|HEAD|OPTIONS|PUT|PATCH|DELETE)$ ) { return 444;
8 r: `, x3 e, w0 `. X}* I, |% L# Q( T. g4 P# v
set $origin $http_origin;( _/ y) \2 h0 G4 V6 m2 V- q
if ($origin !~ '^https?://(subdom1|subdom2)\.yourdom\.zone$') {
8 m: o& Y; k2 i* m set $origin 'https://default.yourdom.zone';! D# N/ J ] x' R
}
" ?4 v0 o+ K' d- b+ ? ^if ($request_method = 'OPTIONS') {
! B: t* q* S1 l8 M5 Z a/ p) Z add_header 'Access-Control-Allow-Origin' "$origin" always;
- D8 M3 v" i! O7 c3 j7 |! P) U add_header 'Access-Control-Allow-Methods' 'GET, POST, PATCH, PUT, DELETE, OPTIONS' always;
! i6 H& p1 [; [* n3 U6 S5 ?& m add_header 'Access-Control-Allow-Headers' 'Content-Type, Accept, Authorization' always;) m$ q+ @$ A$ ^' p) o
add_header 'Access-Control-Allow-Credentials' 'true' always; y8 J+ o) w8 [% C
add_header Access-Control-Max-Age 1728000; #20 days
8 J0 h9 d3 j! _( K* }* p" x/ f add_header Content-Type 'text/plain charset=UTF-8';
3 Q, O! G8 k$ g# y- Y2 R% B add_header Content-Length 0;
( K3 ~+ X# n7 z$ @9 i6 D return 204;
. A$ e( o/ g3 b0 f}
8 l$ \7 J* s, Wif ($request_method ~ '(GET|POST|PATCH|PUT|DELETE)') {5 p+ y# E3 d7 H" h( U" I8 f
add_header Access-Control-Allow-Origin "$origin" always;
% v% v: l5 n. ?7 a( D" Y add_header Access-Control-Allow-Methods 'GET, POST, PATCH, PUT, DELETE, OPTIONS' always;& X7 b5 Y! M Q! ^6 L% o O
add_header Access-Control-Allow-Headers 'Content-Type, Accept, Authorization' always;
9 a1 c$ N5 \$ @- S. i4 s5 u add_header Access-Control-Allow-Credentials true always;
2 M1 l' f5 S) m- ]0 [* Z} Access-Control-Allow-Origin Multiple Origin Domains? 的例子:# based on https://gist.github.com/4165271/
_ {+ W9 g. _2 R- V#
' o8 g4 q' u4 q6 R# Slightly tighter CORS config for nginx
' l' Z8 M, i' o6 f# h1 }#; a- Z' k# S8 l; U+ G
# A modification of https://gist.github.com/1064640/ to include a white-list of URLs9 \6 \& |9 I! F) X/ F& N* h3 n
#: M) t3 E# f' L6 B4 D+ v8 D
# Despite the W3C guidance suggesting that a list of origins can be passed as part of
( r3 w4 g0 r$ e: W& ~: {! L0 X: \# Access-Control-Allow-Origin headers, several browsers (well, at least Firefox)% a1 H% E% i6 K
# don't seem to play nicely with this.
6 ~+ _! R. A0 M3 s/ J( g* f#
! E1 |3 z7 }" n% D; d2 k, K3 S' y# To avoid the use of 'Access-Control-Allow-Origin: *', use a simple-ish whitelisting
: F# x/ `( N( l' _# method to control access instead.
( p# p+ B5 [9 l( f+ B. K#
/ l: e* `/ a' ]* v* j# NB: This relies on the use of the 'Origin' HTTP Header./ h" w' a0 R- U$ _( x: S3 j
3 o) ^5 L9 @1 T2 K
location / {: M6 @: M5 a! }+ u" W
8 i+ c% |& g* H, c0 H
if ($http_origin ~* (^https?://([^/]+\.)*(domainone|domaintwo)\.com$)) {$ S! `2 @. U }7 f6 p
set $cors "true";0 `% R: H+ `9 A
}$ u3 y: ~7 P I: z1 }% z! e
1 w; W9 j& B4 s, y # Nginx doesn't support nested If statements. This is where things get slightly nasty.
5 c$ [8 O f8 E& c. o k # Determine the HTTP request method used
4 L a+ |- m8 Q8 H6 `$ t# W if ($request_method = 'OPTIONS') {
2 n9 t- @) c' t" | set $cors "${cors}options";
8 r+ G( H' q8 z1 s6 L& t }
$ p: o3 q" }+ q; b6 E if ($request_method = 'GET') {
( g: Y4 @9 U1 E- N$ `4 } set $cors "${cors}get";& N3 J, M) k* h! i
}: I- n+ ~! X! I% Z$ e& g% ~" R: m
if ($request_method = 'POST') {0 }# K% P9 g" a+ a4 e. _
set $cors "${cors}post";
3 ~" Q1 x5 z$ {* g; C }! N( W2 p B" r& }8 w$ G) |
( `2 H- b- h% S x; T if ($cors = "true") {1 M2 c) s+ x" \' M2 x: n% g
# Catch all incase there's a request method we're not dealing with properly
4 T$ U" ]# [" _$ b8 D$ z add_header 'Access-Control-Allow-Origin' "$http_origin";
+ M( t$ a6 e: g- T0 g* b }
3 e" v/ v: y9 U: O3 Y7 \( ^8 X9 C- W& L5 p" C
if ($cors = "trueget") {
3 Z' K; X& E( v+ z5 T add_header 'Access-Control-Allow-Origin' "$http_origin";- Z) q2 c5 R. I2 j; j' F# A& H# d7 G
add_header 'Access-Control-Allow-Credentials' 'true';
. [& b7 c6 u* k+ _ add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
2 D- z; i, S8 G add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
! \3 w4 j6 ^* A }
4 s9 v' _7 k- \6 I! B! w
/ l" W2 I% j; e: H! r if ($cors = "trueoptions") {
2 k. j9 t: \' p6 h; J6 [" F: f2 `/ |# m: R add_header 'Access-Control-Allow-Origin' "$http_origin";
5 p% {: R8 e" T0 c i& T% b+ \3 l8 f& _3 x
## n, R5 s& Q6 X& e2 F) n
# Om nom nom cookies
1 Y8 L$ h6 w# w6 I+ L1 Y$ @ } #2 c, A, a# T& a9 y8 m1 y
add_header 'Access-Control-Allow-Credentials' 'true';: \) f' B( y1 p6 R/ A
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';2 k$ f+ I5 U$ ]* ^: @# M3 N# o* J8 R
- W" j+ ~' U$ x6 } #
" I: X3 H# G" ?2 ^8 U; H4 n. s # Custom headers and headers various browsers *should* be OK with but aren't
0 K/ O M( c2 h7 s) M/ i #
6 r5 t+ V$ P2 W7 n0 y2 N add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';+ Z) `; K! {9 q
% n3 m7 s& ?. q" v' |4 v #
- C' N* _) t: q9 [ # Tell client that this pre-flight info is valid for 20 days
7 K2 r+ h& N0 k8 x6 I! A- e2 V Y #) c7 g0 X9 F( i
add_header 'Access-Control-Max-Age' 1728000;+ q7 Y9 d0 k, t. N0 I7 a& t
add_header 'Content-Type' 'text/plain charset=UTF-8';
" E/ S) S7 t' n* ^ add_header 'Content-Length' 0;
W2 p' }9 R# j: o return 204;, H' G5 O# M2 P$ z# T: i" R
}* L. l- i+ p7 l2 i
, U; ?: V6 n- Y" B" g; {! W+ z
if ($cors = "truepost") {
" t0 W: n8 ^) ?5 b- k9 d4 B add_header 'Access-Control-Allow-Origin' "$http_origin";7 ], K9 E) Q; q
add_header 'Access-Control-Allow-Credentials' 'true';
+ j8 @- E4 K# v' w7 s& }8 y add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';8 S8 g9 E: V# k+ k, H
add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';9 g! a* V& x& G1 \$ a0 M) S
}
2 Y1 z# O& D& `6 p8 R0 E% M% f- \" p$ q% Q# R, A
} * @: A/ W4 Z) v" c
2 {3 K. ]5 H! z0 i' Q6 ]2 m
|
|