安卓如何将日志写入文件

6

在安卓中,默认情况下,Log类会将日志写入控制台(logcat)。是否有一种简单的方法来将日志写入文件中?


如果你采用天真的方法,只是打开一个文件句柄并在那里写入 - 你将会写入到你的Android设备上的文件系统,而你需要的可能是你的开发机器上的文件系统? - justadreamer
我想将Logcat消息导出到文件中。 - Yury Pogrebnyak
3
这个库也许是你想要的:http://code.google.com/p/android-log-collector/。 - SERPRO
3
请看这个链接:https://dev59.com/EnI-5IYBdhLWcg3woJ9J。 - Michael Wang
好的,我想这里有一个可接受的解决方案 http://code.google.com/p/microlog4android/ - Yury Pogrebnyak
显示剩余4条评论
4个回答

10

一个简单的Log类(仅用于开发/测试目的),类似于android.util.Log,但日志记录到SD卡。 唯一对现有代码的修改将是更改import android.util.Logimport com.example.Log。 还需要添加权限:

<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

package com.example.logger;

import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.text.SimpleDateFormat;
import java.util.Date;  

import android.os.Environment;

public class Log {
    private static final String NEW_LINE =  System.getProperty("line.separator") ; 
    public static boolean mLogcatAppender = true;
    final static File mLogFile;

    static {
        mLogFile = new File( Environment.getExternalStorageDirectory(),  "logs.log" ); 
        if ( !mLogFile.exists() ) {
            try {
                mLogFile.createNewFile();
            }
            catch (final IOException e) {
                e.printStackTrace();
            }
        }
        logDeviceInfo();
    }

    public static void i( String TAG, String message ){
        appendLog( TAG + " : " + message );
        if ( mLogcatAppender ) {
            android.util.Log.i( TAG, message );
        }
    }

    public static void d( String TAG, String message ){
        appendLog( TAG + " : " + message );
        if ( mLogcatAppender ) {
            android.util.Log.d( TAG, message );
        }
    }

    public static void e( String TAG, String message ){
        appendLog( TAG + " : " + message );
        if ( mLogcatAppender ) {
            android.util.Log.e( TAG, message );
        }
    }

    public static void v(String TAG, String message ){
        appendLog(TAG + " : " + message);
        if ( mLogcatAppender ) {
            android.util.Log.v( TAG, message );
        }
    }

    public static void w( String TAG, String message ) {
        appendLog( TAG + " : " + message );
        if ( mLogcatAppender ) {
            android.util.Log.w( TAG, message ); 
        }
    }

    private static synchronized void appendLog( String text ) {
        final SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");

        try {
            final FileWriter fileOut = new FileWriter( mLogFile, true );
            fileOut.append( sdf.format(new Date()) + " : " + text + NEW_LINE ); 
            fileOut.close();
        }
        catch ( final IOException e ) {
            e.printStackTrace();
        }
    }

    private static void logDeviceInfo() {
        appendLog("Model : " + android.os.Build.MODEL);
        appendLog("Brand : " + android.os.Build.BRAND);
        appendLog("Product : " + android.os.Build.PRODUCT);
        appendLog("Device : " + android.os.Build.DEVICE);
        appendLog("Codename : " + android.os.Build.VERSION.CODENAME);
        appendLog("Release : " + android.os.Build.VERSION.RELEASE);
    }

}

1
如果这只是为了开发目的,您可以在设备上调用logcat并将其输出重定向到文件中。例如:adb shell logcat > log.txt
或者,您可以尝试将stdoutstderr重定向到文件,我记得这样做可以,但我没有带手机来测试。
然而,更容易的方法是创建自己的基本日志记录类,它可以执行与内置日志记录器相同的操作,但也可以保存到文件中。

0
在Eclipse ddms中,有一个选项可以将日志保存到文件中。

-1

使用FileInputStream将所有错误消息重定向到文件


4
他要怎么做呢?你能提供一些链接或示例代码吗? - Gray

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接