hivemqtt-client添加android log打印

hivemqtt-client原本是一個java后臺框架,集成到android并沒有android的log打印挽霉,但是我們可以添加防嗡。

由于hivemqtt-client是封裝的netty,所以我們想用netty的loggerHandler打印log侠坎,所以我們也需要修改源碼本鸣。

1.git下載源碼:https://github.com/hivemq/hivemq-mqtt-client.git ,修改源碼如下硅蹦,在MqttChannelInitializer類 添加LoggingHandler。

package com.hivemq.client.internal.mqtt.handler;
...
public class MqttChannelInitializer extends ChannelInboundHandlerAdapter {
...
private void initMqtt(@NotNull Channel channel) {
        channel.pipeline()
        .addLast("log", new LoggingHandler()) //添加netty的log打印
        .addLast("encoder", this.encoder)
        .addLast("auth", this.authHandler)
        .addLast("connect", this.connectHandler)
        .addLast("disconnect", this.disconnectHandler);
    }
}
...
1.2然后重新編譯出:hivemq-mqtt-client-1.3.4.jar即可,這個時候我們就直接依賴jar包了,但是由于hivemqtt-client不僅僅依賴netty還依賴其他的jar供常,所以我們需要添加其他的gradle build的依賴粟矿。
    implementation(name: 'hivemq-mqtt-client-1.3.4', ext: 'jar')
    //其他依賴
    implementation("io.netty:netty-buffer:4.1.99.Final")
    implementation("io.netty:netty-codec:4.1.99.Final")
    implementation("io.netty:netty-common:4.1.99.Final")
    implementation("io.netty:netty-handler:4.1.99.Final")
    implementation("io.netty:netty-transport:4.1.99.Final")

    implementation 'com.google.dagger:dagger:2.27'
    annotationProcessor 'com.google.dagger:dagger-compiler:2.27'

    implementation("org.jctools:jctools-core:2.1.2")
    implementation("org.jetbrains:annotations:16.0.3")

2.android添加方法和log類如下:

//在Application或初始化的時候添加AndroidInternalLogger類。
@Override
public void onCreate() {
      InternalLoggerFactory.setDefaultFactory(new InternalLoggerFactory() {
          @Override
         protected InternalLogger newInstance(String name) {
            return new AndroidInternalLogger(name); //名字即為tag
         }
    });
...
}

添加AndroidInternalLogger類實(shí)現(xiàn)如下:

import android.util.Log;

import java.net.UnknownHostException;

import io.netty.util.internal.logging.InternalLogLevel;
import io.netty.util.internal.logging.InternalLogger;

/**
 * @Author zhikong
 * @Date 17:55
 */
public class AndroidInternalLogger implements InternalLogger {
    private String TAG;

    public AndroidInternalLogger(String name) {
        TAG = name;
    }

    @Override
    public String name() {
        return TAG;
    }

    @Override
    public boolean isTraceEnabled() {
        return true;
    }

    @Override
    public void trace(String msg) {
        Log.v(TAG, msg);
    }

    @Override
    public void trace(String format, Object arg) {
        Log.v(TAG, String.format(format, arg));
    }

    @Override
    public void trace(String format, Object argA, Object argB) {
        Log.v(TAG, String.format(format, argA, argB));
    }

    @Override
    public void trace(String format, Object... arguments) {
        Log.v(TAG, String.format(format, arguments));
    }

    @Override
    public void trace(String msg, Throwable t) {
        Log.v(TAG, msg, t);
    }

    @Override
    public void trace(Throwable t) {
        Log.v(TAG, "trace", t);
    }

    @Override
    public boolean isDebugEnabled() {
        return true;
    }

    @Override
    public void debug(String msg) {
        Log.d(TAG, msg);
    }

    @Override
    public void debug(String format, Object arg) {
        Log.d(TAG, String.format(format, arg));
    }

    @Override
    public void debug(String format, Object argA, Object argB) {
        Log.d(TAG, String.format(format, argA, argB));
    }

    @Override
    public void debug(String format, Object... arguments) {
        Log.d(TAG, String.format(format, arguments));
    }

    @Override
    public void debug(String msg, Throwable t) {
        Log.d(TAG, msg, t);
    }

    @Override
    public void debug(Throwable t) {
        Log.d(TAG, "debug", t);
    }

    @Override
    public boolean isInfoEnabled() {
        return true;
    }

