2016-12-30 65 views
2

我正在尝试使用FBSDK在我的React Native iOS应用中设置Facebook登录。该按钮呈现,但点击时会导致iOS模拟器中的应用程序崩溃。它甚至不会在远程调试器中记录任何错误。React Native Facebook登录按钮在iOS模拟器中崩溃应用

我加入了FBSDKCoreKit.framework和FBSDKLoginKit.framework到我的项目在Xcode和随后关于如何修改this guideinfo.plistAppDelegate.m

是不是有什么毛病我的按钮的代码?

import React, { Component } from 'react' 
import { View } from 'react-native' 
import FBSDK from 'react-native-fbsdk' 
const { LoginButton } = FBSDK  

import styles from '../styles'  

export default class Login extends Component { 
    constructor (props) { 
    super(props) 
    this.onLoginFinished = this.onLoginFinished.bind(this) 
    }  

    onLoginFinished (error, result) { 
    if (error) { 
     console.log(error) 
     alert("Login failed with error: " + error); 
    } else if (result.isCancelled) { 
     alert("Login was cancelled"); 
    } else { 
     alert("Login was successful with permissions: " + result) 
    } 
    }  

    render() { 
    return (
     <View style={styles.container}> 
     <LoginButton 
      publishPermissions={["public_profile"]} 
      onLoginFinished={this.onLoginFinished} 
      onLogoutFinished={() => alert("User logged out")} 
     /> 
     </View> 
    ) 
    } 
} 

编辑

从Andreyco

<Error>: *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'Read permissions are not permitted to be requested with publish or manage permissions.' 
    *** First throw call stack: 
    (
    0 CoreFoundation      0x00000001102ce34b __exceptionPreprocess + 171 
    1 libobjc.A.dylib      0x000000010f1dc21e objc_exception_throw + 48 
    2 CoreFoundation      0x00000001102ce299 -[NSException raise] + 9 
    3 FunDates       0x000000010e860c05 -[FBSDKLoginManager logInWithPublishPermissions:fromViewController:handler:] + 228 
    4 FunDates       0x000000010e85d523 -[FBSDKLoginButton _buttonPressed:] + 1662 
    5 UIKit        0x000000011284b5b8 -[UIApplication sendAction:to:from:forEvent:] + 83 
    6 UIKit        0x00000001129d0edd -[UIControl sendAction:to:forEvent:] + 67 
    7 UIKit        0x00000001129d11f6 -[UIControl _sendActionsForEvents:withEvent:] + 444 
    8 UIKit        0x00000001129d00f2 -[UIControl touchesEnded:withEvent:] + 668 
    9 UIKit        0x00000001128b8ce1 -[UIWindow _sendTouchesForEvent:] + 2747 
    10 UIKit        0x00000001128ba3cf -[UIWindow sendEvent:] + 4011 
    11 UIKit        0x000000011286763f -[UIApplication sendEvent:] + 371 
    12 UIKit        0x000000011305971d __dispatchPreprocessedEventFromEventQueue + 3248 
    13 UIKit        0x00000001130523c7 __handleEventQueue + 4879 
    14 CoreFoundation      0x0000000110273311 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17 
    15 CoreFoundation      0x000000011025859c __CFRunLoopDoSources0 + 556 
    16 CoreFoundation      0x0000000110257a86 __CFRunLoopRun + 918 
    17 CoreFoundation      0x0000000110257494 CFRunLoopRunSpecific + 420 
    18 GraphicsServices     0x0000000116095a6f GSEventRunModal + 161 
    19 UIKit        0x0000000112849964 UIApplicationMain + 159 
    20 FunDates       0x000000010e69f9bf main + 111 
    21 libdyld.dylib      0x000000011421668d start + 1 
    22 ???         0x0000000000000001 0x0 + 1 
) 
+0

运行'react-native log-ios'来从设备尾部记录日志。发布日志然后 – Andreyco

+0

@Andreyco日志添加 – plmok61

回答

7

运行react-native log-ios根据注释添加日志,我需要改变publishPermissionsreadPermissions

<LoginButton 
    readPermissions={["public_profile email"]} 
    onLoginFinished={this.loginFinished.bind(this)} 
    onLogoutFinished={() => alert("User logged out")} 
/> 
+0

它为我thx工作。 –

+0

@ plmok61我遇到了同样的错误,但将'public'更改为'read'对我无效。自从这篇文章后你可能会遇到任何其他想法? – Turnipdabeets

+0

谢谢! FB文档没有打扰这个小细节...... – jfeferman

相关问题