Eu não vejo qual é o problema com esta configuração do servidor NGINX. Estou executando um servidor tomcat na porta 8081, jboss em 8080 e tenho NGINX ouvindo na porta 80. Estou enviando uma solicitação ajax para a porta 80 e gostaria de tê-lo proxy_pass para o servidor jboss. O webapp está sendo executado na porta 8081 e a solicitação está sendo enviada para a porta 80:
server {
listen 80;
server_name example1.com;
root /home/login/users1;
access_log /home/nginx/example1/log/access.log;
error_log /home/nginx/example1/log/error.log;
location /login {
add_header 'Access-Control-Allow-Origin' '*';
add_header 'Access-Control-Allow-Credentials' 'true';
add_header 'Access-Control-Allow-Headers' 'Content-Type,Accept';
add_header 'Access-Control-Allow-Methods' 'GET, POST, OPTIONS, PUT, DELETE';
proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504;
proxy_redirect off;
proxy_buffering off;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_pass http://192.168.xx.xxx:8080/path/to/api/user/login;
}
}
A saída do console é:
OPTIONS http://192.168.xx.xxx/home/login/users1 405 (Not Allowed) jquery.js:8102
XMLHttpRequest cannot load http://192.168.xx.xxx/home/login/users1. Origin http://192.168.xx.xxx:8081 is not allowed by Access-Control-Allow-Origin.
O pedido AJAX:
$.ajax( {
url : 'http://192.168.xx.xxx/home/login/users1/login',
type : 'post',
contentType : 'application/json',
success : function(data) {
args.success(data);
},
data : args.data,
error : args.error,
crossDomain: true
});
Eu olhei para este post semelhante, mas não vejo o problema como eu estou definindo add_header 'Access-Control-Allow-Origin' '*'; Alguma idéia?
Obrigado,
J