android开发异常信息收集程序代码

2024-06-23 08:08

本文主要是介绍android开发异常信息收集程序代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

首先创建全局的Application ,此Application全局通用。

package com.demo.utils;import com.demo.exception.CrashHandler;
import android.app.Application;
/*** 全局的context,任意位置调用* @author Administrator**/
public class GlobalApplication extends Application
{private static GlobalApplication instance;public static GlobalApplication getInstance(){return instance;}@Overridepublic void onCreate(){super.onCreate();instance = this;CrashHandler crashHandler = CrashHandler.getInstance();//这是收集异常信息的单例类,具体代码请看下文crashHandler.init(getApplicationContext());//初始化}
}

注意:上面的代码需要在注册清单文件中注册。部分清单如下:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"package="com.demo.test"android:versionCode="1"android:versionName="1.0" ><uses-sdkandroid:minSdkVersion="8"android:targetSdkVersion="18" /><!-- 网络 --><uses-permission android:name="android.permission.INTERNET" /><!-- 访问sdcard --><uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" /><!-- 获取mac需要的网络状态 --><uses-permission android:name="andorid.permission.CHANGE_CONFIGURATION" /><uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" /><uses-permission android:name="android.permission.CHANGE_WIFI_STATE" /><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /><applicationandroid:name="com.demo.utils.GlobalApplication"android:allowBackup="true"android:icon="@drawable/app_icon"android:label="@string/app_name"android:theme="@style/AppTheme" ><activityandroid:name="com.demo.activity.MyActivity"android:launchMode="singleTask"android:screenOrientation="landscape"android:theme="@android:style/Theme.NoTitleBar" ><intent-filter><action android:name="android.intent.action.MAIN" /><category android:name="android.intent.category.LAUNCHER" /></intent-filter></activity></activity></application></manifest>

crashHandler

package com.demo.exception;import java.io.FileOutputStream;
import java.io.PrintWriter;
import java.io.StringWriter;
import java.io.Writer;
import java.lang.Thread.UncaughtExceptionHandler;
import java.lang.reflect.Field;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;import android.content.Context;
import android.content.pm.PackageInfo;
import android.content.pm.PackageManager;
import android.content.pm.PackageManager.NameNotFoundException;
import android.os.Build;
import android.os.Looper;import com.demo.utils.ConstantUtils;
import com.demo.utils.PathUtils;
import com.demo.utils.log.MyLog;/*** UncaughtException处理类,当程序发生Uncaught异常的时候,有该类来接管程序,并记录发送错误报告.* * @author user* 实现
UncaughtExceptionHandler接口*/
public class CrashHandler implements UncaughtExceptionHandler
{public static final String TAG = "bug";//系统默认的UncaughtException处理类 private Thread.UncaughtExceptionHandler mDefaultHandler;//CrashHandler实例private static CrashHandler INSTANCE = new CrashHandler();//程序的Context对象private Context mContext;//用来存储设备信息和异常信息private Map<String, String> infos = new HashMap<String, String>();//用于格式化日期,作为日志文件名的一部分private DateFormat formatter = new SimpleDateFormat("yyyy-MM-dd-HH-mm-ss");/** 保证只有一个CrashHandler实例 */private CrashHandler(){}/** 获取CrashHandler实例 ,单例模式 */public static CrashHandler getInstance(){return INSTANCE;}/*** 初始化* * @param context*/public void init(Context context){mContext = context;//获取系统默认的UncaughtException处理器mDefaultHandler = Thread.getDefaultUncaughtExceptionHandler();//设置该CrashHandler为程序的默认处理器Thread.setDefaultUncaughtExceptionHandler(this);}/*** 当UncaughtException发生时会转入该函数来处理*/@Overridepublic void uncaughtException(Thread thread, Throwable ex){if (!handleException(ex) && mDefaultHandler != null){//如果用户没有处理则让系统默认的异常处理器来处理mDefaultHandler.uncaughtException(thread, ex);}else{try{Thread.sleep(3000);}catch (InterruptedException e){MyLog.e(TAG, "error : ", e);}mDefaultHandler.uncaughtException(thread, ex);//退出程序//            android.os.Process.killProcess(android.os.Process.myPid());//            System.exit(1);}}/*** 自定义错误处理,收集错误信息 发送错误报告等操作均在此完成.* * @param ex* @return true:如果处理了该异常信息;否则返回false.*/private boolean handleException(Throwable ex){if (ex == null){return false;}//使用Toast来显示异常信息new Thread(){@Overridepublic void run(){Looper.prepare();//                Toast.makeText(mContext, "很抱歉,程序出现异常,即将退出.", Toast.LENGTH_LONG).show();Looper.loop();}}.start();//收集设备参数信息 collectDeviceInfo(mContext);//保存日志文件 MyLog.i(TAG, "ex:" + ex.toString() + "--" + ex.getLocalizedMessage());saveCrashInfo2File(ex);return true;}/*** 收集设备参数信息* @param ctx*/public void collectDeviceInfo(Context ctx){try{PackageManager pm = ctx.getPackageManager();PackageInfo pi = pm.getPackageInfo(ctx.getPackageName(), PackageManager.GET_ACTIVITIES);if (pi != null){String versionName = pi.versionName == null ? "null" : pi.versionName;String versionCode = pi.versionCode + "";infos.put("versionName", versionName);infos.put("versionCode", versionCode);}}catch (NameNotFoundException e){MyLog.e(TAG, "an error occured when collect package info", e);}Field[] fields = Build.class.getDeclaredFields();for (Field field : fields){try{field.setAccessible(true);}catch (Exception e){MyLog.e(TAG, "an error occured when collect crash info", e);}}}/*** 保存错误信息到文件中* * @param ex* @return    返回文件名称,便于将文件传送到服务器*/private String saveCrashInfo2File(Throwable ex){StringBuffer sb = new StringBuffer();//        for (Map.Entry<String, String> entry : infos.entrySet())//        {//            String key = entry.getKey();//            String value = entry.getValue();//            sb.append(key + "=" + value + "\n");//        }Writer writer = new StringWriter();PrintWriter printWriter = new PrintWriter(writer);ex.printStackTrace(printWriter);Throwable cause = ex.getCause();while (cause != null){MyLog.i(TAG, "cause:" + cause.toString() + "--");cause.printStackTrace(printWriter);cause = cause.getCause();}printWriter.close();String result = writer.toString();MyLog.i(TAG, "result:" + result);sb.append(result);try{long timestamp = System.currentTimeMillis();String time = formatter.format(new Date());String fileName = "crash-" + time + "-" + timestamp + ".log";if (ConstantUtils.isOnline){fileName = "crash-online.log";}String path = PathUtils.BUGPATH;FileOutputStream fos = new FileOutputStream(path + fileName);fos.write(sb.toString().getBytes());fos.close();return fileName;}catch (Exception e){MyLog.e(TAG, "an error occured while writing file...", e);}return null;}
}
上面信息涉及到下面的几个类ConstantUtils,PathUtils和MyLog

constantUtils

public class ConstantUtils
{/***是否上线版本***/public final static boolean isOnline = false;/**** 时间格式*/public static String timeFormat = "yyyy-MM-dd HH:mm:ss";
}

MyLog

package com.demo.utils.log;import java.text.SimpleDateFormat;
import java.util.Date;import android.util.Log;import com.demo.utils.ConstantUtils;
import com.demo.utils.PathUtils;public class MyLog
{private static String filename = "log.txt";/**** 打印日志* @param tag* @param msg*/public static void d(String tag, String msg){if (!ConstantUtils.isOnline){Log.d(tag, msg);}}/**** 打印日志* @param tag* @param msg*/public static void i(String tag, String msg){if (!ConstantUtils.isOnline){Log.i(tag, msg);}}/**** 打印日志* @param tag* @param msg*/public static void e(String tag, String msg){if (!ConstantUtils.isOnline){Log.e(tag, msg);}}/**** 打印日志* @param tag* @param msg*/public static void e(String tag, String msg, Throwable tr){if (!ConstantUtils.isOnline){Log.e(tag, msg, tr);}}/**** 打印日志* @param tag* @param msg*/public static void w(String tag, String msg){if (!ConstantUtils.isOnline){Log.w(tag, msg);}}/**** 写入文本到日志文件中* @param value*/public static void write(String value){if (!ConstantUtils.isOnline){String newValue = getDataFormat(System.currentTimeMillis()) + "  " + value;LogUtils.getInstances().write(PathUtils.LOGPATH, filename, newValue);}}/**** 获取当前时间* @param timeInMillis* @return*/private static String getDataFormat(long timeInMillis){SimpleDateFormat dataFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");return dataFormat.format(new Date(timeInMillis));}}

pathutils

package com.demo.utils;import java.io.File;import android.os.Environment;public class PathUtils
{public final static String sdcardPath = Environment.getExternalStorageDirectory() + "";public final static String PATH = sdcardPath + "/exception/" + AppUtils.getAppPackageName();public final static String BUGPATH = PATH + "/bug/";public final static String LOGPATH = PATH + "/log/";public PathUtils(){File PATH = new File(PathUtils.PATH);if (!PATH.exists()){PATH.mkdirs();}File LOGPATH = new File(PathUtils.LOGPATH);if (!LOGPATH.exists()){LOGPATH.mkdirs();}File BUGPATH = new File(PathUtils.BUGPATH);if (!BUGPATH.exists()){BUGPATH.mkdirs();}}
}



这篇关于android开发异常信息收集程序代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1086603

相关文章

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

使用Python开发一个现代化屏幕取色器

《使用Python开发一个现代化屏幕取色器》在UI设计、网页开发等场景中,颜色拾取是高频需求,:本文主要介绍如何使用Python开发一个现代化屏幕取色器,有需要的小伙伴可以参考一下... 目录一、项目概述二、核心功能解析2.1 实时颜色追踪2.2 智能颜色显示三、效果展示四、实现步骤详解4.1 环境配置4.

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

Python使用smtplib库开发一个邮件自动发送工具

《Python使用smtplib库开发一个邮件自动发送工具》在现代软件开发中,自动化邮件发送是一个非常实用的功能,无论是系统通知、营销邮件、还是日常工作报告,Python的smtplib库都能帮助我们... 目录代码实现与知识点解析1. 导入必要的库2. 配置邮件服务器参数3. 创建邮件发送类4. 实现邮件

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

基于Python开发一个有趣的工作时长计算器

《基于Python开发一个有趣的工作时长计算器》随着远程办公和弹性工作制的兴起,个人及团队对于工作时长的准确统计需求日益增长,本文将使用Python和PyQt5打造一个工作时长计算器,感兴趣的小伙伴可... 目录概述功能介绍界面展示php软件使用步骤说明代码详解1.窗口初始化与布局2.工作时长计算核心逻辑3

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法

《Linux查看系统盘和SSD盘的容量、型号及挂载信息的方法》在Linux系统中,管理磁盘设备和分区是日常运维工作的重要部分,而lsblk命令是一个强大的工具,它用于列出系统中的块设备(blockde... 目录1. 查看所有磁盘的物理信息方法 1:使用 lsblk(推荐)方法 2:使用 fdisk -l(

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1