Saturday, December 30, 2017
Email a File from the Oracle Application Server
Email a File from the Oracle Application Server
Below is the most useful code snippet, that can be used to read a file from the application server or any concurrent program output file from the desired location
*********************************************************
declare
l_conn utl_smtp.connection;
l_file_handle UTL_FILE.FILE_TYPE;
l_dirpath VARCHAR2 (150) := /usr/tmp/;
l_filename VARCHAR2 (50) := Test.txt;
l_sender VARCHAR2 (50) := abc@gmail.com;
l_recpnt VARCHAR2 (255):= xyz@gmail.com;
l_msg VARCHAR2 (32767);
l_line VARCHAR2 (1000);
lc_message VARCHAR2 (1000);
crlf VARCHAR2 (2) := CHR (13) || CHR (10);
l_reply UTL_SMTP.REPLY;
l_clob CLOB := ;
l_subject VARCHAR2(2000) := This is a sample test email;
l_body VARCHAR2(2000) := Body email;
l_boundary VARCHAR2(50) := ----=*#abc1234321cba#*=;
ln_amount NUMBER := 0;
ln_temp NUMBER := 0;
l_filedata VARCHAR(32767);
begin
l_conn := utl_smtp.Open_Connection(127.0.0.1, 25);
utl_smtp.Helo(l_conn, 127.0.0.1);
utl_smtp.Mail(l_conn, l_sender);
utl_smtp.rcpt(l_conn, l_recpnt);
utl_smtp.open_data(l_conn);
l_filedata := l_filedata || Date: || TO_CHAR(SYSDATE, DD-MON-RRRR HH24:MI:SS) || crlf;
l_filedata := l_filedata || To: || l_recpnt || crlf;
l_filedata := l_filedata || From: || l_sender || crlf;
l_filedata := l_filedata || Subject: || l_subject || crlf;
l_filedata := l_filedata || MIME-Version: 1.0 || crlf;
l_filedata := l_filedata || Content-Type: multipart/mixed; boundary= ||chr(34)||l_boundary|| chr(34)||crlf;
l_filedata := l_filedata || --||l_boundary|| crlf;
l_filedata := l_filedata || Content-Type: text/plain;|| crlf ||
Content-Transfer_Encoding: 7bit|| crlf ||
crlf || l_body || crlf || crlf ||
--||l_boundary|| crlf ||
Content-Type: text/plain;|| crlf ||
name="||l_filename||"|| crlf ||
Content-Transfer_Encoding: 8bit|| crlf ||
Content-Disposition: attachment;|| crlf ||
filename="||l_filename||"|| crlf || crlf;
dbms_lob.createtemporary(l_clob, false, 10);
dbms_lob.write(l_clob, LENGTH(l_filedata), 1, l_filedata);
l_file_handle := UTL_FILE.FOPEN (l_dirpath, l_filename, R);
ln_temp := dbms_lob.getlength(l_clob) + 1;
LOOP
BEGIN
utl_file.get_line(l_file_handle, l_msg);
ln_temp := dbms_lob.getlength(l_clob) + 1;
IF DBMS_LOB.GETLENGTH(l_msg) > 0 THEN
dbms_lob.write(l_clob, LENGTH(l_msg)+1, ln_temp, l_msg||CHR(10));
END IF;
EXCEPTION
WHEN NO_DATA_FOUND THEN
EXIT;
END;
END LOOP;
utl_file.fclose(l_file_handle);
ln_temp := 1;
ln_amount := 1900;
WHILE ln_temp < dbms_lob.getlength(l_clob) LOOP
utl_smtp.write_data(l_conn, dbms_lob.substr(l_clob, ln_amount, ln_temp));
ln_temp := ln_temp + ln_amount;
ln_amount := least(1900, dbms_lob.getlength(l_clob) - ln_amount);
END LOOP;
utl_smtp.write_data(l_conn, crlf||crlf);
utl_smtp.close_data(l_conn);
utl_smtp.quit(l_conn);
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE(Error:||SQLERRM);
end;
*********************************************************
Print This Post
*********************************************************
declare
l_conn utl_smtp.connection;
l_file_handle UTL_FILE.FILE_TYPE;
l_dirpath VARCHAR2 (150) := /usr/tmp/;
l_filename VARCHAR2 (50) := Test.txt;
l_sender VARCHAR2 (50) := abc@gmail.com;
l_recpnt VARCHAR2 (255):= xyz@gmail.com;
l_msg VARCHAR2 (32767);
l_line VARCHAR2 (1000);
lc_message VARCHAR2 (1000);
crlf VARCHAR2 (2) := CHR (13) || CHR (10);
l_reply UTL_SMTP.REPLY;
l_clob CLOB := ;
l_subject VARCHAR2(2000) := This is a sample test email;
l_body VARCHAR2(2000) := Body email;
l_boundary VARCHAR2(50) := ----=*#abc1234321cba#*=;
ln_amount NUMBER := 0;
ln_temp NUMBER := 0;
l_filedata VARCHAR(32767);
begin
l_conn := utl_smtp.Open_Connection(127.0.0.1, 25);
utl_smtp.Helo(l_conn, 127.0.0.1);
utl_smtp.Mail(l_conn, l_sender);
utl_smtp.rcpt(l_conn, l_recpnt);
utl_smtp.open_data(l_conn);
l_filedata := l_filedata || Date: || TO_CHAR(SYSDATE, DD-MON-RRRR HH24:MI:SS) || crlf;
l_filedata := l_filedata || To: || l_recpnt || crlf;
l_filedata := l_filedata || From: || l_sender || crlf;
l_filedata := l_filedata || Subject: || l_subject || crlf;
l_filedata := l_filedata || MIME-Version: 1.0 || crlf;
l_filedata := l_filedata || Content-Type: multipart/mixed; boundary= ||chr(34)||l_boundary|| chr(34)||crlf;
l_filedata := l_filedata || --||l_boundary|| crlf;
l_filedata := l_filedata || Content-Type: text/plain;|| crlf ||
Content-Transfer_Encoding: 7bit|| crlf ||
crlf || l_body || crlf || crlf ||
--||l_boundary|| crlf ||
Content-Type: text/plain;|| crlf ||
name="||l_filename||"|| crlf ||
Content-Transfer_Encoding: 8bit|| crlf ||
Content-Disposition: attachment;|| crlf ||
filename="||l_filename||"|| crlf || crlf;
dbms_lob.createtemporary(l_clob, false, 10);
dbms_lob.write(l_clob, LENGTH(l_filedata), 1, l_filedata);
l_file_handle := UTL_FILE.FOPEN (l_dirpath, l_filename, R);
ln_temp := dbms_lob.getlength(l_clob) + 1;
LOOP
BEGIN
utl_file.get_line(l_file_handle, l_msg);
ln_temp := dbms_lob.getlength(l_clob) + 1;
IF DBMS_LOB.GETLENGTH(l_msg) > 0 THEN
dbms_lob.write(l_clob, LENGTH(l_msg)+1, ln_temp, l_msg||CHR(10));
END IF;
EXCEPTION
WHEN NO_DATA_FOUND THEN
EXIT;
END;
END LOOP;
utl_file.fclose(l_file_handle);
ln_temp := 1;
ln_amount := 1900;
WHILE ln_temp < dbms_lob.getlength(l_clob) LOOP
utl_smtp.write_data(l_conn, dbms_lob.substr(l_clob, ln_amount, ln_temp));
ln_temp := ln_temp + ln_amount;
ln_amount := least(1900, dbms_lob.getlength(l_clob) - ln_amount);
END LOOP;
utl_smtp.write_data(l_conn, crlf||crlf);
utl_smtp.close_data(l_conn);
utl_smtp.quit(l_conn);
EXCEPTION
WHEN OTHERS THEN
DBMS_OUTPUT.PUT_LINE(Error:||SQLERRM);
end;
*********************************************************
Print This Post
Subscribe to:
Post Comments (Atom)
No comments:
Post a Comment