2011-03-09 2 views
2

У меня есть приложение, которое является файлом index.php с javascript, и когда пользователь регистрируется в javascript, загружает содержимое страницы, которая хранится в контенте. phpFacebook connect. Работает в Firefox/Internet Explorer, а не в Chrome/Safari/Opera

(k, я выяснил, что он работает в сафари, если пользователь разрешил всплывающие окна.Я получаю ту же ошибку с firefox.Таким образом, всплывающие окна могут быть врагом? Как я могу переписать это на тонну всплывающих окон ?)

index.php:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"> 
<html> 
    <head> 
     <title>My app</title> 
     <link type="text/css" rel="stylesheet" href="css/style.css"/> 
     <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script> 
    </head> 
    <body> 
     <div id="fb-root"></div> 
     <script src="http://connect.facebook.net/en_US/all.js"></script> 
     <script src="js/jquery.validationEngine.js"></script> 
     <script src="js/jquery.validationEngine-en.js" type="text/javascript" charset="utf-8"></script> 
     <link rel="stylesheet" href="css/validationEngine.jquery.css" type="text/css"/> 
     <script src="js/functions.js"></script> 
    </body> 
</html> 

functions.js:

FB.init({ 
    appId : '123456789', 
    status : true, // check login status 
    cookie : true, // enable cookies to allow the server to access the session 
    xfbml : true // parse XFBML 
}); 

FB.login(function(response) { 
    if (response.session) { 
     if (response.perms) { 
      $.get("content.php", {get: "form"}, function(data){ 
       $('body').append(data); 
      });  
     } else { 
      top.location.href="http://example.com"; 
     } 
    } else { 
     top.location.href="http://www.example.com"; 
    } 
}, {perms:'publish_stream'}); 

Работает в Firefox и Internet Explorer, но в Chrome, Safari и Opera это не так. Я получил эту ошибку в Chrome с яваскрипта отладки:

Unsafe JavaScript attempt to access frame with URL https://www.facebook.com/login.php?api_key=123456789&skip_api_login=1&display=popup&cancel_url=http%3A%2F%2Fstatic.ak.fbcdn.net%2Fconnect%2Fxd_proxy.php%3Fversion%3D0%23cb%3Df13bcfbe1%26origin%3Dhttp%253A%252F%252Fexample.com%252Ff1fd4b982c%26relation%3Dopener%26transport%3Dpostmessage%26frame%3Df206b2144c%26result%3D%2522xxRESULTTOKENxx%2522&fbconnect=0&next=https%3A%2F%2Fwww.facebook.com%2Fdialog%2Fpermissions.request%3F_path%3Dpermissions.request%26app_id%3D152123456789%26redirect_uri%3Dhttp%253A%252F%252Fstatic.ak.fbcdn.net%252Fconnect%252Fxd_proxy.php%253Fversion%253D0%2523cb%253Df13bcfbe1%2526origin%253Dhttp%25253A%25252F%25252Fexample.com%25252Ff1fd4b982c%2526relation%253Dopener%2526transport%253Dpostmessage%2526frame%253Df206b2144c%2526result%253D%252522xxRESULTTOKENxx%252522%26sdk%3Djoey%26display%3Dpopup%26api_key%3D123456789%26fbconnect%3D0%26locale%3Den_US%26method%3Dpermissions.request%26perms%3Dpublish_stream%26return_session%3D1%26session_version%3D3%26from_login%3D1&rcount=1 from frame with URL http://example.com/myfacebookapp/. Domains, protocols and ports must match. 

В Opera он застревает на всплывающем окне (всплывающее окно разрешено) с этим URL:

http://static.ak.fbcdn.net/connect/xd_proxy.php?version=0#cb=f5132b51b60fbe&origin=http%3A%2F%2Fexample.com%2Ff10a57ba8d445c&relation=opener&transport=flash&frame=f19023256ffd8&result=%7B%22perms%22%3A%22publish_stream%22%2C%22selected_profiles%22%3A1245738876%2C%22session%22%3A%22%7B%5C%22session_key%5C%22%3A%5C%222.buXjHddfcr_xKQHVeu_FXw__.3600.1299679200-1245738876%5C%22%2C%5C%22uid%5C%22%3A%5C%221245738876%5C%22%2C%5C%22expires%5C%22%3A1299679200%2C%5C%22secret%5C%22%3A%5C%22glwIAcpeG0HDT__0z1QI3g__%5C%22%2C%5C%22access_token%5C%22%3A%5C%22152384968151443%7C2.buXjHdcfcr_xKQHVeu_FXw__.3600.1299679100-1245738876%7CdyZCE5trqgMkU0HSzSorX3jqbIs%5C%22%2C%5C%22sig%5C%22%3A%5C%228724dd80df9f16e7c3a2ce1b06f8d1e1%5C%22%7D%22%7D 

Так что мой вопрос: Как может Я получаю это для работы во всех браузерах (Firefox, IE, Chrome & safari)?

(редактирование: Я изменил URLs и удалить коды и адрес в моем приложении)

ответ

0

Я также имел столь же неудачный опыт с всплывающими окнами. В конце концов я отошел от модели потока клиентов, которую вы используете, к модели потока сервера, где сервер перенаправляет.

(я никогда не следовал за этим через с Javascript, но то, что я могу видеть в документации, не похоже, чтобы быть возможность отключить всплывающие окна. http://developers.facebook.com/docs/reference/javascript/fb.login/)

Я не могу предоставить вам с php, поскольку мой материал находится в .NET, но я думаю, что он должен работать аналогичным образом для вас:

  1. Создайте ссылку на страницу входа в FB: напр. FBLogin.php
  2. Эта страница затем использует библиотеку (facebook php sdk?), Чтобы помочь создать URL-адрес для входа в facebook с обратным адресом (например, FBAuthorize.php) на ваш сайт. Затем вы будете перенаправлены на адрес входа в facebooke.
  3. После успешной проверки подлинности на FB вы будете отправлены обратно на страницу FBAuthorize.php, где обмен магическими токенами должен обрабатываться библиотекой.

Нет всплывающих окон, без javascript.

+0

Спасибо. Я думал о возвращении к php (я использовал его в начале, но не работал, поэтому я попробовал js). Но проблема в том, что у меня не осталось много времени до крайнего срока. : / – Patrik

Смежные вопросы