トップページphp
54コメント19KB

今更だけど完璧なメール送信ライブラリってあるの?

■ このスレッドは過去ログ倉庫に格納されています
0001nobodyさん2009/08/09(日) 09:45:20ID:???
”完璧”の定義

 ・RFCをきちんと守っている。
 ・だけど、正しくないメールアドレスを許容できるようにも設定できる
 ・ISO-2022-JPだけじゃなく、Shift-JISやUTF-8など対応
 ・添付ファイルやHTMLメールにも対応
 ・sendmail呼び出しだけじゃなくてSMTPにも対応
 ・使いやすい

プログラム言語は問わないというか、どの言語でも必要になるだろうから
どの言語版も必要だけど。

巷にメール送信のサンプルは数あれど、これでいいのか
今更ながらに迷う。
0002nobodyさん2009/08/09(日) 10:28:03ID:???
これは期待age
0003nobodyさん2009/08/09(日) 10:35:46ID:???
ずっと前からある問題なのに、ぐぐっても不完全な情報の断片ばかり。
最近のフレームワークなどで対応しているのかと思いきや、次のような流ればっかり。
「メール送信機能がついている → 日本語では文字化けする → その修正方法 (不完全)」

これだけ時間がたっているのだから、さすがにどの言語でも
完成された形でライブラリが出来上がっていると思うのに、
見つからない・・・見つけられない俺が悪いのだろうか?
0004nobodyさんNGNG
( ̄ー ̄)ニヤリッ(わっ)
0005nobodyさん2009/08/09(日) 23:00:12ID:???
> RFCをきちんと守っている
これだとa@aなんてアドレスが通ったりしません?
0006nobodyさん2009/08/09(日) 23:35:40ID:???
>>5
そこんところは、柔軟に、
チェックするかしないかを設定できるってことで。
0007nobodyさん2009/08/10(月) 00:07:41ID:???
>>5です

ううむ
なんとなくPerlで作ってみたくなったんですが
野良モジュールでよかったらとか……CPAN嫌い

