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