我正在托管自己的 TURN-Server,并且已将 NGINX 配置为我的 Web 服务器。
这是我的问题:
我有一个 JavaScript WebRTC 客户端,它需要为 ICE Candidates 调用一个转向服务器,所以我的 TURN-Server 在 40501 端口上运行。
不幸的是,在 JavaScript 中,我收到了 Cross Origin Request Blocked 错误!
这里是 NGINX 寻求帮助的地方。我将 NGINX 配置为侦听端口 40500 并将请求代理到运行 TURN-Server 的端口 40501,如下所示:
upstream turn{
server 128.199.xx.xx:40501;
}
server {
listen 40500;
server_name _;
location / {
proxy_pass http://turn;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
if ($request_method = 'OPTIONS') {
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
add_header 'Access-Control-Max-Age' 1728000;
add_header 'Content-Type' 'text/plain charset=UTF-8';
add_header 'Content-Length' 0;
return 204;
}
if ($request_method = 'POST') {
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
}
if ($request_method = 'GET') {
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS';
add_header 'Access-Control-Allow-Headers' 'DNT,X-CustomHeader,Keep-Alive,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type';
}
}
}
但这对我没有好处。我无法通过 NGINX 连接到我的 TURN-Sever。我究竟做错了什么?提前致谢!