【主机】sendEmail发送带有附件的邮件

需求:

    从数据库获取数据并保存为CSV的文件,并把数据文件通过sendEmail以附件的形式发送到指定邮箱。

    这里主要利用sendEmail的: -m 邮件内容  -a 邮件附件 这两个参数来完成此工作。

shell 脚本:

#!/bin/sh

#function: get data from database and keep them in csv mode 

#then send the log and the csv file to var $TO

#author: yang qilong

#date: 2011 08 01

TODAY=`date +"%Y_%m_%d_%H%M%S"`

DIR='YANGDIR_TMP'

FILENAME=IM_REPORT_ERRINFO_$TODAY.csv

SQLCMD='select * from YANG.ERRINFO WHERE rownum <12'

LOGFILE=/tmp/oracle/get_im_report_errinfo.log

FROM=qilong.yangql@yangql.com

TO=yangqilong@163.com,yangql@163.com --为了发送至多人

sqlplus yang/yang  1>$LOGFILE  2>&1 <
select sysdate from dual;

exec sys.csv.generate('$DIR','$FILENAME','$SQLCMD');

exit;

EOF!

attach_file_list=/tmp/oracle/$FILENAME

/home/oracle/admin/bin/sendEmail -u "`whoami`@`hostname`:$attach_file_list" \

 -m  <$LOGFILE \ --以执行过程日志为文件的内容

 -f $FROM -s 172.18.100.3:25 -t $TO \

 -a $attach_file_list  -发送的附件

!<>

脚本输出:

oracle@rac1:rac1 /tmp/oracle>./test.sh  

SQL*Plus: Release 11.2.0.1.0 Production on Mon Aug 1 21:10:49 2011

Copyright (c) 1982, 2009, Oracle.  All rights reserved.

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

yang@rac1>

SYSDATE

-----------------------------

Aug 01 2011 21:10:49

yang@rac1>

PL/SQL procedure successfully completed.

yang@rac1>Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production

With the Partitioning, Real Application Clusters, Automatic Storage Management, OLAP,

Data Mining and Real Application Testing options

Reading message body from STDIN because the '-m' option was not used.

If you are manually typing in a message:

  - First line must be received within 60 seconds.

  - End manual input with a CTRL-D on its own line.

Aug 01 21:10:49 rac1 sendEmail[12684]: Message input complete.

Aug 01 21:10:49 rac1 sendEmail[12684]: Email was sent successfully!

oracle@rac1:rac1 /tmp/oracle>

附上此过程遇到的问题:

主要在 -m 的使用上,将执行结果重定向到 -m 的输入内容。但是中间有注释,写法如下:

/home/oracle/admin/bin/sendEmail -u "`whoami`@`hostname`:$attach_file_list" \

 -m "`whoami`@`hostname`:$attach_file_list" < /tmp/oracle/sql.log \

 #-m  

 -f qilong.yang@yangql.com -s 10.18.100.3:25 -t yangql@163..com \

 -a $attach_file_list

输出:

Aug 01 21:10:03 rac1 sendEmail[12628]: ERROR => You must specify a 'from' field!  Try --help.

./test.sh: line 22: -f: command not found

1 经过测试,发现sendEmail 语句中不能带#注释。

2 当格式为:
-m "`whoami`@`hostname`:$attach_file_list" < /tmp/oracle/sql.log 此方式 -m 发送的邮件的内容是:root@localhost.localdomain:/tmp/IM_REPORT_ERRINFO_2011_08_01_182007.csv  而不是我们想要的从数据库取数据的过程日志。

时间: 2025-01-30 11:55:27

【主机】sendEmail发送带有附件的邮件的相关文章

利用php中mail函数发送带有附件的邮件

mail函数,发送邮件 语法: mail(to,subject,message,headers,parameters) to 规定邮件的接收者 subject 规定邮件的主题.该参数不能包含任何换行字符 message 规定要发送的消息 headers 规定额外的报头,比如 From, Cc 以及 Bcc parameters 规定 sendmail 程序的额外参数. 碰到的主要问题是乱码问题,刚开始是某些客户端接收邮件时好(比如QQ邮箱,估计带自动那个识别编码)的有些不foxmail.ipad

