Java Facebook登录无法使用已签名的应用程序
我使用以下代码登录到Facebook。此登录过程在调试时工作,但不适用于已签名的应用程序。我在Facebook应用程序设置中添加了调试哈希键和释放哈希键,但没有成功。你知道这是什么原因吗Java Facebook登录无法使用已签名的应用程序,java,android,facebook,apk,facebook-login,Java,Android,Facebook,Apk,Facebook Login,我使用以下代码登录到Facebook。此登录过程在调试时工作,但不适用于已签名的应用程序。我在Facebook应用程序设置中添加了调试哈希键和释放哈希键,但没有成功。你知道这是什么原因吗 package com.priyank.safeboard; import java.util.Arrays; import android.content.Intent; import android.os.Bundle; import android.util.Log; import android.v
package com.priyank.safeboard;
import java.util.Arrays;
import android.content.Intent;
import android.os.Bundle;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import com.actionbarsherlock.app.SherlockFragment;
import com.facebook.Session;
import com.facebook.SessionState;
import com.facebook.UiLifecycleHelper;
import com.facebook.widget.LoginButton;
public class MainFragment extends SherlockFragment {
private static final String TAG = "MainFragment";
private UiLifecycleHelper uiHelper;
Button b;
LoginButton authButton;
@Override
public View onCreateView(LayoutInflater inflater,
ViewGroup container,
Bundle savedInstanceState) {
View view = inflater.inflate(R.layout.safeboardlogin, container, false);
authButton = (LoginButton) view.findViewById(R.id.authButton);
authButton.setFragment(this);
/*b=(Button) view.findViewById(R.id.button1);
b.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
updateDetail();
}
});*/
authButton.setReadPermissions(Arrays.asList("user_location", "user_birthday","user_likes", "user_status"));
return view;
}
protected void updateDetail() {
Intent intent = new Intent();
intent.setClass(getActivity(), MainActivity.class);
startActivity(intent);
}
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
uiHelper = new UiLifecycleHelper(getActivity(), callback);
uiHelper.onCreate(savedInstanceState);
}
@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);
}
private void onSessionStateChange(Session session, SessionState state, Exception exception) {
if (state.isOpened()) {
updateDetail();
authButton.setVisibility(View.INVISIBLE);
//b.setVisibility(View.VISIBLE);
Log.i(TAG, "Logged in...");
} else if (state.isClosed()) {
Log.i(TAG, "Logged out...");
}
}
private Session.StatusCallback callback = new Session.StatusCallback() {
@Override
public void call(Session session, SessionState state, Exception exception) {
onSessionStateChange(session, state, exception);
}
};
}
在log cat中调试应用程序时,我使用了以下代码获取应用程序的密钥哈希,但是如何获取已签名应用程序的“密钥哈希”
try {
PackageInfo info = getPackageManager().getPackageInfo(
"Your package name",
PackageManager.GET_SIGNATURES);
for (Signature signature : info.signatures) {
MessageDigest md = MessageDigest.getInstance("SHA");
md.update(signature.toByteArray());
Log.d("Your Tag", Base64.encodeToString(md.digest(), Base64.DEFAULT));
}
} catch (NameNotFoundException e) {
} catch (NoSuchAlgorithmException e) {
}
您唯一要更改的是iz应用程序签名,因此很明显,其中有一些与哈希有关的内容。Facebook给出了错误的散列计算方法。今天我也遇到了这个问题-这个解决方案:对我来说没问题。您唯一要更改的是iz应用程序签名,所以很明显,哈希有问题。Facebook给出了错误的散列计算方法。今天我也遇到了这个问题-这个解决方案对我来说很好。我喜欢那些白痴们无缘无故地拒绝投票的问题。我喜欢那些白痴们无缘无故地拒绝投票的问题。我已经用过了,并被提示输入密码和哈希键,但仍然无法进入我的应用程序发布版本::C:\程序Files\Java\jre7\bin>keytool-exportcert-alias signedkeyalias-keystore“C:\Users\priyankmandalia\desktop\keystrename”|“C:\Openssl\bin\Openssl”sha1-binary |“C:\Openssl\bin\Openssl”base64链接的答案以facebook的方式计算哈希,因此它似乎是最可靠的。你有什么错误?我已经有了正确的调试哈希标记,它工作正常,但我无法登录到有发布哈希标记的已签名应用程序。那么如何获得正确的签名应用程序哈希标记呢?我已经使用了这段代码并获得了调试应用程序的密钥哈希。但是如何获取签名应用程序的密钥散列:尝试{PackageInfo=getPackageManager().getPackageInfo(“您的包名”,PackageManager.GET_SIGNATURES);for(Signature Signature:info.SIGNATURES){MessageDigest md=MessageDigest.getInstance(“SHA”);md.update(signature.toByteArray());Log.d(“您的标记”,Base64.encodeToString(md.digest(),Base64.DEFAULT));}}catch(NameNotFoundException e){}catch(nosuchagorithmexception e){}我还需要提交应用程序详细信息以供审查,使其与在Google Play中发布的已签名应用程序配合使用吗?我已经使用了此应用程序,并被提示输入密码并获得哈希键,但仍然无法在我的应用程序发布版本中漫游::C:\Program Files\Java\jre7\bin>keytool-exportcert-alias signedkeyalias-keystore“C:\Users\priyankmandalia\desktop\keystername”|“C:\Openssl\bin\Openssl”sha1-binary |“C:\Openssl\bin\Openssl”"Base64链接答案以facebook的方式计算哈希值,因此它似乎是最可靠的。您有什么错误?我已经有了正确的调试哈希值标记,并且它工作正常,但我无法登录具有释放哈希值标记的已签名应用程序。那么如何获得正确的已签名应用程序哈希值标记?我使用了此代码并获得了t我的调试应用程序的密钥散列。但是如何获取签名应用程序的密钥散列:尝试{PackageInfo=getPackageManager().getPackageInfo(“您的包名”,PackageManager.GET_SIGNATURES);for(Signature Signature Signature:info.SIGNATURES){MessageDigest md=MessageDigest.getInstance(“SHA”);md.update(signature.toByteArray());Log.d(“您的标签”,Base64.encodeToString(md.digest(),Base64.DEFAULT));}}catch(NameNotFoundException e){}catch(nosuchalgorithexception e){}我还需要提交应用程序详细信息以供审核,使其与已签名的应用程序一起在Google Play中发布吗?