Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/android/202.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
facebook的android发布密钥_Android_Facebook_Openssl_Android Keystore - Fatal编程技术网

facebook的android发布密钥

facebook的android发布密钥,android,facebook,openssl,android-keystore,Android,Facebook,Openssl,Android Keystore,我知道有人问过这个问题,但我一直在尝试500种不同的方法为我的android应用程序生成发布密钥,这样我就可以使用facebook获取数据。原因是我想在我自己的设备上测试它,当我尝试使用Facebook登录时,我得到的错误是无效的密钥散列,后跟一个我从未输入过的密钥散列 那么,我尝试了什么来生成密钥散列呢 我用命令提示符转到Java中的libs,并输入以下行: keytool -exportcert -alias androiddebugkey -keystore C:\Users\Riaan\

我知道有人问过这个问题,但我一直在尝试500种不同的方法为我的android应用程序生成发布密钥,这样我就可以使用facebook获取数据。原因是我想在我自己的设备上测试它,当我尝试使用Facebook登录时,我得到的错误是无效的密钥散列,后跟一个我从未输入过的密钥散列

那么,我尝试了什么来生成密钥散列呢

我用命令提示符转到Java中的libs,并输入以下行:

keytool -exportcert -alias androiddebugkey -keystore C:\Users\Riaan\.android | C:\OpenSSL\bin\openssl sha1 -binary | C:\OpenSSL\bin\openssl base64
androiddebugkey是我从eclipse导出文件时得到的密钥库别名,密钥库的路径是我在C:users\riaan\.android中的路径,它被称为debug.keystore

然后在下一行中,我定义了openssl的路径,之后我再次这样做

我确实得到了一些看起来像密钥散列的东西。然而,当我把它放在facebook上时,我仍然会遇到和以前一样的错误。它工作了一次,然后就停止了工作

另一件我感到奇怪的事情是,当我在命令提示符中输入这行代码时,没有提示我输入密码。很明显我做错了什么,但是什么

为完整起见,我将在此处给出登录页面的代码:

    import java.util.ArrayList;
    import java.util.Arrays;

    import org.json.JSONArray;
    import org.json.JSONObject;

    import com.facebook.Request;
    import com.facebook.Response;
    import com.facebook.Session;
    import com.facebook.SessionState;
    import com.facebook.UiLifecycleHelper;
    import com.facebook.model.GraphObject;
    import com.facebook.model.GraphObjectList;
    import com.facebook.model.GraphUser;
    import com.facebook.widget.LoginButton;

    import android.app.AlertDialog;
    import android.app.Dialog;
    import android.app.DialogFragment;
    import android.content.Intent;
    import android.os.Bundle;
    import android.support.v4.app.Fragment;
    import android.util.Log;
    import android.view.LayoutInflater;
    import android.view.View;
    import android.view.View.OnClickListener;
    import android.view.ViewGroup;
    import android.widget.Button;
    import android.widget.TextView;

    public class User_data_prompt_dialog extends Fragment {
    private static final String TAG = "MainFragment";
    private UiLifecycleHelper uiHelper;
    private TextView userInfoTextView;

private Session.StatusCallback callback = new Session.StatusCallback() {
    @Override
    public void call(Session session, SessionState state, Exception exception) {
        onSessionStateChange(session, state, exception);
    }
};

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    uiHelper = new UiLifecycleHelper(getActivity(), callback);
    uiHelper.onCreate(savedInstanceState);
}

public View onCreateView(LayoutInflater inflater, 
        ViewGroup container, 
        Bundle savedInstanceState) {
    View view = inflater.inflate(R.layout.activity_first_dialog, container, false);

 // create manual input button
    Button manualbutton =(Button)view.findViewById(R.id.manualinput);
    manualbutton.setOnClickListener(new OnClickListener(){

            @Override
            public void onClick(View v) {
                // experiment, erase later.
                Intent intent = new Intent(getActivity(), ManualDataEntry.class);
                startActivity(intent);

                getActivity().finish();
                // implement soon!
            }
        });

    // initialize authentication button and ask for permissions
    // to access data from facebook.
    LoginButton authButton = (LoginButton) view.findViewById(R.id.authButton);
    authButton.setFragment(this);
    authButton.setReadPermissions(Arrays.asList("user_location", "user_birthday", "user_likes"));

    // Textview that displays data
    userInfoTextView = (TextView) view.findViewById(R.id.userInfoTextView);

    return view;
}
private void onSessionStateChange(Session session, SessionState state, Exception exception) {

    if (state.isOpened()) {
        userInfoTextView.setVisibility(View.VISIBLE);
    } else if (state.isClosed()) {
        userInfoTextView.setVisibility(View.INVISIBLE);
    }


}

private String buildUserInfoDisplay(GraphUser user) {
    StringBuilder userInfo = new StringBuilder("");

    // Example: typed access (name)
    // - no special permissions required
    userInfo.append(String.format("Name: %s\n\n", 
        user.getName()));

    // Example: typed access (birthday)
    // - requires user_birthday permission
    userInfo.append(String.format("Birthday: %s\n\n", 
        user.getBirthday()));

    // Example: partially typed access, to location field,
    // name key (location)
    // - requires user_location permission
    userInfo.append(String.format("Location: %s\n\n", 
        user.getLocation().getProperty("name")));

    // Example: access via property name (locale)
    // - no special permissions required
    userInfo.append(String.format("Locale: %s\n\n", 
        user.getProperty("locale")));

    return userInfo.toString();
}

private interface MyGraphLanguage extends GraphObject {
    // Getter for the ID field
    String getId();
    // Getter for the Name field
    String getName();
}

@Override
public void onResume() {
    super.onResume();


    Session session = Session.getActiveSession();
    if (session != null &&
           (session.isOpened() || session.isClosed()) ) {
        onSessionStateChange(session, session.getState(), null);
    }
    uiHelper.onResume();
}

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
    super.onActivityResult(requestCode, resultCode, data);
    uiHelper.onActivityResult(requestCode, resultCode, data);
}

@Override
public void onPause() {
    super.onPause();
    uiHelper.onPause();
}

@Override
public void onDestroy() {
    super.onDestroy();
    uiHelper.onDestroy();
}

@Override
public void onSaveInstanceState(Bundle outState) {
    super.onSaveInstanceState(outState);
    uiHelper.onSaveInstanceState(outState);
}
 }
这里有两种类型的证书指纹,调试和发布

要在窗口中显示调试证书指纹,只需打开cmd 然后键入命令:

首先检查java路径变量

命令后更改用户名。keytool-list-v-keystore C:/Users/xxxxx/.android/debug.keystore-别名androiddebugkey

要显示发布证书指纹,您需要创建 释放密钥库并对.APK进行一次签名

1.找到sh-1或md5的简单方法

符号apk的切圆表示日食中的sh-1或md5

或 2.-打开cmd并键入命令:keytool-list-v-keystore-alias

keytool-list-v-keystore C:/release\u certificate\u name-别名 别名

其中:是密钥库的路径和名称。 是您在以下情况下分配给证书的别名: 是你创造的


如果我理解正确,请检查

,这是我应该做的:1对.APK文件进行签名导出。收集密钥库别名。2把这个放在命令里。3找到密钥库的路径并将其粘贴到命令中。4找到我的openssl地址并将其粘贴到命令中。是这样吗?我觉得不需要使用openssl。如果我的问题有帮助,请接受ans。