相信大家在做应用调试的时候,不可能时时通过USB线连着电脑去查看log信息,所以,将应用的log信息保存到手机本地就很有必要了,有助我们从这些log信息中提取有用的部分,以解决一些bug,下面我把网上分享的代码中作了一些精简,作为开发者使用,个人觉得没必要通过用户上传给我们,用户上传的不需要这么庞大的log信息,仅仅那部分崩溃的log信息即可,可参考我的另外一篇blog:http://blog.csdn.net/weidi1989/article/details/7927273

好了,废话不多说,直接分享封装好的log信息类:LogcatHelper

  1. package com.way.util;
  2. import java.io.BufferedReader;
  3. import java.io.File;
  4. import java.io.FileNotFoundException;
  5. import java.io.FileOutputStream;
  6. import java.io.IOException;
  7. import java.io.InputStreamReader;
  8. import android.content.Context;
  9. import android.os.Environment;
  10. /**
  11. * log日志统计保存
  12. *
  13. * @author way
  14. *
  15. */
  16. public class LogcatHelper {
  17. private static LogcatHelper INSTANCE = null;
  18. private static String PATH_LOGCAT;
  19. private LogDumper mLogDumper = null;
  20. private int mPId;
  21. /**
  22. *
  23. * 初始化目录
  24. *
  25. * */
  26. public void init(Context context) {
  27. if (Environment.getExternalStorageState().equals(
  28. Environment.MEDIA_MOUNTED)) {// 优先保存到SD卡中
  29. PATH_LOGCAT = Environment.getExternalStorageDirectory()
  30. .getAbsolutePath() + File.separator + "miniGPS";
  31. } else {// 如果SD卡不存在,就保存到本应用的目录下
  32. PATH_LOGCAT = context.getFilesDir().getAbsolutePath()
  33. + File.separator + "miniGPS";
  34. }
  35. File file = new File(PATH_LOGCAT);
  36. if (!file.exists()) {
  37. file.mkdirs();
  38. }
  39. }
  40. public static LogcatHelper getInstance(Context context) {
  41. if (INSTANCE == null) {
  42. INSTANCE = new LogcatHelper(context);
  43. }
  44. return INSTANCE;
  45. }
  46. private LogcatHelper(Context context) {
  47. init(context);
  48. mPId = android.os.Process.myPid();
  49. }
  50. public void start() {
  51. if (mLogDumper == null)
  52. mLogDumper = new LogDumper(String.valueOf(mPId), PATH_LOGCAT);
  53. mLogDumper.start();
  54. }
  55. public void stop() {
  56. if (mLogDumper != null) {
  57. mLogDumper.stopLogs();
  58. mLogDumper = null;
  59. }
  60. }
  61. private class LogDumper extends Thread {
  62. private Process logcatProc;
  63. private BufferedReader mReader = null;
  64. private boolean mRunning = true;
  65. String cmds = null;
  66. private String mPID;
  67. private FileOutputStream out = null;
  68. public LogDumper(String pid, String dir) {
  69. mPID = pid;
  70. try {
  71. out = new FileOutputStream(new File(dir, "GPS-"
  72. + MyDate.getFileName() + ".log"));
  73. } catch (FileNotFoundException e) {
  74. // TODO Auto-generated catch block
  75. e.printStackTrace();
  76. }
  77. /**
  78. *
  79. * 日志等级:*:v , *:d , *:w , *:e , *:f , *:s
  80. *
  81. * 显示当前mPID程序的 E和W等级的日志.
  82. *
  83. * */
  84. // cmds = "logcat *:e *:w | grep \"(" + mPID + ")\"";
  85. // cmds = "logcat  | grep \"(" + mPID + ")\"";//打印所有日志信息
  86. // cmds = "logcat -s way";//打印标签过滤信息
  87. cmds = "logcat *:e *:i | grep \"(" + mPID + ")\"";
  88. }
  89. public void stopLogs() {
  90. mRunning = false;
  91. }
  92. @Override
  93. public void run() {
  94. try {
  95. logcatProc = Runtime.getRuntime().exec(cmds);
  96. mReader = new BufferedReader(new InputStreamReader(
  97. logcatProc.getInputStream()), 1024);
  98. String line = null;
  99. while (mRunning && (line = mReader.readLine()) != null) {
  100. if (!mRunning) {
  101. break;
  102. }
  103. if (line.length() == 0) {
  104. continue;
  105. }
  106. if (out != null && line.contains(mPID)) {
  107. out.write((MyDate.getDateEN() + "  " + line + "\n")
  108. .getBytes());
  109. }
  110. }
  111. } catch (IOException e) {
  112. e.printStackTrace();
  113. } finally {
  114. if (logcatProc != null) {
  115. logcatProc.destroy();
  116. logcatProc = null;
  117. }
  118. if (mReader != null) {
  119. try {
  120. mReader.close();
  121. mReader = null;
  122. } catch (IOException e) {
  123. e.printStackTrace();
  124. }
  125. }
  126. if (out != null) {
  127. try {
  128. out.close();
  129. } catch (IOException e) {
  130. e.printStackTrace();
  131. }
  132. out = null;
  133. }
  134. }
  135. }
  136. }
  137. }

记得加上权限:

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