ubuntu下发送带有附件的邮件的例子

一台服务器检查程序需要将检查结果自动发送给指定邮箱,想当然的使用mail命令,结果在测试时发现有错误: mail: cannot send message: process exited with a non-zero status 其没有提到明确的问题,但从其中提出的log查看,倒是发现了线索. 有两个log都记录了对应的信息,即syslog和mail.err.mail.err中的信息更明确: postfix/sendmail[27115]: fatal: open /etc/postfix/

java中javamail发送带附件的邮件实现方法_java

本文实例讲述了java中javamail发送带附件的邮件实现方法.分享给大家供大家参考.具体分析如下: JavaMail,顾名思义,提供给开发者处理电子邮件相关的编程接口.它是Sun发布的用来处理email的API.它可以方便地执行一些常用的邮件传输,JavaMail是可选包,因此如果需要使用的话你需要首先从java官网上下载.目前最新版本是JavaMail1.5.0,下面我们来看看javamail发送带附件的邮件实例 mail.java 代码: 复制代码 代码如下: package mail;

kettle发送带附件的邮件

问题描述 kettle发送带附件的邮件 在用kettle发送带附件的邮件时,邮件能够发送成功,但是邮件里面没有附件,哪位大神给个成功的案例,或者帮忙看看是哪里的问题,谢谢! 解决方案 http://blog.csdn.net/ganggetwo/article/details/50914826 解决方案二: import java.io.File; import java.util.ArrayList; import java.util.List; import java.util.Proper

Codeigniter实现发送带附件的邮件

 这篇文章主要介绍了Codeigniter实现发送带附件的邮件的方法,涉及Codeigniter中attach方法的使用技巧,非常具有实用价值,需要的朋友可以参考下     本文实例讲述了Codeigniter实现发送带附件的邮件的方法.分享给大家供大家参考.具体分析如下: attach() 方法允许你的发邮件时带上附件,下面是演示代码 代码如下: $this->load->library('email'); $this->email->from('w3@w3mentor.com'

javamail-javaMail发送带附件的邮件时,png的附件可以发送而jpg的图片则会导致发送失败

问题描述 javaMail发送带附件的邮件时,png的附件可以发送而jpg的图片则会导致发送失败 同一个图片的png可以发送,而jpg格式发送失败,定位到代码处如下: // 保存邮件到指定的收件夹中 public boolean copyMessage(Message[] message, String folderName) throws MessagingException { openFolder(folderName, Folder.READ_WRITE);// 打开指定的邮件夹 fol

php简单实现发送带附件的邮件_php技巧

本文实例讲述了php简单实现发送带附件的邮件.分享给大家供大家参考.具体如下: 下面是静态html代码: <html> <head> <title>带附件的邮件发送</title> </head> <body> <form method="post" name="form1" action="sendmail.php" ENCTYPE="multipart/f

Codeigniter实现发送带附件的邮件_php实例

本文实例讲述了Codeigniter实现发送带附件的邮件的方法.分享给大家供大家参考.具体分析如下: attach() 方法允许你的发邮件时带上附件,下面是演示代码 复制代码 代码如下: $this->load->library('email'); $this->email->from('w3@w3mentor.com', 'W3M'); $this->email->subject('Email Test with attachment'); $this->ema

用vbs发送带附件的邮件_vbs

function Send_mail(You_Account,You_Password,Send_Email,Send_Email2,Send_Topic,Send_Body,Send_Attachment)  'code by NetPatch 'VBS发送邮件参数说明 'You_Account:你的邮件帐号 'You_Password:你的邮件密码 'Send_Email: 主要邮件地址 'Send_Email2: 备用邮件地址 'Send_Topic: 邮件主题 'Send_Body: