cordova-plugin-facebook4 Facebook не открывается на iOS - PullRequest
0 голосов
/ 16 февраля 2019

У меня проблема с cordova-plugin-facebook4 (https://github.com/jeduan/cordova-plugin-facebook4) на iOS устройствах. После выполнения процедуры установки, указанной в документации («Руководство по iOS»)") и правильной настройки приложения в консоли разработчика Facebook, когда я нажимаю кнопку входа в Facebook , ничего не происходит . Консоль XCODE выдает следующую ошибку:

2019-02-15 17:22:58.678937+0100 HelloCordovaApp[59179:1228209] Logging in with CORDOVA ... 2019-02-15 17:22:58.692742+0100 HelloCordovaApp[59179:1228209] Checking login status: unknown 2019-02-15 17:22:58.692947+0100 HelloCordovaApp[59179:1228209] Performing Fb login ... 2019-02-15 17:22:58.693087+0100 HelloCordovaApp[59179:1228209] Starting login 2019-02-15 17:22:58.693271+0100 HelloCordovaApp[59179:1228209] *** WebKit discarded an uncaught exception in the webView:decidePolicyForNavigationAction:request:frame:decisionListener: delegate: <NSInvalidArgumentException> Permissions should each be specified in separate string values in the array. 2019-02-15 17:22:58.694627+0100 HelloCordovaApp[59179:1228209] Client application failed to make a policy decision via WebPolicyDecisionListener, using defaultPolicy 2

Приложение, которое я разработал, написано на AngularJs и упаковано с использованием Cordova. Что бы это могло быть? На устройствах Android оно отлично работает ... Вот код, который выполняется, когда пользователь нажимает на кнопку входа в Facebook:

function fbLoginButtonClick(){
    console.log('Logging in with CORDOVA ...');
    facebookConnectPlugin.getLoginStatus(_fbLoginStatusSuccess, _fbLoginStatusError);
}

////////

function _fbLoginStatusSuccess(response) {
    var responseStatus = response.status;
    console.log('Checking login status: ', responseStatus);
    if (responseStatus === 'connected') {
      _fbLoginSuccess();
    } else if (responseStatus !== null) {
      _doFbLogin();
    } else {
      handleFacebookError(responseStatus);
    }
 }

function _fbLoginStatusError(error) {
    handleFacebookError(error);
}   

function _doFbLogin() {
    console.log('Performing Fb login ...');
    facebookConnectPlugin.login(['email, public_profile'], _fbLoginSuccess, _fbLoginError);
}

function _fbLoginSuccess(result) {
    console.log('Fb API: getting user data ...');
    facebookConnectPlugin.api('/me?fields=id,name,first_name,last_name,email', ['email', 'public_profile'], _fbApiSuccess, _fbApiError);
}

function _fbLoginError(error) {
    handleFacebookError(error);
}  

function _fbApiSuccess(userData) {
    alert('User Authenticated!!');
    //redirect to admin page
}

function _fbApiError(error) {
    handleFacebookError(error);
}

function handleFacebookError (error) {
  if(error){
    console.log(error);
  }
}

И это конфигурация в моем файле config.xml:

<plugin name="cordova-plugin-facebook4" spec="4.2.1">
    <variable name="APP_ID" value="************" />
    <variable name="APP_NAME" value="HelloCordovaApp" />
    <variable name="FACEBOOK_HYBRID_APP_EVENTS" value="false" />
    <variable name="FACEBOOK_ANDROID_SDK_VERSION" value="4.40.0" />
</plugin>

1 Ответ

0 голосов
/ 17 февраля 2019

Мне потребовалось некоторое время, чтобы понять это, в основном ошибка в том, что разрешения, которые вы передаете в SDK, имеют неправильный тип.Вот как это исправить:

Замените эту строку:

facebookConnectPlugin.login(['email, public_profile'], _fbLoginSuccess, _fbLoginError);

На:

var perms = new Array("email","public_profile");
facebookConnectPlugin.login(perms, _fbLoginSuccess, _fbLoginError);

Это должно решить проблему для вас.Удачи!

...