Access-Control-Allow-Origin '*' não permitido / funcionando com o Apache2

2

Estou tentando conectar ao hood.ie via Javascript:

hoodie = new Hoodie('http://example.com:6001');

Mas, em seguida, receba um erro: A wildcard '*' cannot be used in the 'Access-Control-Allow-Origin' header when the credentials flag is true. Origin 'xxx' is therefore not allowed access.

Com:

hoodie = new Hoodie('http://example.com');

404 ...

Eu posso me conectar a localhost : 6001 e: 6002 para public / admin, então as portas estão funcionando (também para external example.com)

Mas no devonsole eu recebo:

OPTIONS: http://example.com:6001/_api/_session Um curinga '*' não pode ser usado no cabeçalho 'Access-Control-Allow-Origin' quando o sinalizador de credenciais é verdadeiro. Portanto, o link 'de origem não tem permissão para acessar. '

Eu configurei o Apache2:

 <VirtualHost *:80>
    DocumentRoot /var/www
    Header set Access-Control-Allow-Origin *
    Header add Access-Control-Allow-Headers "origin, content-type"
    Header always set Access-Control-Allow-Methods "POST, GET, PUT, DELETE, OPTIONS"
    Header set Access-Control-Allow-Credentials "false"
    <Directory />
            Options FollowSymLinks
            AllowOverride None
    </Directory>
    <Directory /var/www/>
            Options Indexes FollowSymLinks MultiViews
            AllowOverride None
            Order allow,deny
            allow from all
            Header set Access-Control-Allow-Origin *
            Header set Access-Control-Allow-Credentials "false"
    </Directory>

    ScriptAlias /cgi-bin/ /usr/lib/cgi-bin/
    <Directory "/usr/lib/cgi-bin">
            AllowOverride None
            Options +ExecCGI -MultiViews +SymLinksIfOwnerMatch
            Order allow,deny
            Allow from all
    </Directory>
     ErrorLog ${APACHE_LOG_DIR}/error.log

    # Possible values include: debug, info, notice, warn, error, crit,
    # alert, emerg.
    LogLevel warn

    CustomLog ${APACHE_LOG_DIR}/access.log combined
Alias /doc/ "/usr/share/doc/"
<Directory "/usr/share/doc/">
    Options Indexes MultiViews FollowSymLinks
    AllowOverride None
    Order deny,allow
    Deny from all
    Allow from 127.0.0.0/255.0.0.0 ::1/128
</Directory>

E tentei um extra:

<VirtualHost *:6001>
        Header set Access-Control-Allow-Origin *
        Header set Access-Control-Allow-Credentials "false"
</VirtualHost>

Tentei:

Header set Access-Control-Allow-Credentials false
Header set Access-Control-Allow-Credentials 'false'
Header set Access-Control-Allow-Credentials true 
...etc

Header set Access-Control-Allow-Origin "*"
Header set Access-Control-Allow-Origin "example.com"

Tentei todas as variações possíveis, mas ainda recebo o mesmo erro ...

Mas eu estou querendo saber se eu tenho que configurá-lo em um lugar diferente, porque o diretório www do serviço :6001 está em algum lugar na minha pasta pessoal, não em var / www, mas ainda funciona, Eu não tenho ideia de como o apache lida com isso, ou sabe sobre a localização, ou se o hood.ie inicia seu próprio webservice.

    
por TrySpace 25.03.2014 / 18:50

2 respostas

3

Eu acredito que deveria ser apenas:

Header set Access-Control-Allow-Origin "*"

sem os outros sinalizadores Access-Control- *, conforme descrito em enable-cors.org .

    
por 02.01.2016 / 04:35
1

Eu acho que o "Hoodie" está usando um XMLHttpRequest que envia cookies (withCredentials="true") e, portanto, seu navegador está rejeitando a resposta do servidor, pois ele tem um caractere curinga em o cabeçalho de origem permitido.

    
por 18.04.2014 / 11:27