解决阿里推送sdk 3.0以上初始化报“init cloudchannel failed -- errorcode:10212 -- errorMessage:静默连接进程未初始化”的问题

解决方案如下:

   @Override
    public void onCreate() {
        super.onCreate();
        //注意:这句要放到最前面执行,必须是 在 android:process=":channel"
        initCloudChannel(this);
        //我的项目是多进程,例如
         String processName = getProcessName();
        switch (processName) {
            case "com.xxx.xxx":
                init();
                break;
            case "com.xxx.xxx:childprocess":
               init2();
                break;
            default:
                break;
        }
        
  }
 /**
     * 初始化云推送通道
     *
     * @param applicationContext
     */
    private void initCloudChannel(Context applicationContext) {
        PushServiceFactory.init(applicationContext);
        CloudPushService pushService = PushServiceFactory.getCloudPushService();
        pushService.register(applicationContext, new CommonCallback() {
            @Override
            public void onSuccess(String response) {
                Log.d(TAG, "init cloudchannel success " + response);
            }

            @Override
            public void onFailed(String errorCode, String errorMessage) {
                Log.d(TAG, "init cloudchannel failed -- errorcode:" + errorCode + " -- errorMessage:" + errorMessage);
            }
        });
    }

一开始我的错误初始化如下

 @Override
    public void onCreate() {
        super.onCreate();
         String processName = getProcessName();
        switch (processName) {
            case "com.xxx.xxx":
                initCloudChannel(this); //注意:这句要放到最前面执行,必须是 在 android:process=":channel"
                init();
                break;
            case "com.xxx.xxx:childprocess":
               init2();
                break;
            default:
                break;
        }   
  }

然后就去官网搜了错误码 10212 常见错误码,找到一句“默认为channel进程”很关键,然后我去AndroidManifest.xml中看了一下android:process配置如下:

解决阿里推送sdk 3.0以上初始化报“init cloudchannel failed -- errorcode:10212 -- errorMessage:静默连接进程未初始化”的问题_第1张图片
看到阿里sdk都是自己开了一个channel进程来做推送保活操作,顺便看了一下PushExtActivity源码,发现里面开启一个1像素的界面,也就是双进程守护里面我们用到的qq保活1像素方案,有部分做了混淆,但是核心代码还是可以看的清楚。
解决阿里推送sdk 3.0以上初始化报“init cloudchannel failed -- errorcode:10212 -- errorMessage:静默连接进程未初始化”的问题_第2张图片

造成初始化失败原因总结

1、 用户在自定义Application中(如MyApplication)执行推送SDK初始化时做了进程判断,导致初始化操作只在主进程执行。其他进程中没有初始化
2、 用户在MainActivity中进行相关初始化,activity只会在主进程创建,导致相关操作只能在主进程执行。

你可能感兴趣的:(android,阿里推送3.0以上,errorcode:10212)