Android本地文件日志記錄

一、背景
對(duì)于有些公司對(duì)安全性要求比較高,可能不會(huì)使用第三方(例如 Bugly)柱恤。這個(gè)是需要自己記錄日志排查現(xiàn)場(chǎng)問(wèn)題,而且有時(shí)候客戶是內(nèi)網(wǎng)下使用找爱,沒(méi)法把信息發(fā)送到自己的服務(wù)器梗顺。那么,本地日志文件保存是很有必要的车摄。

二寺谤、實(shí)現(xiàn)
思路:就是可以同cmd把Logcat所有的日志都寫到文件中。它可以直接把所有的信息都寫入到文件中吮播,包括崩潰信息矗漾,Android Log信息,也包括flutter的崩潰信息薄料,print信息等敞贡,只要是在Android Studio中Logcat輸出的信息都能保存都本地。

三摄职、代碼

package hik.fp.baseline.port.common.util;

import android.content.Context;
import android.os.Environment;

import com.ezviz.stream.LogUtil;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStreamReader;

/**
 * @Description: 把日志寫到本地
 * @date 2020/12/23 
 */
public class LogcatHelper {
    public static final String TAG = "LogcatHelper";
    private static String pathLogcat;
    private static volatile LogcatHelper mInstance;
    String cmds = null;
    private Process logcatProc;
    private LogDumper mLogDumper;
    private int mPid;

    private LogcatHelper(Context context) {
      init(context);
      mPid = android.os.Process.myPid();
    }

    public static LogcatHelper newInstance(Context context) {
        if (mInstance == null) {
            synchronized (LogcatHelper.class) {
                if (mInstance == null) {
                    mInstance = new LogcatHelper(context);
                }
            }
        }
        return mInstance;
    }

    /**
     * 初始化目錄
     */
    private void init(Context context) {

//        String path = "";
        if (Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)) {
            //保存在SD卡中
            pathLogcat = Environment.getExternalStorageDirectory().getPath() + "/logInfo/";
        } else {
            //保存到應(yīng)用目錄下 todo 需要測(cè)試
            pathLogcat = context.getFilesDir().getAbsolutePath() + "/logInfo/";
        }

        File file = new File(pathLogcat);
        if (!file.exists()) {
            file.mkdirs();
            LogUtil.e(TAG, "創(chuàng)建文件夾");
        }
        LogUtil.e(TAG, pathLogcat);
    }

    public void start(){
        if (mLogDumper == null){
            mLogDumper = new LogDumper(String.valueOf(mPid),pathLogcat);
        }
        mLogDumper.start();
    }

    public void stop(){
        if (mLogDumper != null){
            mLogDumper.stopLogs();
            mLogDumper = null;
        }
    }

    private class LogDumper extends Thread {
        private String mPid;
        private FileOutputStream outputStream = null;
        private BufferedReader mReader = null;
        private boolean mIsRunning = true;

        public LogDumper(String pid, String dir) {
            mPid = pid;
            long timeMillis = System.currentTimeMillis();
            //錯(cuò)誤日志文件名稱
            String fileName = "hikvison-log" + timeMillis + ".log";
            try {
                outputStream = new FileOutputStream(new File(dir,fileName ));
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            }
            //顯示當(dāng)前mPid程序的日志等級(jí)  日志等級(jí):*:v , *:d , *:w , *:e , *:f , *:s
            // cmds = "logcat *:e *:w | grep \"(" + mPid + ")\"";
             cmds = "logcat  | grep \"(" + mPid + ")\"";//打印所有日志信息
            // cmds = "logcat -s way";//打印標(biāo)簽過(guò)濾信息
//            cmds = "logcat *:e *:i | grep \"(" + mPid + ")\"";
        }

        public void stopLogs(){
            mIsRunning = false;
        }

        @Override
        public void run() {
            try {
                logcatProc = Runtime.getRuntime().exec(cmds);
                mReader = new BufferedReader(new InputStreamReader(logcatProc.getInputStream()),1024);
                String line = null;
                while (mIsRunning && (line = mReader.readLine()) != null){
                    if (!mIsRunning){
                        break;
                    }
                    if (line.length() == 0){
                        continue;
                    }
                    if (outputStream != null && line.contains(mPid)){
                        outputStream.write((line+"\n").getBytes());
                    }
                }
            } catch (IOException e) {
                e.printStackTrace();
            }finally {
                if (logcatProc != null){
                    logcatProc.destroy();
                    logcatProc = null;
                }
                if (mReader != null){
                    try {
                        mReader.close();
                        mReader = null;
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                }
                if (outputStream != null){
                    try {
                        outputStream.close();
                    } catch (IOException e) {
                        e.printStackTrace();
                    }
                    outputStream = null;
                }
            }
        }
    }
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末誊役,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子谷市,更是在濱河造成了極大的恐慌蛔垢,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件迫悠,死亡現(xiàn)場(chǎng)離奇詭異鹏漆,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)创泄,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門艺玲,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人鞠抑,你說(shuō)我怎么就攤上這事饭聚。” “怎么了搁拙?”我有些...
    開(kāi)封第一講書人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵秒梳,是天一觀的道長(zhǎng)法绵。 經(jīng)常有香客問(wèn)我,道長(zhǎng)酪碘,這世上最難降的妖魔是什么朋譬? 我笑而不...
    開(kāi)封第一講書人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮兴垦,結(jié)果婚禮上此熬,老公的妹妹穿的比我還像新娘。我一直安慰自己滑进,他們只是感情好犀忱,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著扶关,像睡著了一般阴汇。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上节槐,一...
    開(kāi)封第一講書人閱讀 49,837評(píng)論 1 290
  • 那天搀庶,我揣著相機(jī)與錄音,去河邊找鬼铜异。 笑死哥倔,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的揍庄。 我是一名探鬼主播咆蒿,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼蚂子!你這毒婦竟也來(lái)了沃测?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤食茎,失蹤者是張志新(化名)和其女友劉穎蒂破,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體别渔,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡附迷,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了哎媚。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片喇伯。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖抄伍,靈堂內(nèi)的尸體忽然破棺而出艘刚,到底是詐尸還是另有隱情,我是刑警寧澤截珍,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布攀甚,位于F島的核電站,受9級(jí)特大地震影響岗喉,放射性物質(zhì)發(fā)生泄漏秋度。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一钱床、第九天 我趴在偏房一處隱蔽的房頂上張望荚斯。 院中可真熱鬧,春花似錦查牌、人聲如沸事期。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)兽泣。三九已至,卻和暖如春胁孙,著一層夾襖步出監(jiān)牢的瞬間唠倦,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工涮较, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留稠鼻,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓狂票,卻偏偏與公主長(zhǎng)得像候齿,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子闺属,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

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