Android将日志信息自动发送到指定的邮箱中 邮件的内容以附件形式发送
今日整合了网上一些大神的例子(具体看了那些大神的?这个真不好意思我忘记了。下次再整合一定给大家补上,这次也只有默默的给那几个大神说声抱歉了。)做了一个“记录android项目中的日志信息,并将日志信息存放到手机客户端,然后自动发送到指定邮箱中的例子”。测demo我已经测试过了,是可以成功发送的。下面会告诉大家到哪里下载源代码。希望大家从中能够得到帮助。哈哈。
一、记录android项目中的异常日志类
package cn.yw.exception;
import java.io.File;
import java.io.FileOutputStream;
import java.lang.Thread.UncaughtExceptionHandler;
import android.content.Context;
import android.os.Environment;
import android.os.Looper;
import android.util.Log;
/**
* 在Application中统一捕获异常
* @author tony
*
*/
public class CrashHandler implements UncaughtExceptionHandler {
/**
* 是否开启日志输出,在debug状态下开启
* 在release状态下关闭以提示程序性能
*/
public static final boolean DEBUG = true;
/**
* 系统默认的UncaughtException处理类
*/
private Thread.UncaughtExceptionHandler mDefaultHandler;
private static CrashHandler INSTANCE;
private CrashHandler(){}
public static CrashHandler getInstance() {
if (INSTANCE == null) {
INSTANCE = new CrashHandler();
}
return INSTANCE;
}
/**
* 初始化,注册Context对象,
* 获取系统默认的UncaughtException处理器,
* 设置该CrashHandler为程序的默认处理器
*
* @param ctx
*/
public void init(Context ctx) {
mDefaultHandler = Thread.getDefaultUncaughtExceptionHandler();
Thread.setDefaultUncaughtExceptionHandler(this);
}
@Override
public void uncaughtException(Thread thread, Throwable ex) {
if (!handleException(ex) && mDefaultHandler != null) {
//如果用户没有处理则让系统默认的异常处理器来处理
mDefaultHandler.uncaughtException(thread, ex);
} else { //如果自己处理了异常,则不会弹出错误对话框,则需要手动退出app
try {
Thread.sleep(3000);
} catch (InterruptedException e) {
}
android.os.Process.killProcess(android.os.Process.myPid());
System.exit(10);
}
}
/**
* 自定义错误处理,收集错误信息
* 发送错误报告等操作均在此完成.
* 开发者可以根据自己的情况来自定义异常处理逻辑
* @return
* true代表处理该异常,不再向上抛异常,
* false代表不处理该异常(可以将该log信息存储起来)然后交给上层(这里就到了系统的异常处理)去处理,
* 简单来说就是true不会弹出那个错误提示框,false就会弹出
*/
private boolean handleException(final Throwable ex){
if(ex == null){
return false;
}
final StackTraceElement[] stack = ex.getStackTrace();
final String message = ex.getMessage();
new Thread() {
@Override
public void run() {
Looper.prepare();
String fileName = "crash-test.log";
File file = new File(Environment.getExternalStorageDirectory(), fileName);
Log.e("path", ""+Environment.getExternalStorageDirectory());
try {
FileOutputStream fos = new FileOutputStream(file,true);
fos.write(message.getBytes());
for (int i = 0; i < stack.length; i++) {
fos.write(stack[i].toString().getBytes());
}
fos.flush();
fos.close();
} catch (Exception e) {
}
Looper.loop();
}
}.start();
return false;
}
}
二、Application类
package mi.email.activity;
import android.app.Application;
import cn.yw.exception.CrashHandler;
public class GApplication extends Application{
@Override
public void onCreate() {
super.onCreate();
CrashHandler crashHandler = CrashHandler.getInstance();
crashHandler.init(getApplicationContext());
}
}
三、一键发送邮件的activity(邮件的主要代码都在这个类中,需要给位修改的地方已经加上了注释)
package mi.email.activity;
import java.util.Properties;
import javax.activation.DataHandler;
import javax.activation.FileDataSource;
import javax.mail.MessagingException;
import javax.mail.Session;
import javax.mail.Transport;
import javax.mail.internet.InternetAddress;
import javax.mail.internet.MimeBodyPart;
import javax.mail.internet.MimeMessage;
import javax.mail.internet.MimeMultipart;
import mi.email.core.PassAuthenticator;
import mi.learn.com.R;
import android.app.Activity;
import android.os.Bundle;
import android.os.Environment;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
/**
* 一键发送邮件
* @author tony
*
*/
public class MailActivity extends Activity {
private Button btnOK;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.mail);
btnOK = (Button) findViewById(R.id.btnOK);
btnOK.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
sendEmail();
}
});
}
/**
* 发送邮件的方法
* @return
*/
private boolean sendEmail(){
Properties props = new Properties();
props.put("mail.smtp.protocol", "smtp");
props.put("mail.smtp.auth", "true");//设置要验证
props.put("mail.smtp.host", "smtp.163.com");//设置host
props.put("mail.smtp.port", "25"); //设置端口
PassAuthenticator pass = new PassAuthenticator(); //获取帐号密码
Session session = Session.getInstance(props, pass); //获取验证会话
try
{
//配置发送及接收邮箱
InternetAddress fromAddress, toAddress;
/**
* 这个地方需要改成自己的邮箱
*/
fromAddress = new InternetAddress("发送邮箱", "自己给自己发");
toAddress = new InternetAddress("接收邮箱", "自己接收自己发的邮件");
/**
* 一下内容是:发送邮件时添加附件
*/
MimeBodyPart attachPart = new MimeBodyPart();
FileDataSource fds = new FileDataSource(Environment.getExternalStorageDirectory()+"/crash-fortrun.log"); //打开要发送的文件
attachPart.setDataHandler(new DataHandler(fds));
attachPart.setFileName(fds.getName());
MimeMultipart allMultipart = new MimeMultipart("mixed"); //附件
allMultipart.addBodyPart(attachPart);//添加
//配置发送信息
MimeMessage message = new MimeMessage(session);
// message.setContent("test", "text/plain");
message.setContent(allMultipart); //发邮件时添加附件
message.setSubject("这次发送仅作测试");
message.setFrom(fromAddress);
message.addRecipient(javax.mail.Message.RecipientType.TO, toAddress);
message.saveChanges();
//连接邮箱并发送
Transport transport = session.getTransport("smtp");
/**
* 这个地方需要改称自己的账号和密码
*/
transport.connect("smtp.163.com", "账号", "密码");
transport.send(message);
transport.close();
} catch (Exception e) {
throw new RuntimeException();//将此异常向上抛出,此时CrashHandler就能够接收这里抛出的异常并最终将其存放到txt文件中
// Log.e("sendmail", e.getMessage());
}
return false;
}
}
三、认证邮箱账号和密码的类
package mi.email.core;
import javax.mail.Authenticator;
import javax.mail.PasswordAuthentication;
public class PassAuthenticator extends Authenticator
{
public PasswordAuthentication getPasswordAuthentication()
{
/**
* 这个地方需要添加上自己的邮箱的账号和密码
*/
String username = "账号";
String pwd = "密码";
return new PasswordAuthentication(username, pwd);
}
}
四、xml文件就不写了,里面就一个按钮别的什么都没有。
备注:此demo需要引入3个jar包分别是activation.jar、 mail.jar 、additionnal.jar。
源代码下载地址http://download.csdn.net/detail/openopen_119/5846353
问题补充:上面的代码虽然发送邮件可以,但是当发送邮件的内容为中文是,在收件箱中会看到中文乱码(需要制定编码格式)
解决办法:message.setContent(content, "text/html;charset=GBK");
Android将日志信息自动发送到指定的邮箱中 邮件的内容以附件形式发送的更多相关文章
- 使用log4j使某些java类的日志信息输出到指定日志文件中
Log4j 是 Apache 的一个开放源代码项目,通过使用 Log4j,我们可以控制日志信息输送的目的地是控制台.文件.GUI 组件.甚至是套接口服务器.NT 的事件记录器.UNIX Syslog ...
- 使用log4j将不同级别的日志信息输出到不同的文件中
使用log4j.xml xml格式的配置文件可以使用filter. 例如想只把log4j的debug信息输出到debug.log.error信息输出到error.log,info信息输出到info.l ...
- 【API管理 APIM】如何查看APIM中的Request与Response详细信息,如Header,Body中的参数内容
问题描述 通过APIM门户或者是Developer门户,我们可以通过Test功能测试某一个接口,通过Trace可以获取非常详细的Request,Response的信息,包含Header,X-Forwa ...
- Android Studio日志工具的使用
Android Studio的LogCat工具 Verbose:对应Log.v(),这个方法用于打印那些最为琐碎的信息,意义最小的日志信息.是Android日志里面级别最低的一种. Debug:对应L ...
- Log4J日志信息配置文件详解
原文地址: http://blog.csdn.net/wuxintdrh/article/details/78282097 使用log4j 记录日志甚是方便,其提供了两种日志配置方式,log4j.pr ...
- VisualSVN:强制必须填写日志信息
上回将到怎么修改已提交的版本日志信息,而开发项目过程中团队中总是有人忘记添加日志信息注释直接提交,这样会后期维护带来不便. 现在先演示一下效果 当直接提交一个空白日志信息时 有填写日志信息时 那怎么实 ...
- java解析邮箱中的邮件信息
import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Value; import ...
- Android中日志信息的打印方式
Android中日志信息的打印方式主要有以下7种: 1)System.out(i级别) 2)System.err(w级别) 3)Log.v 4)Log.d 5)Log.i 6)Log.w 7)Log. ...
- 【转载】理解Android中垃圾回收日志信息
本文转自:http://droidyue.com/blog/2014/11/08/understanding-garbage-collection-output-messages-in-android ...
随机推荐
- DRF序列化/反序列化
反序列化(不推荐版):两个字段 一个为正序准备,一个为反序准备重写create update方法 1. 确定数据结构: 自己定义key book_obj = { "title": ...
- Echarts地图绘制(散点,色卡)
echarts绘制地图时,提供了js内部注册,也提供了json数据手动注册,这两种都可以绘制对应地图,但有一点不同的是,js内部只注册了中国地图和世界地图,而json数据提供了世界,中国,中国城市的数 ...
- Java基础笔记(2) 程序入口 关键字 标识符 常量 变量
提醒:关于那些和我一样新鸟来看资料的,能看懂多少看多少,看不懂的就是不重要,重要的你想我自己学习肯定要标注的,这些信息明白每个知识点实际作用就好了,其他的比如等会讲的常量内存,常量池这些都是我找的资料 ...
- js替换数组中字符串实例
这个是替换数组中的一个对象字符串: 直接上代码: var aaa=[ {"name":"张珊","sex":"man"} ...
- 第一篇 Windows docker 概述
本人行业属于智能制造,偏向工厂应用,客户端程序全部是.Net 的 WinForm:本系统的后台是.Net,多系统交互的有java的:因系统发布效率问题,想采用docker Windows 的生产力环境 ...
- leveldb源码阅读
http://blog.csdn.net/sparkliang/article/details/8567602 http://brg-liuwei.github.io/tech/2014/10/15/ ...
- SQL Server自动备份 备份到本地或者远程服务器
0.1 在SQLServer2008 --> 备份数据库 --> 安全 --> 新建用户 --> 用户名 选择该windows用户 (确保 --> 机器名/人名 --&g ...
- 跨过Django的坑
在最近的Django的学习中,慢慢的开始踩坑,开此栏,专为收纳Django的坑,在以后的学习中以便警示.(使用工具为pycharm专业版2018.2.4,python3.5.2,Django版本2.1 ...
- python基础学习7----编码与解码
一.python2 python2中默认以ASCII编码 str='hello world' gbk_to_unicode=str.decode('gbk')#将gbk解码为unicode print ...
- Linux学习之路-2017/12/22
第三章 管道符.重定向与环境变量 管道命令符,“|”,作用是将前一个命令的标准输出当作后一个命令的标准输入, 格式:“命令A|命令B” 输入输出重定向, 标准输入,STDIN,文件描述符为0,默认从 ...