Atualize a solução compatível de Rongyun 4.0 e superior

Atualize a solução compatível de Rongyun 4.0 e superior

Ao atualizar da versão 2.10.6 para a versão 4.0, encontrei alguns buracos e resumi algumas experiências deles.Espero que seja útil para aqueles que lerem este artigo.

Há basicamente apenas um método que relatará um erro ao atualizar o SDK e é o método de conexão connectWithToken. Como a forma de retorno de chamada desse método mudou na versão 4.0 e posteriores, é necessário "excluir o retorno de chamada ilegal token de interface de conexão e alterar a lógica de processamento, movido para o retorno de chamada de erro "

Código de amostra:

O código a seguir usa o IMKit como exemplo, IMLib pode modificar a classe principal correspondente.

  • vantagem iOS

     [[RCIM sharedRCIM] connectWithToken:token
                 dbOpened:^(RCDBErrorCode code) {
                     //如果消息数据库打开,可以进入到主页面
                 }
                 success:^(NSString *userId) {
                     //连接成功
                 }
                 error:^(RCConnectErrorCode status) {
                     if (status == RC_CONN_TOKEN_INCORRECT) {
                         //将旧版本 token 非法的回调处理代码写到这里
                         //从 APP 服务获取新 token,并重连
                     } else {
                         //无法连接 im 服务器,请根据相应的错误码作出对应处理
                     }
                 }];
  • Lado Android

    RongIM.connect(token, new RongIMClient.ConnectCallback() {
          @Override
          public void onDatabaseOpened(RongIMClient.DatabaseOpenStatus code) {
              //如果消息数据库打开,可以进入到主页面
          }
    
          @Override
          public void onSuccess(String s) {
              //连接成功
          }
    
          @Override
          public void onError(RongIMClient.ErrorCode e) {
              if(e.equals(RongIMClient.ErrorCode.RC_CONN_USER_OR_PASSWD_ERROR)) {
                  //将旧版本 token 非法的回调处理代码写到这里
                  //从 APP 服务获取新 token,并重连                  
              }else {
                  //无法连接 im 服务器,请根据相应的错误码作出对应处理
              }
          }
    });

Nota

No SDK 4.0 e superior, haverá alguns códigos de erro sem retorno de chamada de erro. Recomenda-se lidar com isso de acordo com a situação:

* 用户第一次登录,设置 timeLimit 为有效值,网络极差情况下超时回调 error。
* 用户后续登录,调用没有 timeLimit 的接口,SDK 就会保持旧版本的自动重连。

Acho que você gosta

Origin blog.51cto.com/15056506/2678294
Recomendado
Clasificación