Аутентификация Facebook и странное поведение перенаправления

#asp.net-mvc-3 #redirect #facebook-c#-sdk

#asp.net-mvc-3 #перенаправление #facebook-c #-sdk

Вопрос:

В настоящее время я тестирую реализацию OAuth для facebook connect, используя http://facebooksdk.codeplex.com .

У меня есть FacebookController с 2 простыми действиями, называемыми LogOn и CallBack.

Все работает нормально, и пользователь правильно зарегистрирован в моей системе.

Проблема в том, что при вызове обратного вызова происходит что-то странное, что делает простой

 return Redirect(loggedUrl);
  

перенаправление на правильный зарегистрированный URL-адрес, заканчивающийся следующими символами: #_=_

Похоже, что сервер Facebook отправляет информацию на мой веб-сервер, используя следующий HTTP-заголовок:

 HTTP/1.1 302 Found
Cache-Control: private, no-cache, no-store, must-revalidate
Expires: Sat, 01 Jan 2000 00:00:00 GMT
Location: http://mywebsite.com/Facebook/CallBack/?state=1amp;code=AQCXexr10uxANSBOu9JqrBDxqPkWbsyxM1S9ltuY9XwCXW7eGsOII329SthClxOSM_a7wJvwrXh1_O3D5I7E_nxCDTWDLpyYdMpMUfw4zMWcQ4oV2PmRkIMd2NfPYRKlkLgkurEzka1CjAF1jp8Xb3crklOB59W4IT7LZy6MEmFusuhSKacmsTcV1LAOW4uJ3K4#_=_
P3P: CP="Facebook does not have a P3P policy. Learn why here: http://fb.me/p3p"
Pragma: no-cache
Set-Cookie: locale=en_US; expires=Fri, 28-Oct-2011 00:09:38 GMT; path=/; domain=.facebook.com
Content-Type: text/html; charset=utf-8
X-FB-Server: 10.43.103.61
X-Cnection: close
Date: Fri, 21 Oct 2011 00:09:38 GMT
Content-Length: 0
  

Как вы можете видеть, мы можем найти #_=_ символы в конце значения местоположения.

Похоже, что перенаправление учитывало #_=_ символы, автоматически добавляя их в loggedUrl.

Даже когда я пытаюсь return Redirect("/"); , #_=_ он добавляется (почти) ниоткуда к моему перенаправленному URL…

Любая идея будет очень признательна.

Заранее спасибо за любой ответ.

С уважением,

LB

Комментарии:

1. Это вызвало проблемы с прослушиванием URL-адреса jQuery Mobile. $.mobile.hashListeningEnabled = false; решил это.

Ответ №1:

Недавно Facebook изменил свой механизм аутентификации, добавив символы #= в конец своего ответа. Символ # в конце строки фактически создает проблему. Таким образом, вы можете либо обрезать запрос, либо выполнить перенаправление, которое будет работать нормально.

Комментарии:

1. Что значит обрезать запрос?

2. @capdragon: извлеките URL-адрес, удалите #= в конце и повторно отправьте запрос URL-адреса, используя любой метод (ajax, перенаправление и т. Д.)