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
Java Facebook登录无法使用已签名的应用程序_Java_Android_Facebook_Apk_Facebook Login - Fatal编程技术网

Java 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

我使用以下代码登录到Facebook。此登录过程在调试时工作,但不适用于已签名的应用程序。我在Facebook应用程序设置中添加了调试哈希键和释放哈希键,但没有成功。你知道这是什么原因吗

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中发布吗?