68user's page 掲示板

Prev< No. 1447〜1452> Next  [最新発言に戻る] [過去ログ一覧]
No. 1447 # nac 2000/12/11 (月) 17:14:39
nac と申します。ネットワークプログラミング大変参考になりました。
私も、POP3 クライアントを作ってみて疑問がでてきました。
rfc1939 を読んでみると pop3 サーバーの返答は 512文字まで
と書いてありました。そこで、一行が512文字以上のメールを
pop3 から落してくると、次のように

hogehoge...hoge!CRLF
hogehoge....hogeCRCF

途中で ! マークが入っておりました。rfc1939 を読む限りこの、! に
ついては言及されていないようですが、これはどこで規定されているのでしょうか。
(もし、rfc の中で書いてあるようでしたら、理解不足です、すいません)

No. 1448 # 68user 2000/12/11 (月) 18:48:27
> rfc1939 を読む限りこの、! については言及されて
> いないようですが
ちらっとしか見てませんが、512 ってレスポンス行 (+OK
とか +ERR) の最大長であって、メールの1文の長さとは
無関係じゃないでしょうか?

とはいえ、! で fold されていたというのは気になりますね。
現在 IMAP 環境しかないので試せませんが、その POP3
サーバアプリケーションの名前を教えてください。qpopper ですか?

No. 1449 # kiki@TL [E-mail] 2000/12/11 (月) 20:34:30
一応インストールは成功しているみたいです。GNOME+enlightenmentで「サウンドを有効にする」ボタンを押したらでは正常に動いたのですが、その後デスクトップのタスクバーが出なくなり、仕方なく再インストールして一からやり直したんですが、GNOM+Sawmillでは無理なんでしょうか?
PCはNECのLAVIE「LV16CWS」(ノート型)です。サウンドカードはESS社 ES1869Sで、動作確認の取れたOSSの最新版ファイルをインストール済みです。ディストリビューションは、Turbo Linux6.0です。
音だけじゃなくて、スクリーンセイバーもKDEだと動くのにGNOMEではプレビューでは見れても、実際には動きません。ウィンドウマネージャーとの愛称って在るんですかね???誰かアドバイスお願いします。
あとメモリーの自動認識ができないのですが、方法ありますか?解れば教えて下さい。96MBなのでデフォルトでは認識しないようです。宜しくお願いします。

No. 1450 # hayata [E-mail] 2000/12/11 (月) 23:21:46
skel.103Mさん @hayataです。
No.1437でのアドバイスありがとうございます。
出張でこちらの掲示板を見落としてしまいました。これからアドバイスに沿って再挑戦してみます。
成功しましたは報告いたします。
ではでは

No. 1451 # Mie 2000/12/12 (火) 14:13:12
1430の回答、ありがとうございました。
すぐに応答くださったのに、質問を投げた私が、反応が鈍く、
大変失礼いたしました。
「ヘルスチェック」という言い方は、どうやら「職場方言」のようですが、
68userさんの御推測の通りのものです。
回答いただいたうちの、3、及び4を、使用してみようと思っています。
ありがとうございました。
また、なにかの折りには、よろしくお願いいたします。

No. 1452 # rosegarden 2000/12/12 (火) 14:16:04
>とはいえ、! で fold されていたというのは気になりますね。
qpopper の場合一行の最大は \0 込みで 1024 bytes です。
ソースを見ると早いでしょう。

        /* Send the header of the message followed by a blank line */
        while (fgets(buffer, MAXMSGLINELEN, p->drop)) {
                if (!strncasecmp(buffer, "Content-Length:", 15) ||
                        !strncasecmp(buffer, "X-UIDL:", 7)) { /* Skip UIDLs */
                        continue; /* Content-Length is MTA dependent, don't send to MUA */
                }

\0 込みと言うのは、fgets 使っているための仕様です。

もしも、512 文字というのが 2 バイト文字の意味で、512 文字なら
ちょうどこの制限に引っかかります。\0 込みなので、iso2022-jp なら
途中出来られると ! なんていくらでも出て来ます。iso-2022-jp なら
「。」なんて「!#」とかなりますから。
ただ、普通は困りませんね。rfc で決められている一行の推奨値は
70 bytes + αですから。

問題は本当に POP3 サーバだけの制限なのかということです。
実験の際に使った MUA や MTA の制限も関係あります。
sendmail 8.11.1 のソースを見たら行の長さ関係は 2048 bytes でした。
また POP3 サーバなどをinetd を通している場合 inetd 自体の制限も
あります。8192 bytes かな? FreeBSD の inted の場合。ヘッダーしか見て
いないので断定できませんけど。
もっとも、自分で /var/mail/ のファイルにメールらしきものを手動で
append して実験した場合は話は別ですが。
他にも実験を telnet でやったのなら、telnet などの制限も考えられます。
FreeBSD なら ring buffer 使っているので、
そういう制限はありませんが、OS のベンダによってこの実装は変わるでしょうね。

Prev< No. 1447〜1452> Next  [最新発言に戻る] [過去ログ一覧]