2014-10-13 2 views
0

내 앱에서 흥미로운 문제가 발견되었습니다.Safari에서만 권한이없는 리소스 401을로드하지 못했습니다.

저는 Rails 3와 Ruby 2.0을 사용하고 있습니다. 이미 내 앱이 실행중인 프로덕션 서버와 다른 스테이징 서버가 있습니다. 새로운 기능을 구성하고 있지만 Safari에만 문제가 있습니다. 내가 네트워크 탭에서 검사 할 때

Redirected to http://ip.server/ 
Completed 302 Found in 201.7ms (ActiveRecord: 0.0ms) 
Started GET "/" for my.ip at 2014-10-13 08:17:18 +0200 
Processing by DashboardController#index as HTML 
Completed 401 Unauthorized in 1.2ms 
Started GET "/user/sign_in" for my.ip at 2014-10-13 08:17:18 +0200 
Processing by Devise::SessionsController#new as HTML 
    Rendered application/_field_errors.html.erb (0.0ms) 
    Rendered application/_field_errors.html.erb (0.0ms) 
    Rendered devise/sessions/new.html.erb within layouts/devise (2.3ms) 
Completed 200 OK in 5.5ms (Views: 3.8ms | ActiveRecord: 0.0ms) 

, 나는이를 볼 수 있습니다

실패 자원을로드 : 서버는 내가 생각했던 초에 401 (무단)

의 상태로 응답 내 문제는 Devise에서 왔지만 Google에서 확인한 결과는 다음과 같습니다. cross browser problem

Chrome에서 시도한 결과 작동합니다. 나는 AdBlock없이 또는 개인 네비게이션을 사용해 보았지만 여전히 Safari와는 작동하지 않습니다.

편집 :

내가했던 2 명 요청, 크롬에서 오는 하나와 사파리에서 두 번째.

WARNING: Can't verify CSRF token authenticity 

편집 2 : 나는 내 문제에 대해 책임을지지했다 (CSRF에 대한) 내 ApplicationController.rb 그리고 마지막으로이 오류에 선 protect_from_forgery 댓글을 달았습니다

유일한 차이점은이 라인이다.

Chrome과 Safari를 함께 사용하면 스택이 생깁니다. 크롬

:

Started POST "/user/sign_in" for my.ip at 2014-10-14 13:27:51 +0200 
Processing by Devise::SessionsController#create as HTML 
Parameters: {"utf8"=>"✓", "authenticity_token"=>"c86MNR4MCSbQWJiAjkGtgfgPMg5YirG1tqf/2vqdBWc=", "user"=>{"email"=>"[email protected]", "password"=>"[FILTERED]", "remember_me"=>"0"}} 
User Load (0.4ms) SELECT `users`.* FROM `users` WHERE `users`.`email` = '[email protected]' LIMIT 1 
(0.1ms) BEGIN 
WARNING: User#current is nil, are you including SentientController on your ApplicationController? 
(0.3ms) UPDATE `users` SET `last_sign_in_at` = '2014-10-14 11:26:45', `current_sign_in_at` = '2014-10-14 11:27:51', `sign_in_count` = 52, `updated_at` = '2014-10-14 11:27:51' WHERE `users`.`type` IN ('User::Admin') AND `users`.`id` = 1 
(26.1ms) COMMIT 
Redirected to http://server.ip/ 
Completed 302 Found in 135.6ms (ActiveRecord: 0.0ms) 
Started GET "/" for my.ip at 2014-10-14 13:27:51 +0200 
Processing by DashboardController#index as HTML 
User Load (0.4ms) SELECT `users`.* FROM `users` WHERE `users`.`id` = 1 LIMIT 1 
server.ip Rendered dashboard/index.html.erb within layouts/application (2.5ms) 
Rendered application/_header.html.slim (57.6ms) 
Rendered application/_sidebar.html.erb (48.1ms) 
Rendered application/_page_header.html.slim (2.0ms) 
Rendered application/_flash_messages.html.erb (0.5ms) 
Rendered application/_footer.html.erb (0.8ms) 
Completed 200 OK in 137.5ms (Views: 122.9ms | ActiveRecord: 5.1ms) 

사파리 : 해결

Started POST "/user/sign_in" for my.ip at 2014-10-14 13:27:58 +0200 
Processing by Devise::SessionsController#create as HTML 
Parameters: {"utf8"=>"✓", "authenticity_token"=>"TWKhSxus5q46H9sZdEvMnzD52r0zA5phw/Pv7K+NKuY=", "user"=>{"email"=>"[email protected]", "password"=>"[FILTERED]", "remember_me"=>"0"}} 
User Load (0.4ms) SELECT `users`.* FROM `users` WHERE `users`.`email` = '[email protected]' LIMIT 1 
(0.1ms) BEGIN 
(0.3ms) UPDATE `users` SET `last_sign_in_at` = '2014-10-14 11:27:51', `current_sign_in_at` = '2014-10-14 11:27:58', `sign_in_count` = 53, `updated_at` = '2014-10-14 11:27:58' WHERE `users`.`type` IN ('User::Admin') AND `users`.`id` = 1 
(24.8ms) COMMIT 
Redirected to http://server.ip/ 
Completed 302 Found in 138.2ms (ActiveRecord: 0.0ms) 
Started GET "/" for my.ip at 2014-10-14 13:27:58 +0200 
Processing by DashboardController#index as HTML 
Completed 401 Unauthorized in 1.2ms 
Started GET "/user/sign_in" for my.ip at 2014-10-14 13:27:58 +0200 
Processing by Devise::SessionsController#new as HTML 
Rendered application/_field_errors.html.erb (0.0ms) 
Rendered application/_field_errors.html.erb (0.0ms) 
Rendered devise/sessions/new.html.erb within layouts/devise (2.2ms) 
Completed 200 OK in 5.2ms (Views: 3.7ms | ActiveRecord: 0.0ms) 

답변

0

문제. 내 앱에서 오는 것이 아니라 내 DNS 리디렉션에서 발생했습니다. 테스트를 위해 간단한 웹 리다이렉션을했고 DNS 리디렉션을 추가하지 않았습니다.

이제 모든 것이 완벽하게 작동합니다.

다른 사람들에게 도움이되기를 바랍니다.