Android GCMRegistrar getRegistrationId返回空ID
可能重复:Android GCMRegistrar getRegistrationId返回空ID,android,google-cloud-messaging,Android,Google Cloud Messaging,可能重复: 我已经遵循了在我的应用程序中实现GCM的步骤,但是 final String regId = GCMRegistrar.getRegistrationId(this); 返回恩皮。一直如此 我正确地放置了所有权限 代码如下: public void registerPush(){ GCMRegistrar.checkDevice(this); GCMRegistrar.checkManifest(this); final String reg
我已经遵循了在我的应用程序中实现GCM的步骤,但是
final String regId = GCMRegistrar.getRegistrationId(this);
返回恩皮。一直如此
我正确地放置了所有权限
代码如下:
public void registerPush(){
GCMRegistrar.checkDevice(this);
GCMRegistrar.checkManifest(this);
final String regId = GCMRegistrar.getRegistrationId(this);
REG_ID = regId;
if (regId.equals("")) {
GCMRegistrar.register(this, this.getString(R.string.SENDER_ID));
} else {
if (GCMRegistrar.isRegisteredOnServer(this)) {
// Skips registration.
} else {
// Try to register again, but not in the UI thread.
// It's also necessary to cancel the thread onDestroy(),
// hence the use of AsyncTask instead of a raw thread.
final Context context = this;
mRegisterTask = new AsyncTask<Void, Void, Void>() {
@Override
protected Void doInBackground(Void... params) {
boolean registered = forceRegister(context, regId);
// At this point all attempts to register with the app
// server failed, so we need to unregister the device
// from GCM - the app will try to register again when
// it is restarted. Note that GCM will send an
// unregistered callback upon completion, but
// GCMIntentService.onUnregistered() will ignore it.
if (!registered) {
GCMRegistrar.unregister(context);
}
return null;
}
@Override
protected void onPostExecute(Void result) {
mRegisterTask = null;
}
};
mRegisterTask.execute(null, null, null);
}
}
}
public void registerPush(){
GCMRegistar.检查装置(本);
GCMRegistar.检查清单(本);
最终字符串regId=gcmregistar.getRegistrationId(this);
注册号=注册号;
if(regId.equals(“”){
gcmregistar.register(this,this.getString(R.string.SENDER_ID));
}否则{
if(GCMRegistrar.isRegisteredOnServer(本)){
//跳过注册。
}否则{
//尝试再次注册,但不要在UI线程中注册。
//还需要取消onDestroy()线程,
//因此,使用AsyncTask而不是原始线程。
最终上下文=此;
mRegisterTask=newasynctask(){
@凌驾
受保护的Void doInBackground(Void…参数){
布尔注册=强制注册(上下文,regId);
//此时,所有尝试向应用程序注册的用户
//服务器失败,因此我们需要注销设备
//从GCM-应用程序将在
//它已重新启动。请注意,GCM将发送
//完成时未注册的回调,但
//gcminentService.onUnregisted()将忽略它。
如果(!已注册){
GCMRegistar.unregister(上下文);
}
返回null;
}
@凌驾
受保护的void onPostExecute(void结果){
mRegisterTask=null;
}
};
mRegisterTask.execute(null,null,null);
}
}
}
谢谢你的帮助
编辑:manifest.xml
当您第一次安装应用程序时,注册id将为空。因此,请在此处将字符串regestarionid设置为static,并在gcminentservice.java上进行更改
@Override
protected void onRegistered(Context context, String registrationId) {
Log.i(TAG, "Device registered: regId = " + registrationId);
yourcallingactivity.regId = registrationId;
CommonUtilities.displayMessage(context, getString(R.string.gcm_registered));
ServerUtilities.register(context, registrationId);
}
你在打电话吗
final String regId = GCMRegistrar.getRegistrationId(this);
以前
GCMRegistrar.register(this, this.getString(R.string.SENDER_ID));
第一次运行应用程序时尚未注册
还要检查GCMinentService类是否具有空构造函数:
public class GCMIntentService extends GCMBaseIntentService {
public GCMIntentService() {
super(SENDER_ID);
}
@Override
protected void onRegistered(Context context, String registrationId) {
Log.i("GCMIntentService", "Device registered: regId = " + registrationId);
}
}
并将SENDER\u ID
作为public static final String SENDER\u ID=“YOUR\u GOOGLE\u PROYECT\u ID”代码>
希望能有帮助。对我来说,解决这个问题的办法是设备卡在了唤醒锁中
长话短说,日志指出它试图在这里找到我的服务:
IntentService类:com.myapppackage.gcminentservice
我想在这里指出:
IntentService类:com.myapppackage.gcm.gcminentservice
因此,我扩展了广播接收器,如下所示:
package com.myapppackage.gcm;
import android.content.Context;
public class GCMBroadcastReceiver extends
com.google.android.gcm.GCMBroadcastReceiver {
@Override
protected String getGCMIntentServiceClassName(Context context) {
return "com.myapppackage.gcm.GCMIntentService";
}
}
然后,我更新了清单以反映更改:
<receiver
android:name="com.myapppackage.gcm.GCMBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND" >
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
<category android:name="com.myapppackage" />
</intent-filter>
</receiver>
此意向服务将由GCMBroadcastReceiver调用(其中
由GCM库提供),如下一步所示。一定是
com.google.android.gcm.GCMBaseIntentService的子类必须
包含公共构造函数,并且应命名为
my_app_package.gcminentservice(除非您使用
GCMBroadcastReceiver,它重写用于命名
服务)
我能说什么呢,我是金牛座的我喜欢把我的东西整理得井井有条 但在教程中,这是这样的。。。你在ADV上测试吗?如果是这样,请检查API上低于16的GoogleAccount。logcat什么也没说?标签是gcmregistar。我正在我的手机上(在jelly bean上)进行测试,logcat什么也没说示例gcm应用程序工作正常吗?你能在这个问题上包括清单吗?我用我尝试过的清单编辑了这篇文章,但结果是相同的问题。每次都是空id。我的日志注册了以下内容:V/gcmregistar(2409):注册发件人的app com.myapp 12345678912和V/GCMBroadcastReceiver(2409):onReceive:com.google.android.c2dm.intent.REGISTRATION和V/GCMBroadcastReceiver(2409):GCM IntentService类:com.myapp.gcminentservice和V/GCMBaseIntentService(2409):获取WakeLock检查GCMinentService的构造函数,确保您有一个类似public GCMinentService(){super(SENDER_ID);}
的构造函数,并在清单中检查包:@nseminiuk可能是其他任何东西,因为我已正确设置了服务(与gcm演示示例相同)。我的舱单和上面的相似。但是你被困在了唤醒锁中。。。我认为是因为GCMRegistar找不到接收器,或者接收器设置不正确。我也遇到过类似的问题,它们都是由错误的包裹名称引起的。让我们特别感谢链接到解释。我第一次注册时面临问题,钥匙总是空的。但下次注册时每次都会出现。你知道吗?为什么第一次是空的?天哪,哈拉尔多,我能嫁给你的大脑吗?它真的很好用。在过去的一个小时里,我的头都碎了。你救了我。我对你的答案投了赞成票。非常感谢!我遇到了同样的问题,花了3天时间,但在得到你的建议之前无法解决!现在对我有用了!
<receiver
android:name="com.myapppackage.gcm.GCMBroadcastReceiver"
android:permission="com.google.android.c2dm.permission.SEND" >
<intent-filter>
<action android:name="com.google.android.c2dm.intent.RECEIVE" />
<action android:name="com.google.android.c2dm.intent.REGISTRATION" />
<category android:name="com.myapppackage" />
</intent-filter>
</receiver>