Subjectを要求通りエンコードしたら日本語UTF-8で文字化けする
実はRFCの要求ではメールアドレスにだって改行コードを入れることができる(爆
メールアドレスの途中にコメントなんか入れることができる(爆
[例] example"Hello World"@example.com = example@example.com
a@aといった.のないメールアドレスが通ってしまう
Per5.8系ではメールアドレスの完璧な正規表現は無理

などの気の遠くなるような課題が山積でしたよね
0008nobodyさん2009/08/10(月) 00:21:01ID:???
>>7
頭いたいねw
こんなんだから、誰もちゃんとしたのを
作れないだろうね。

まあ機能不足は許容するとして、
間違ったメールは出したくないよなぁ。
0009nobodyさん2009/08/10(月) 00:27:57ID:???
> Per5.8系ではメールアドレスの完璧な正規表現は無理

無理して正規表現にしなくていいと思う。
たぶん読みにくくなるというデメリットしかない。
001052009/08/10(月) 00:33:40ID:???
こんな問題もある(有名
ttp://neta.ywcafe.net/000799.html
ttp://neta.ywcafe.net/000803.html
ttp://neta.ywcafe.net/000804.html
001152009/08/10(月) 00:49:36ID:???
> [例] example"Hello World"@example.com = example@example.com
これ勘違い

こうらしい
[例] example(Hello World)@example.com = example@example.com
0012nobodyさん2009/08/10(月) 01:12:27ID:???
>>10
そこらへんは、--disable-@の直前に.が来ないかチェック なんてオプションで対応使用と思います。

それで、いろいろ考えていたんだけど、
send-mail --from=a@example.com --to=b@example.com -body='test'
なんてオプションで後れる方式もつけるとして、
これだとマルチパートで添付ファイルもついているHTMLメールなど
複雑なメールだとオプションで対応しきれないと思うんだよね。

そこれで、ftpみたいに、コマンド入力形式にしようと考えているんだ。


send-mail [ENTER]
>set-charset iso-2022-jp
>from a@example.com
>to b@example.com
>subject メール
>attach ファイル.zip
>send
0013nobodyさん2009/08/10(月) 01:15:40ID:???
一見、sendmailコマンドと同じように見えるかもしれないけど
あれは、標準入力からうけとった文字列をただ流しているだけ。

>>12の方法はattach見たいな簡易な命令を書くだけで、
Content-Type: multipart/mixed; boundary="---"
なんてヘッダを自動的に補間したり文字コード変換したりするのが違いね。
0014nobodyさんNGNG
メールでドットが2つあると送れないのあるよね。どうして?
0015nobodyさん2009/08/10(月) 02:37:41ID:???
>>11
そういう変な仕様を思い出したら教えてほしい。


本当はRFCを読むべきなのはわかっているが、
時間がかかるんだ。
0016nobodyさん2009/08/10(月) 04:14:29ID:???
>>1
巷の実装は調べてみたの?

「どのサンプルでも実装できていない問題がある」という事と、
「部分的には満たしてるけど一部残念なところがある」という事は
分けて考えた方がいいと思う。

後者なら書き直せばなんとかなるわけだし、前者なら仕様策定が必要。
0017nobodyさん2009/08/10(月) 11:27:43ID:???
> 巷の実装は調べてみたの?
というか、ちゃんとしているのあるのかなぁ?と。
0018nobodyさん2009/08/10(月) 11:32:38ID:???
> 巷の実装は調べてみたの?

それ無理だわw

だってメールの仕様って思った以上に複雑というか
知られざる罠が存在するんだ。

ぶっちゃけ知らん。 そういう細かい所を知らなくても
簡単に使えるようにしたのが、ライブラリだと思うんだが。
0019nobodyさん2009/08/10(月) 14:43:54ID:???
>>1
そもそもメールサーバ側の実装が怪しい以上RFCを完璧に遵守してもなあ
0020nobodyさん2009/08/10(月) 15:29:10ID:???
文字エンコーディングの必要ない、新しいプロトコルできないものかね?

互換性を保つ為に非対応を検出したらサーバー側で変換する
0021nobodyさん2009/08/11(火) 12:05:16ID:???
>>17-18
なるほど。俺はQdmailというやつを使っている。
ttp://hal456.net/qdmail/

コンセプトが気に入ったので使ってるけど、大して多角的には使ってないので、
もし他に評価対象が無いなら、試しに使ってみたらいいかも。オヌヌヌ。

個人的な使用感としては、文字コードとSMTP送信は今の所いい感じ。
変なメールアドレスは試してないのでわからん、といったところです。
0022nobodyさん2009/08/12(水) 07:26:10ID:???
ライブラリってのは柔軟に作ってあって
必要に応じて制限掛けていくもんだろ
>>1は要するに他人が完璧に全て作ったものをそのまま使いたいだけじゃないのか?
0023nobodyさん2009/08/12(水) 09:32:05ID:???
>>22
ま、そうだろうね。
どこそこのサンプルが使いにくい、という具体的な話にならない所を見ると、
もはやクレクレ厨以下の予感がする。
0024nobodyさん2009/08/12(水) 09:45:38ID:???
使って不満なとこを作ってる奴にフィードバックしてやればいいじゃないか。
0025nobodyさん2009/08/12(水) 17:49:41ID:???
> どこそこのサンプルが使いにくい、という具体的な話にならない所を見ると、

どのライブラリも、文字コード変換とMIME変換を
ライブラリの利用者がしないといけないのがダメだな。
特にHTMLやファイル添付をするとき。
0026nobodyさん2009/08/12(水) 20:53:28ID:???
とりあえずたたき台として
CPANモジュール使いまくりの
コマンドライン版メール送信クライアントをおいときますね。

http://www.tocd.org/uploader/data/30/sendmail.zip
0027nobodyさん2009/08/12(水) 21:01:43ID:???
>>26
仕事はやw

ってきり、sendmailプログラムを入れただけだと思っていたのにwww
0028nobodyさん2009/08/12(水) 21:16:41ID:???
>>27
ちょっと前に作って放置してたやつをうpしただけなので^^
HTMLメール送信機能はないです。
GmailのSMTPサーバを使ってサーバのログ送信するために作りました。
いちおう毎朝WindowsXPのタスクとかいう機能で動かしてます。
0029nobodyさん2009/08/13(木) 12:48:49ID:???
これ、exeは何してるのですか?
0030nobodyさん2009/08/13(木) 12:59:39ID:???
>>29
ppでsendmail.plをコンパイル
0031nobodyさん2009/08/13(木) 20:36:38ID:???
もうすこし詳しく話す必要があるかと
0032nobodyさん2009/08/13(木) 22:22:35ID:???
本当にこの>>26のスクリプトの解説が必要なひとって
いるのかわからんけどいちおう書いておくと、、

perlが動かせる人にとって必要なことは
CPANでモジュールをとってくることだけです。
モジュールがそろえば
コマンドプロンプトから
> perl sendmail.pl
で動きます。

perlが動かせない人にとって必要なものは何もなくて
sendmail.exeをコマンドプロンプトでたたくだけで使えます。
コマンドプロンプトから
> sendmail.exe
で動きます。

同じフォルダにあるSSL関連のライブラリとか
make.batなどのファイルは、ppを使って
sendmail.plをsendmail.exeにするときに使った残骸ですので、
ふつーのひとには必要ないと思います。
0033nobodyさん2009/08/13(木) 22:35:14ID:???
あと、helpは-hをコマンドライン引数につけると出てきます。
(GNU Wgetの書き方をパクったんですが、
typoを修正せずにうpしてしまってます。。)

コマンドライン引数で指定したオプションはそのまま使われます。
コマンドライン引数で足りなかった項目については
標準入力からもらうように問い合わせるようになっています。
パスワードについては標準出力にエコーされないようになっています。
0034nobodyさん2009/08/14(金) 15:35:34ID:???
開発を引き継いでくれるひとが出てくれるように
開発環境一発インストールスクリプトをつけたよ。
アンインストールは手作業だけど。。

Perlはstrawberry perlしか試してないし、
勝手にC:\Windows\System32決めうちで
OpenSSLのDLLをインストールするけどいいよね。

あと、前のバージョンはUbuntuでしか試してなかったので
入力される文字列の文字コードがUTF8固定になってた。。
その部分はEncode::Guessを使うようにしたよ。

http://www.tocd.org/uploader/data/31/sendmail.zip
0035nobodyさん2009/08/15(土) 14:11:28ID:???
my $host = 'smtp.gmail.com';

こういうのは直す必要がありますよね
あとuseできるようにしなければ
0036nobodyさん2009/08/17(月) 03:01:00ID:???
TkでGUIをつけてみたよ
つかれた。。。

http://www.tocd.org/uploader/data/32/MySendMail.zip
0037nobodyさん2009/08/17(月) 04:29:27ID:???
GUIつけるなんて方向性が間違っているような気がするんですが
0038nobodyさん2009/08/17(月) 09:24:54ID:???
>>37
モジュールだけ適当に使ってください
0039nobodyさん2009/08/17(月) 15:39:34ID:???
>>36
ubuntuだと文字が入力できなかった

http://okwave.jp/qa3605759.html
XMODIFIERS="@im=none"とすればいちおう入力はできるけど
文字変換はできないのでコピペするしかない…

https://bugs.launchpad.net/ubuntu/+source/perl-tk/+bug/283806
これによると2009-06-18にFixされたらしい
0040nobodyさん2009/08/25(火) 17:51:21ID:???
>>36
レンタルサーバーのsendmailコマンドで使いたいのですが、対応してますか?
0041nobodyさん2009/08/25(火) 18:52:08ID:???
>>40
sendmailは呼び出していません。
そのレンタルサーバでNet::SMTP::SSLなどの
Perlモジュールが使えたら動くと思います。
0042nobodyさん2009/08/25(火) 18:54:05ID:???
>>41
了解
0043nobodyさん2009/09/07(月) 17:23:52ID:???
>>40
朝鮮人にも生まれ付き二重はいる
正確に見分けるには顔の表面より骨格を見る必要がある
例えば鼻の下が長かったら、まず間違いなく朝鮮人だと思っていい
0044nobodyさん2009/09/07(月) 18:22:37ID:???
いや、この毛深さならケツ毛は処理したと見るべきでしょ。 女優さんだってば
0045nobodyさん2009/11/18(水) 13:54:59ID:???
モダンPerlの世界へようこそ
第20回 Email::Sender:メールを送信する|gihyo.jp … 技術評論社
ttp://gihyo.jp/dev/serial/01/modern-perl/0020?page=1

この Email::Sender は日本語大丈夫なのかな。
メールの解説記事って添付や From: の日本語のことを書かないよね。
0046nobodyさん2009/11/18(水) 22:56:16ID:???
日本語が大丈夫かどうかはメール送信モジュールは関係なく
そこに引き渡す文字列の文字コード変換云々の問題だからな
日本語ならBASE64エンコードすればいいだけだし
■ このスレッドは過去ログ倉庫に格納されています