    @Override
    public void info(String msg) {
        Log.i(TAG, msg);
    }

    @Override
    public void info(String format, Object arg) {
        Log.i(TAG, String.format(format, arg));
    }

    @Override
    public void info(String format, Object argA, Object argB) {
        Log.i(TAG, String.format(format, argA, argB));
    }

    @Override
    public void info(String format, Object... arguments) {
        Log.i(TAG, String.format(format, arguments));
    }

    @Override
    public void info(String msg, Throwable t) {
        Log.i(TAG, msg, t);
    }

    @Override
    public void info(Throwable t) {
        Log.i(TAG, "info", t);
    }


    @Override
    public boolean isWarnEnabled() {
        return true;
    }

    @Override
    public void warn(String msg) {
        Log.w(TAG, msg);
    }

    @Override
    public void warn(String format, Object arg) {
        Log.w(TAG, String.format(format, arg));
    }

    @Override
    public void warn(String format, Object argA, Object argB) {
        Log.w(TAG, String.format(format, argA, argB));
    }

    @Override
    public void warn(String format, Object... arguments) {
        Log.w(TAG, String.format(format, arguments));
    }

    @Override
    public void warn(String msg, Throwable t) {
        Log.w(TAG, msg, t);
    }

    @Override
    public void warn(Throwable t) {
        Log.w(TAG, "warn", t);
    }


    @Override
    public boolean isErrorEnabled() {
        return true;
    }

    @Override
    public void error(String msg) {
        Log.e(TAG, msg);
    }

    @Override
    public void error(String format, Object arg) {
        Log.e(TAG, String.format(format, arg));
    }

    @Override
    public void error(String format, Object argA, Object argB) {
        Log.e(TAG, String.format(format, argA, argB));
    }

    @Override
    public void error(String format, Object... arguments) {
        Log.e(TAG, String.format(format, arguments));
    }

    @Override
    public void error(String msg, Throwable t) {
        if (t instanceof UnknownHostException) {
            Log.e(TAG, msg + ":" + t.getMessage());
        } else {
            Log.e(TAG, msg, t);
        }
    }

    @Override
    public void error(Throwable t) {
        Log.e(TAG, "error", t);
    }


    @Override
    public boolean isEnabled(InternalLogLevel level) {
        return true;
    }

    @Override
    public void log(InternalLogLevel level, String msg) {
        switch (level) {
            case DEBUG:
                Log.d(TAG, msg);
                break;
            case INFO:
                Log.i(TAG, msg);
                break;
            case WARN:
                Log.w(TAG, msg);
                break;
            case ERROR:
                Log.e(TAG, msg);
                break;
            default:
                Log.v(TAG, msg); // 默認(rèn)情況下涩金,如果沒有匹配的級別,可以使用VERBOSE級別
        }
    }

    @Override
    public void log(InternalLogLevel level, String format, Object arg) {
        switch (level) {
            case DEBUG:
                Log.d(TAG, String.format(format, arg));
                break;
            case INFO:
                Log.i(TAG, String.format(format, arg));
                break;
            case WARN:
                Log.w(TAG, String.format(format, arg));
                break;
            case ERROR:
                Log.e(TAG, String.format(format, arg));
                break;
            default:
                Log.v(TAG, String.format(format, arg)); // 默認(rèn)情況下,如果沒有匹配的級別生音,可以使用VERBOSE級別
        }
    }

    @Override
    public void log(InternalLogLevel level, String format, Object argA, Object argB) {
        switch (level) {
            case DEBUG:
                Log.d(TAG, String.format(format, argA, argB));
                break;
            case INFO:
                Log.i(TAG, String.format(format, argA, argB));
                break;
            case WARN:
                Log.w(TAG, String.format(format, argA, argB));
                break;
            case ERROR:
                Log.e(TAG, String.format(format, argA, argB));
                break;
            default:
                Log.v(TAG, String.format(format, argA, argB)); // 默認(rèn)情況下,如果沒有匹配的級別窒升,可以使用VERBOSE級別
        }
    }

