当前位置: 首页 > 编程笔记 >

Android将应用调试log信息保存在SD卡的方法

严嘉良
2023-03-14
本文向大家介绍Android将应用调试log信息保存在SD卡的方法,包括了Android将应用调试log信息保存在SD卡的方法的使用技巧和注意事项,需要的朋友参考一下

把自己应用的调试信息写入到SD卡中。

package com.sdmc.hotel.util;
import java.io.BufferedReader; 
import java.io.File; 
import java.io.FileNotFoundException; 
import java.io.FileOutputStream; 
import java.io.IOException; 
import java.io.InputStreamReader; 
import android.content.Context; 
import android.os.Environment; 
import android.util.Log;
/** 
* log日志统计保存 
* 会打印i,e,w,不会打印d
* 每次开启应用,就会把上次的log信息覆盖 
* @author way 
* 
*/ 
public class LogcatHelper { 
private static LogcatHelper INSTANCE = null; 
private static String PATH_LOGCAT; 
private LogDumper mLogDumper = null; 
private int mPId; 
/** 
* 
* 初始化目录 
* 
* */ 
public void init(Context context) { 
if (Environment.getExternalStorageState().equals( 
Environment.MEDIA_MOUNTED)) {// 优先保存到SD卡中 
PATH_LOGCAT = Environment.getExternalStorageDirectory() 
.getAbsolutePath() + File.separator + "miniGPS"; 
} else {// 如果SD卡不存在,就保存到本应用的目录下 
PATH_LOGCAT = context.getFilesDir().getAbsolutePath() 
+ File.separator + "miniGPS"; 
} 
File file = new File(PATH_LOGCAT); 
if (!file.exists()) { 
file.mkdirs(); 
} 
} 
public static LogcatHelper getInstance(Context context) { 
if (INSTANCE == null) { 
INSTANCE = new LogcatHelper(context); 
} 
return INSTANCE; 
} 
private LogcatHelper(Context context) { 
init(context); 
mPId = android.os.Process.myPid(); 
} 
public void start() { 
if (mLogDumper == null){ 
mLogDumper = new LogDumper(String.valueOf(mPId), PATH_LOGCAT); 
}
Log.i("path", PATH_LOGCAT);///storage/sdcard0/miniGPS
mLogDumper.start(); 
} 
public void stop() { 
if (mLogDumper != null) { 
mLogDumper.stopLogs(); 
mLogDumper = null; 
} 
} 
private class LogDumper extends Thread { 
private Process logcatProc; 
private BufferedReader mReader = null; 
private boolean mRunning = true; 
String cmds = null; 
private String mPID; 
private FileOutputStream out = null; 
public LogDumper(String pid, String dir) { 
mPID = pid; 
try { 
out = new FileOutputStream(new File(dir, "GPS-" 
+ MyDate.getFileName() + ".log")); 
} catch (FileNotFoundException e) { 
// TODO Auto-generated catch block 
e.printStackTrace(); 
} 
/** 
* 
* 日志等级:*:v , *:d , *:w , *:e , *:f , *:s 
* 
* 显示当前mPID程序的 E和W等级的日志. 
* 
* */ 
// cmds = "logcat *:e *:w | grep \"(" + mPID + ")\""; 
// cmds = "logcat | grep \"(" + mPID + ")\"";//打印所有日志信息 
// cmds = "logcat -s way";//打印标签过滤信息 
cmds = "logcat *:e *:i | grep \"(" + mPID + ")\"";//会打印i,e,w,不会打印d 
} 
public void stopLogs() { 
mRunning = false; 
} 
@Override 
public void run() { 
try { 
logcatProc = Runtime.getRuntime().exec(cmds); 
mReader = new BufferedReader(new InputStreamReader( 
logcatProc.getInputStream()), 1024); 
String line = null; 
while (mRunning && (line = mReader.readLine()) != null) { 
if (!mRunning) { 
break; 
} 
if (line.length() == 0) { 
continue; 
} 
if (out != null && line.contains(mPID)) { 
out.write((MyDate.getDateEN() + " " + 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 (out != null) { 
try { 
out.close(); 
} catch (IOException e) { 
e.printStackTrace(); 
} 
out = null; 
} 
} 
} 
} 
} 

系统权限

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

时间工具类:

package com.sdmc.hotel.util;
import java.text.SimpleDateFormat; 
import java.util.Date; 
public class MyDate { 
public static String getFileName() { 
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd"); 
String date = format.format(new Date(System.currentTimeMillis())); 
return date;// 2012年10月03日 23:41:31 
} 
public static String getDateEN() { 
SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
String date1 = format1.format(new Date(System.currentTimeMillis())); 
return date1;// 2012-10-03 23:41:31 
} 
}

方法的调用:

public class MyApplication extends Application { 
@Override 
public void onCreate() { 
LogcatHelper.getInstance(this).start(); 
} 
} 
 类似资料:
  • 目前,我的(使用的是Stackoverflow,我自己没有完整地编写)代码如下所示: 我得到错误:“打开失败;EACCES(权限被拒绝)”。 我的舱单是这样的:

  • 本文向大家介绍android将Bitmap对象保存到SD卡中的方法,包括了android将Bitmap对象保存到SD卡中的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了android将Bitmap对象保存到SD卡中的方法。分享给大家供大家参考。具体如下: 希望本文所述对大家的Android程序设计有所帮助。

  • 我一直在寻找保存音频到SdCard。 我还试图保存以下内容: 在这两种情况下,它都起作用,但会保存到内部存储中。从不使用SD卡 我使用getExternalFilesDirs()来创建。但如果用户卸载应用程序,则会丢失文件。 我不想那样。 如何将音频保存在SD卡公用文件夹中或创建新文件夹。 任何时候它都会创建到内部存储中。 有什么解决办法吗??? 我尝试了这个,我可以在SD卡中创建一个文档。还有一

  • 当我运行progressdialog出现在屏幕上时,它突然停止运行,并发出通知“应用程序停止了,再试一次”,然后我在android manitor上重复了这个错误,当然我首先要做的是:

  • 问题内容: 我尝试使用此代码下载图像并将其保存在以下行中: 我在emulator.my应用程序上尝试了此操作,但出现异常,没有权限保存到此路径: 我也添加了这一行: 这是代码: 问题答案:

  • 问题内容: 已关闭 。这个问题需要更加集中。它当前不接受答案。 想改善这个问题吗? 更新问题,使其仅通过编辑此帖子来关注一个问题。 5年前关闭。 我想允许我的客户用户输入他们的信用卡信息,这样我就可以每月向他们收费。 我不知道应该如何保存此信息? 应该将其保存在MySQL数据库(“用户”表)中还是这种信息过于敏感而需要存储在其他位置? 我对此没有经验,如果有人可以建议我如何实现这一目标,我将感到非