另外把那个时间的工具类也分享一下:

  1. package com.way.util;
  2. import java.text.SimpleDateFormat;
  3. import java.util.Date;
  4. public class MyDate {
  5. public static String getFileName() {
  6. SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
  7. String date = format.format(new Date(System.currentTimeMillis()));
  8. return date;// 2012年10月03日 23:41:31
  9. }
  10. public static String getDateEN() {
  11. SimpleDateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
  12. String date1 = format1.format(new Date(System.currentTimeMillis()));
  13. return date1;// 2012-10-03 23:41:31
  14. }
  15. }

OK,所有事情做完之后,在我们的应用中start一下就OK了,使用完之后,记得调用一下stop:

    1. public class GPSApplication extends Application {
    2. @Override
    3. public void onCreate() {
    4. // TODO Auto-generated method stub
    5. LogcatHelper.getInstance(this).start();
    6. }
    7. }

原文:http://blog.csdn.net/way_ping_li/article/details/8487866

Android将应用log信息保存文件的更多相关文章

  1. LogcatHelperDemo【应用log信息保存成本地文件】

    版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 简单记录下LogcatHelper的使用,并对原有代码进行了修改[因为保存到应用内的目录中不需要申请权限,所以去掉保存到SD的功能- ...

  2. Android将程序崩溃信息保存本地文件

    大家都知道,现在安装Android系统的手机版本和设备千差万别,在模拟器上运行良好的程序安装到某款手机上说不定就出现崩溃的现象,开发者个人不可能购买所有设备逐个调试,所以在程序发布出去之后,如果出现了 ...

  3. 【Android Developers Training】 25. 保存文件

    注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...

  4. 解决在web项目使用log4j中无法将log信息写入文件

    这是log4j.properties中关于的配置 log4j.appender.appender2.File=F:/myeclipseworkspace2/SecondBook2/log/second ...

  5. android 项目中log信息的正确处理

    我们在做项目中,调试程序的时候通常是debug或者打log,特别是看一些json数据之类的,都喜欢打log看看,可是在项目上线时log信息一定不能被打印出来,大家能够平时下载一些做的烂的app,连接e ...

  6. openwrt 下python程序后台运行,并将打印信息保存文件

    python -u gw20191223.py  > test.log 1 2 & "python" 表示执行python代码 "-u" 表示不启 ...

  7. 查看Android系统中硬件信息的文件

    文件目录: 使用Linux命令,进入到/proc目录 进入/proc目录,可以查看内存信息(memoinfo)或CPU信息(cpuinfo),使用cat命令

  8. python开发_搜索本地文件信息写入文件

    功能:#在指定的盘符,如D盘,搜索出与用户给定后缀名(如:jpg,png)相关的文件 #然后把搜索出来的信息(相关文件的绝对路径),存放到用户指定的 #文件(如果文件不存在,则建立相应的文件)中 之前 ...

  9. Android开发过程中在sh,py,mk文件中添加log信息的方法

    Android开发过程中在sh,py,mk文件中添加log信息的方法 在sh文件中: echo "this is a log info" + $info 在py文件中: print ...

随机推荐

  1. 使用Html.fromHtml将html格式字符串应用到textview上面

    在android中,有一个容易遗忘的Html.fromhtml方法,意思是可以将比如文本框中的字符串进行HTML格式化,支持的还是很多的, 但要注意的是要在string.xml中用<!--cda ...

  2. vs2012布局问题

    问题背景: 北大青鸟ASP.Net视频中,老师提到可以通过更改属性PageLayout的值,来实现页面布局由默认的FlowLayout(流式布局)而成为GridLayout(网格布局),即系统控件安排 ...

  3. WCF - Windows Service Hosting

    WCF - Windows Service Hosting The operation of Windows service hosting is a simple one. Given below ...

  4. 个人比较喜欢的Sublime Text主题

    Monokai Bright Pastels on Dark Sunburst Twilight Flatland Dark Flatland Monokai

  5. c#继承中的函数调用

    首先看下面的代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 using System;   namespace Test {     public cl ...

  6. "is not on any development teams " Xcode的账号错误问题

    "***@*** is not on any development teams " Xcode现在在"Accounts"中时不时会出现这个提示. 但其他按钮都 ...

  7. .NET平台上的Memcached客户端介绍(Memcached Providers)

    早上接到一个任务,需要对Linux服务器的Memcached的update操作进行性能测试,我发现我是一个典型的“手里拿着锤子,就把所有问题都当成钉子”的人.我第一个念头就是,上Memcached的官 ...

  8. 设置oracle11g空表exp导出

    1.Oracle11g默认对空表不分配segment,故使用exp导出Oracle11g数据库时,空表不会导出. 2.设置deferred_segment_creation 参数为FALSE后,无论是 ...

  9. POJ2236 Wireless Network 并查集

    水题 #include<cstdio> #include<cstring> #include<queue> #include<set> #include ...

  10. codeforces 652C Foe Pairs 水题

    题意:给你若干个数对,给你一个序列,保证数对中的数都在序列中 对于这个序列,询问有多少个区间,不包含这些数对 分析:然后把这些数对转化成区间,然后对于这些区间排序,然后扫一遍,记录最靠右的左端点就好 ...