    @Override
    public void log(InternalLogLevel level, String format, Object... arguments) {
        switch (level) {
            case DEBUG:
                Log.d(TAG, String.format(format, arguments));
                break;
            case INFO:
                Log.i(TAG, String.format(format, arguments));
                break;
            case WARN:
                Log.w(TAG, String.format(format, arguments));
                break;
            case ERROR:
                Log.e(TAG, String.format(format, arguments));
                break;
            default:
                Log.v(TAG, String.format(format, arguments)); // 默認(rèn)情況下缀遍,如果沒有匹配的級別,可以使用VERBOSE級別
        }
    }

    @Override
    public void log(InternalLogLevel level, String msg, Throwable t) {
        switch (level) {
            case DEBUG:
                Log.d(TAG, msg, t);
                break;
            case INFO:
                Log.i(TAG, msg, t);
                break;
            case WARN:
                Log.w(TAG, msg, t);
                break;
            case ERROR:
                Log.e(TAG, msg, t);
                break;
            default:
                Log.v(TAG, msg, t); // 默認(rèn)情況下饱须,如果沒有匹配的級別域醇,可以使用VERBOSE級別
        }
    }

    @Override
    public void log(InternalLogLevel level, Throwable t) {
        switch (level) {
            case DEBUG:
                Log.d(TAG, "Exception", t);
                break;
            case INFO:
                Log.i(TAG, "Exception", t);
                break;
            case WARN:
                Log.w(TAG, "Exception", t);
                break;
            case ERROR:
                Log.e(TAG, "Exception", t);
                break;
            default:
                Log.v(TAG, "Exception", t); // 默認(rèn)情況下,如果沒有匹配的級別,可以使用VERBOSE級別
        }
    }

}

最后譬挚,送上我編譯好的jar锅铅,包括重連,過濾tag:cong减宣。添加androidlog版的hivemq-mqtt-client.jar資源-CSDN文庫

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末盐须,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子漆腌,更是在濱河造成了極大的恐慌贼邓,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屉凯,死亡現(xiàn)場離奇詭異立帖,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)悠砚,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進(jìn)店門晓勇,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人灌旧,你說我怎么就攤上這事绑咱。” “怎么了枢泰?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵描融,是天一觀的道長。 經(jīng)常有香客問我衡蚂,道長窿克,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任毛甲,我火速辦了婚禮年叮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘玻募。我一直安慰自己只损,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布七咧。 她就那樣靜靜地躺著跃惫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪艾栋。 梳的紋絲不亂的頭發(fā)上爆存,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機(jī)與錄音裹粤,去河邊找鬼终蒂。 笑死蜂林,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的拇泣。 我是一名探鬼主播噪叙,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼霉翔!你這毒婦竟也來了睁蕾?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤债朵,失蹤者是張志新(化名)和其女友劉穎子眶,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體序芦,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡臭杰,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了谚中。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片渴杆。...
    茶點(diǎn)故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖宪塔,靈堂內(nèi)的尸體忽然破棺而出磁奖,到底是詐尸還是另有隱情,我是刑警寧澤某筐,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布比搭,位于F島的核電站,受9級特大地震影響南誊,放射性物質(zhì)發(fā)生泄漏身诺。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一抄囚、第九天 我趴在偏房一處隱蔽的房頂上張望戚长。 院中可真熱鬧,春花似錦怠苔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至锅劝,卻和暖如春攒驰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背故爵。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工玻粪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓劲室,卻偏偏與公主長得像伦仍,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子很洋,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,933評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 1 前言 年初做了一款A(yù)ndroid TV 應(yīng)用充蓝,用到了MQTT。主要實(shí)現(xiàn)的是類似一些景區(qū)利用大屏幕實(shí)時顯示景點(diǎn)人...
    wildma閱讀 74,898評論 51 173
  • afinalAfinal是一個android的ioc喉磁,orm框架 https://github.com/yangf...
    passiontim閱讀 15,431評論 2 45
  • afinalAfinal是一個android的ioc谓苟,orm框架 https://github.com/yangf...
    wgl0419閱讀 6,283評論 1 9
  • 別人的總結(jié)不一定適合自己,所以盡量多做一些自己的總結(jié)协怒,針對自己的薄弱點(diǎn)重點(diǎn)說明涝焙,適當(dāng)?shù)慕梃b別人,少走一些彎路孕暇。最重...
    renkuo閱讀 7,411評論 2 48
  • 用兩張圖告訴你仑撞,為什么你的 App 會卡頓? - Android - 掘金 Cover 有什么料? 從這篇文章中你...
    hw1212閱讀 12,724評論 2 59