Facebook C# SDK を使用しています。これは、ほとんど ASPNet-MVC3-JsSdk の例に基づいています。私のアプリには、標準の Javascript コードがあります (ほとんどの場合、サンプル アプリから直接取得したものです)。
function facebooklogin() {
FB.login(function (response) {
if (response.authResponse) {
alert(window.location.pathname);
// user authorized
window.location = window.location.origin + "/Account/FacebookLogon" + "?returnUrl=" + window.location.pathname;
} else {
// user cancelled
}
}, { scope: "@ScoreTrack.Controllers.AccountController.ExtendedPermissions"});
};
私は基本的に、承認を確認するコントローラー アクションにリダイレクトしたいと考えてAccount.FacebookLogon()
います。ユーザーがアプリを承認した場合は、FormsAuthentication cookie/token を設定します。
public ActionResult FacebookLogon(string returnURL)
{
var fbWebContext = new FacebookWebContext(FacebookApplication.Current, ControllerContext.HttpContext); // or FacebookWebContext.Current;
if (fbWebContext.IsAuthorized(@MyApp.Controllers.AccountController.ExtendedPermissions.Split(',')))
{
// If the User is Logged in and Authorized
var fbwc = new FacebookWebClient();
dynamic me = fbwc.Get("me");
FormsAuthenticationTicket authTicket = new
FormsAuthenticationTicket(1, //version
me.username, // user name
DateTime.Now, //creation
DateTime.Now.AddMinutes(30), //Expiration
false, //Persistent
me.username);
string encTicket = FormsAuthentication.Encrypt(authTicket);
this.Response.Cookies.Add(new HttpCookie(FormsAuthentication.FormsCookieName, encTicket));
}
return Redirect(Url.Content("~/" + returnURL));
}
ある点まで、すべてが素晴らしく機能します。
Facebookのログインボタンをクリックして...
- 認証画面が表示されるので、「ログイン」をクリックします
- 拡張アクセス許可を承認します (新しい拡張認証を使用)
- Javascript が自分の
AccountController.FacebookLogon()
メソッドにリダイレクトする FacebookLogon()
メソッドは、Facebook が承認されているかどうかをチェックし、C# SDK は承認されていないと言っています。
どうしたインターネット?それとも FacebookC#SDK の人?または他のスマート facebook C# プログラマ男?
一体何?
誰?