Declaration
template <class Socket> class basic_smtp : public Socket; typedef basic_smtp<tcp::socket> smtp;
Overview
smtp クラスは SMTP (Simple Mail Transfer Protocol) でメールを送信するためのクラスです. start() メソッドでメールサーバと接続し,login() メソッドでログイン処理を行った後, mail() メソッドで実際にメールを送信します.login() メソッドは現在のところ EHLO パケットを送るのみで,SMTP-AUTH などの実装は行っていません.sttp クラスは SMTP で決められているプロトコルに沿ってデータを送信するのみです.したがって,メールの書式 (Date, From, To, Subject ヘッダの付与など)はユーザが正しく記述する必要があります.
smtp クラスは,サーバからエラーメッセージが返された場合には smtp_error を例外として送出します. また,smtp クラスはサーバからの応答メッセージを内部に蓄積するように実装しています. response() メソッドを呼ぶと,サーバからの応答メッセージの一覧を取得することができます.
Example
#include <iostream>
#include <string>
#include <sstream>
#include "clx/smtp.h"
#include "clx/date_time.h"
int main(int argc, char* argv[]) {
if (argc < 5) {
std::cerr << "usage " << argv[0] << " host id from to" << std::endl;
std::exit(-1);
}
try {
clx::smtp session(argv[1], 25);
session.login(argv[2]);
std::string from(argv[3]);
std::string to(argv[4]);
// create a sample message
std::stringstream msg;
clx::date_time now;
msg << "Date: " << now.to_string<char>("%a, %d %b %Y %H:%M:%S +0900") << "\r\n";
msg << "From: " << from << "\r\n";
msg << "To: " << to << "\r\n";
msg << "Subject: SMTP test mail\r\n";
msg << "\r\n";
msg << "This ia test mail for clx::smtp class.\r\n";
msg << ".\r\n";
session.mail(from, to, msg.str());
session.finish();
// print message log
for (size_t i = 0; i < session.responses().size(); i++) {
std::cout << session.response(i).first << ": " <<
session.response(i).second << std::endl;
}
}
catch (clx::smtp_error& e) {
std::cerr << e.what() << std::endl;
std::exit(-1);
}
catch (clx::socket_error& e) {
std::cerr << e.what() << std::endl;
std::exit(-1);
}
return 0;
}
Result 221: Bye 250: Ok: queued as 1DB8025DB 354: End data with. 250: Ok 250: Ok 250: 8BITMIME 250: ETRN 250: SIZE 104857600 250: PIPELINING 250: smtp.abeam.ocn.ne.jp 220: smtp.abeam.ocn.ne.jp ESMTP Postfix
Template Parameters
- Socket
- ソケットクラスを指定します.
Related Types
typedef Socket socket_type; typedef char char_type; typedef std::basic_string<char_type> string_type; typedef std::pair<int, string_type> response_type; typedef std::deque<response_type> response_array;
Construction and Member Functions
basic_smtp();
basic_smtp(const basic_smtp& cp);
explicit basic_smtp(const string_type& host, int port = 25);
explicit basic_smtp(const char_type* host, int port = 25);
virtual ~basic_smtp();
basic_smtp& start();
basic_smtp& start(const string_type& host, int port = 25);
basic_smtp& start(const char_type* host, int port = 25);
void finish();
basic_smtp& login(const string_type& id);
basic_smtp& login(const char_type* id);
basic_smtp& mail(const string_type& from, const string_type& to,
const string_type& message);
basic_smtp& mail(const char_type* from, const char_type* to,
const char_type* message);
start() メソッドで SMTP サーバと接続し,login() メソッドでログイン処理を行います (現在は EHLO パケットを送るだけ).実際にメールを送信するときは,送信元,宛先, メールの内容を引数として指定し mail() メソッドを実行します.
response_array& response(); const response_array& response() const; const response_type& response(size_t index) const;
response() メソッドは,SMTP サーバからの応答メッセージの一覧を取得するためのメソッドです. それぞれの応答メッセージ (response_type) は,応答コードとメッセージのペアで構成されています. サーバからの応答メッセージはキュー (正確には std::deque) で管理しているため, 最新のメッセージが先頭に格納されています.