1

DevitsTokenAuth를 사용하는 레일 4 백엔드와 ngTokenAuth를 사용하는 AngularJS 프론트 엔드가 있습니다.
프런트 엔드와 백엔드가 동일한 도메인에 배포되면 인증이 완벽하게 작동합니다.다른 도메인에 Set-Cookie 헤더를 반환하지 않는 Devise 토큰 인증

두 개의 다른 포트에서 localhost에서 localhost를 실행하면서 localhost에서 테스트 할 때 sign_in 요청은 200 OK로 완료되지만 응답에는 Set-Cookie 헤더가 없으므로 클라이언트는 다음에 대해 인증되지 않은 상태로 유지됩니다 요청.

아래에서 두 시나리오에서 sign_in 응답으로받은 헤더 사본을 볼 수 있습니다.
서버에 배포 된 RAILS 백엔드에서 로컬로 실행되는 프론트 엔드에서 인증을 시도하는 경우에도 문제가 동일합니다. CORS 헤더는 서버에 다음과 같이 구성되어 모든 것이 십자가의 기원에 대해 나에게 잘 보인다

config.middleware.insert_before 0, "Rack::Cors" do 
    allow do 
    origins '*' 
    resource '*', :headers => :any, :methods => [:get, :post, :options] 
    end 
end 

로컬 호스트에

Accept-Ranges:bytes 
Access-Control-Allow-Credentials:true 
Access-Control-Allow-Methods:GET, POST, OPTIONS 
Access-Control-Allow-Origin:example.org 
Access-Control-Expose-Headers: 
Access-Control-Max-Age:1728000 
access-token:XXXXXXXXXXOI9s2x0IuVMA 
Age:0 
Cache-Control:max-age=0, private, must-revalidate 
client:XXXXXXXXXXAP2TsoBZTnjg 
Connection:keep-alive 
Content-Type:application/json; charset=utf-8 
Date:Thu, 04 May 2017 09:28:17 GMT 
ETag:W/"XXXXXXXXXXc86bb292d476d2366d3742" 
expiry:1495099697 
Server:nginx/1.10.0 (Ubuntu) 
Set-Cookie:_differenthood_session=ZE1NWndTUUVmMkNDbWRWckNNbkpKdWh6SVdaVTFlaGN6XXXXXXXXXXcrb2EzSGd3SFQvN2h3Z2IxOE9BMVYrTjV6YmsvRXpWNmN4T213R2V3MEJ1WWc9PS0tbU01Ymt6YkdOc0VIUTFCK1NUVFlMZz09--861a3aebd1d79f224d9ad810a88e5d5f23e114c0; path=/; HttpOnly 
token-type:Bearer 
Transfer-Encoding:chunked 
uid:[email protected] 
Vary:Origin 
X-Content-Type-Options:nosniff 
X-Frame-Options:SAMEORIGIN 
X-Request-Id:c935b76c-d173-48ce-b21c-5e694845148b 
X-Runtime:0.629113 
X-XSS-Protection:1; mode=block 

테스트 서버에 배포

Access-Control-Allow-Credentials:true 
Access-Control-Allow-Methods:GET, POST, OPTIONS 
Access-Control-Allow-Origin:http://localhost:9000 
Access-Control-Expose-Headers: 
Access-Control-Max-Age:1728000 
Access-Token:XXXXXXXXXXXAiR5CQmwYpQ 
Cache-Control:max-age=0, private, must-revalidate 
Client:XXXXXXXXXXq2UC7GXE0qbw 
Connection:Keep-Alive 
Content-Length:418 
Content-Type:application/json; charset=utf-8 
Date:Thu, 04 May 2017 09:27:20 GMT 
Etag:W/"XXXXXXXXXX37381b8c1637b2ea1bba96" 
Expiry:1495099640 
Server:WEBrick/1.3.1 (Ruby/2.2.6/2016-11-15) 
Token-Type:Bearer 
Uid:[email protected] 
Vary:Origin 
X-Content-Type-Options:nosniff 
X-Frame-Options:SAMEORIGIN 
X-Request-Id:3ef1f652-b29f-4fe7-bbb9-3de47f1acddf 
X-Runtime:0.653264 
X-Xss-Protection:1; mode=block 

답변