1. 程式人生 > >android JPushInterface.setAlias 報錯 java.lang.NullPointerException: Attempt to invoke virtual method

android JPushInterface.setAlias 報錯 java.lang.NullPointerException: Attempt to invoke virtual method

報錯內容:

06-20 16:47:49.519: E/AndroidRuntime(21018): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.zipingfang.wanhucang/com.heiyue.project.ui.IndexActivity}: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.String.intern()' on a null object reference
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2460)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2522)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.ActivityThread.access$800(ActivityThread.java:167)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1417)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.os.Handler.dispatchMessage(Handler.java:111)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.os.Looper.loop(Looper.java:179)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.ActivityThread.main(ActivityThread.java:5543)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at java.lang.reflect.Method.invoke(Native Method)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at java.lang.reflect.Method.invoke(Method.java:372)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:955)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:750)
06-20 16:47:49.519: E/AndroidRuntime(21018): Caused by: java.lang.NullPointerException: Attempt to invoke virtual method 'java.lang.String java.lang.String.intern()' on a null object reference
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.content.IntentFilter.addCategory(IntentFilter.java:1167)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at cn.jpush.android.service.ServiceInterface.a(Unknown Source)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at cn.jpush.android.api.JPushInterface.a(Unknown Source)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at cn.jpush.android.api.JPushInterface.setAliasAndTags(Unknown Source)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at cn.jpush.android.api.JPushInterface.setAlias(Unknown Source)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at com.heiyue.project.dao.ServerDao.setJpushAlias(ServerDao.java:198)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at com.heiyue.project.ui.IndexActivity.initViews(IndexActivity.java:55)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at com.heiyue.project.base.BaseActivity.onCreate(BaseActivity.java:151)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.Activity.performCreate(Activity.java:5975)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1111)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2413)
06-20 16:47:49.519: E/AndroidRuntime(21018): 	... 10 more

報錯位置:

public void setJpushAlias() {
		User cacheUser = getCacheUser();
		if (cacheUser == null) {
			return;
		}
		String tel = cacheUser.tel;
		
		if (!TextUtils.isEmpty(tel)) {
			LogOut.d("  繫結極光 ", " tel:" + tel);
			// 為極光設定別名,後臺使用使用者的賬戶id作為別名推送
			JPushInterface.setAlias(context, tel, new TagAliasCallback() {
				@Override
				public void gotResult(int arg0, String arg1, Set<String> arg2) {
					LogOut.d("  繫結極光 ", "[initJPush] 設定別名: " + "arg0:" + arg0
							+ ",arg1:" + arg1 + ",arg2:" + arg2);
					if (arg0 != 0) {
						// 設定失敗,重新設定
						setJpushAlias();
					}
				}
			});
		}
	}

準確的報錯位置是:
JPushInterface.setAlias(context, tel, new TagAliasCallback() {
解決方案



在libs下的每個子資料夾裡拷入相對應的so檔案

註明:如果上面的方法不能解決您的問題,那就需要升級一下jar檔案和so檔案了,我用的是,就解決了這個問題,如果您用的是205的版本,報這種錯誤,就可以用這種方式。