ひまつぶし雑記帖

multipartの解析部分の変更

2006/7/11 [09:18:14] (火) 天気

まだうまく行ってるのかどうか疑問だけど、multipart解析部分で、今回変更したのは。

/usr/local/lib/perl5/site_perl/5.8.6/CGI/Lite.pm
の中の
sub_parse_multipart_data

から、
current_bufferに対して正規表現で disposition header body を取得する部分。
出力用ファイルハンドルを変更する部分(CL00がすでに使われていたら、インクリメントしてファイルハンドルを変更する)
を取り込んでみた。

ファイルハンドルを変更するところは、use strict 環境下では、ブロック内で
no strict 'refs'
が必要。

自作ルーチンでは、disposition データ部分の切り分けで失敗することが多かった、ようなので、すでに枯れて落ち着いてる車輪を導入。
mod_perl下でメモリのキャッシュの挙動がよくわからんし、同時アクセス制御にもなるだろう、ということでファイルハンドルの変更を導入。

といった感じか。
multipart/form-dataを使って、画像などのアップロードするCGIはこのやり口が定番、らしい。Mac版IE5.23のバグも吸収してるっぽいし、これで安定してくれるといいんだけど…。



 

»電子書籍制作代行についてはこちら

ぼーっと週末。

2006/7/9 [17:43:10] (日) 天気

相変わらずmultipartの解析がうまく行ってないようで、アップロードされた画像が壊れてるケースが、特にMacとMSIE5.23の組み合わせで頻発する。

自作のサブルーチンのバグ。今日は天気も天気だし、プール疲れが残るので、図書館に行ったぐらいであとは部屋でぼーっといちんち、だ。なので、バグ部分とにらめっこ。(ちなみに、今日初めて知ったんだけど、地元の図書館には「ハヤカワミステリ」の棚があって腰が抜けた…マニアック過ぎ)

CGI.pmとかCGI_Lite.pmとか、あちこちにあるリソースを覗いて回る。
たぶん、該当するところ。わたしがsplitで分けてから場当たり式にふりわけてるところを、どのモジュールも正規表現一発で済ませてる。なるへそ(死語)と思い、それをそのまま拝借して入れたら、特に問題なくアップロードはできる…。んだけど、従来の自作ルーチンでもわたしの環境下では問題ないんだよなぁ。

でもって、Lite.pmあたりは、バッファの上限をつけて、読み込みを分けてるんだけど、これって意味があるのかな。Content-lengthで最大サイズに制限かけてるから小分けにする意味がないような…。

あとは、もしかするとmod_perlのバッファがなにか干渉してるかも、とか、出力のファイルハンドルを細工しなきゃいけないのか、とか。

いろいろ試してみるんだけど、Macなんて持ってないのが困ったちゃんだぞ、おれ。

»電子書籍制作代行についてはこちら

ぶーさん

2006/5/14 [21:25:11] (日) 天気

image 今日は久しぶりの武蔵小金井。
駅前再開発のため、お気に入りのカレー屋さん「ぷーさん」が17日で一度立ち退きとなる、とのことで慌てて食いにいってきた。
相変わらずうまかったっす。

で、↓はちょっとメモ
-------------
Mac 版の MSIE で boundary の扱いが少し違っていた以外は致命的な差はあり
ませんでしたが、Mac 版の Netscape は filename を url エンコードしてい
たので、自動デコードするようにしました。Mac の MSIE 以外の Mozilla と
して判定していますが、もし 4.5 というバージョンや PPC 等にも依存するよ
うな事があれば、お知らせして頂ければありがたいです。

また、Windows については filename をフルパスで返すようです。これは自動
で削除して他のプラットホームに合わせた方が扱いやすそうですが、勝手に削
除するのもかえって不親切かもしれないので、とりあえずそのままにしてあり
ます。この件についても利用者のみなさんのご意見を伺えるとありがたいです。

最後に、やはり結構面倒なのが Mac です。以下、Mac のファイルとは無関係
な方は読み飛ばして下さい。

まず、Netscape はデータフォークのみをアップします。これはテキストや画
像データをアップする場合等にはサーバー側でそのまま利用できるので便利で
す。しかし、アプリケーションやリソースフォークも必要なデータファイルの
場合は、ファイルが壊れるという事になります。

もっとも、そのようなデータを生でアップする必要性というのはほとんど無い
でしょうから、この場合には一度アーカイブし、それをアップするという事で
対応するのが良いでしょう。

次に、MSIE ですが、こちらは MacBinary をアップします。user_agent で
MSIE を判定せずとも、content_type で確認できます。

MacBinary でアップされるため、そのまま別ディレクトリ等に移動して公開す
るには便利ですが、一方、テキストや画像データの場合は、適当なツール(確
か、Debian 等にもあったような)でデータフォークを取り出してやる必要があ
ります。

まあ、とりあえず、通常は Netscape でアップしてもらうのが簡単そうですね
-------------

なにしろ、MSIE for Macintosh は、過去に

  HTTP_USER_AGENT に「インターネットエクスプローラ」と、
  しかも「半角カナ」で返す

という、USER_AGENT 業界(笑)に金字塔を打ち立てたシロモノですから、
strcmp() も大変だあ。

# MSIE 3.x の一部が、FORM の INPUT ごとに日本語キャラクタセットが違う、
# ってのもあったな
--------------

 [23:08:38] 
Macは例外が多いみたいで、泣かされる。該当機種・ブラウザ・OSを持ってれば、調べて対応するのは、たいしたことじゃないんだけど…。
みんなに使ってもらおうと思うといろいろ出てくるですね。ごめんなさい、で、対応しきれない部分も出てきそうだなぁ。

 [2006/05/15 11:46:39] 
body部が取れてなくてUAがMSIE、MacならContent-Typeで区切りなおし。

if( ! $body && $ENV{'HTTP_USER_AGENT'} =~ /MSIE.+Mac/i){
  ($header, $body) = split(/Content-Type.+\r\n/i, $c, 2);
}

 

»電子書籍制作代行についてはこちら

mod_perl2のキャッシュに悩む

2006/3/9 [22:34:02] (木) 天気

perl の time で処理していたところ、mod_perl2 のレジストリ環境だと、$now=time などとやってグローバルに使うとちょっと不都合。意図せずキャッシュされてうまくない。まったく同じ時間、というのが頻発するのだ。どうやって避けるのか、もしくは、キャッシュを吐き出させるのか、ぐーぐる様にたずねても今いちぴんとこない。なもんで、timeの出力をintで受けていたテーブルをすべてtimestampに直してみた。…って、これだけでえらい騒ぎ。
current_timestamp というのが今の時間を出す定数と書いてあって、コマンドラインで試すとなるほど、そのとおり。ところが dbi で使うとinsert と updateで使えない。current は、もうサポートしてないよ、とエラーで止まる。同等の now() を使えば大丈夫だったんだけど、where句の中では current_timestamp + ... というのは使えるから混乱した。しばらくハマった。

日付計算までpostgresqlにやらせるのもどうだろ、と思うんだよなぁ。もちろん、使い慣れてるから、perl の time でやってしまいたいってのが本当なんだけど、こないだから言ってるように、perl と postgresql の棲み分けのことも。読み書き検索といった足腰部分をpostgresqlで、表示加工や細かいところは perl で、と意識はしてたつもり。ある日数が経過してるから色を変えてみる、なんてのはそれこそ perl の細かい仕事だろう。読み書きで忙しいpostgresqlにそんなどーでもいいところまでやらせていいのかと。

今日、小諸そばのおやじに、はじめて、「毎度」と言われてちょっと照れる。たぬきに油揚げをトッピングしたり、わかめをトッピングしたり、毎度定食モノじゃないので目をつけられていたかもしれんなぁ。

 

»電子書籍制作代行についてはこちら

冷たい雨の週末はひきこもる

2006/2/26 [22:30:12] (日) 天気

激しく冷たい雨模様。自治会の集金に回って、クリーニングを取りにいって。あとは部屋でごろごろのったり、だ。
Net-Amazonを使って検索する場合、isbnコードだと割りとすんなり早く帰ってくるんだけど、キーワード検索だとちょっと待たされる。短気だと多分、ばしっと切る程度には遅い。って、わたしがそうなんだけど。
こんなもんか、と思えば待つんだけど、初めてだと不安になる。というところか。なもんで、一度検索されたら、一時的にデータベースに放り込んでおいて、検索があったらまずはデータベースを見て、それでなければアマゾンにいく、という方式にした。データ数で1万件、日数で30日、どのぐらい溜め込んでおけばいいのかは、やりながら調整、だなぁ。
これで、シリーズ物・巻数モノの入力がラクになる。タイトルを入れて検索して、チェックボックスをつけて表示させればあとはなんとかなる、かな。

そいや、昨日ジブリ美術館でジブリがいっぱいスペシャル・ショートショートというDVDを買ってきた。TVCMとかプロモビデオとか。後半、なんじゃこりゃ、みたいなのが入ってて、ちとアレだったけど、前半は面白いものばかりだった。脱力系もうまいんだなぁ。

»電子書籍制作代行についてはこちら

mod_perl は難しいっす

2006/1/18 [19:04:11] (水) 天気

また新たにページ作りが飛び込んでくる。うううむ、今度は難題かも。あわてて本屋に走ってデザイン系の本・雑誌を購入してみる。ネットで検索して出てくるような内容だろうけど、こういう焦り気味の時、紙媒体の手軽な一覧性は大きなアドバンテージだなぁ。
今度はシンプルなものにしたいぞ。

メモ
昨日からModPerl::Registry環境で出るエラーに悩む。

execute on disconnected handle at ****** line 124

アクセスして一度目はエラーはなし、次のアクセスで確実にエラーとなり、さらに次のアクセスは問題なし。

ModPerl::PerlRunだとエラーにはならない。これはModPerl::Registryの現象なのかなぁ。…って、よく分かりもしないド素人のくせに情報の少ないmod_perl2にしたバチが当たったか。
接続が切れてるのにexecuteするのは無理っ。というエラーだろうから、disconnectをコメントアウトしてみる。スクリプトが終了すれば勝手に処理して disconnect してくれることを期待だ。案の定エラーにはならないけど、ps axするとpostmasterがアイドル状態でいくつも残ってる。いくらなんでもこりゃまずい。
apache2 に mod_perl2 って本当に情報が少なくて悶絶。本屋で見たオライリーのapache拡張本は、もう5年も前の初版でApache::Registry。

とりあえず。
$r = $dbh->ping;
if( ! $r ){コネクト処理}
というのを、いちいち入れたらエラーは出ない。…けど、大丈夫なんかい。要調査続行。

 [21:06:01] 
そいや、見よう見真似でゾーンファイルも書いて、置いてみた。しかし。こいつはわからん。オライリーのを買おうかと思ったら5000円超。…オライリーのはどれもこれも、しょーもないジョークがいいので、欲しいんだけど。吉野家と小諸そばとさくら水産でもってる身としては(高脂血症の診断が出てから吉野家は却下してるけど)なかなか手の出ない値段設定なんだよなぁ。

 

»電子書籍制作代行についてはこちら

profile

profile

 
doncha.net
contact:
»運営者
@t2aki@tokoroten.doncha.net

ところてんx5

2024/5/6 22:25

たぶん、1番ラクなのは、ひげ剃りと同じにするんだろうけど、頭を剃りあげるのはさすがに、だなあ

2024/5/6 22:23

だけど、坊主頭は坊主頭で、ちゃんとそれなりの頻度でバリカンしないといけいけないのが面倒くさい

2024/5/6 22:21

マダラハゲが進行してるし、バリカンのたびに、いちいち整えるのが、もうそろそろ面倒くさい

検索
<<2024/5>>
   1234
567891011
12131415161718
19202122232425
262728293031

リンク

WINDOWS版サウンドノベル
おかえりください PC WINDOWS版サウンドノベル
『おかえりください』体験版

[21 Page]« »
11 12 13 14 15 16 17 18 19 20

TOTAL:2982

2024 (5)
1 (2)
2 (2)
3 (1)
2023 (53)
1 (1)
2 (5)
3 (1)
4 (1)
5 (3)
6 (9)
7 (9)
8 (6)
9 (5)
10 (3)
11 (2)
12 (8)
2022 (16)
1 (1)
3 (2)
6 (2)
7 (1)
8 (4)
9 (2)
10 (1)
11 (2)
12 (1)
2021 (12)
1 (3)
2 (1)
6 (1)
8 (2)
9 (1)
10 (1)
11 (2)
12 (1)
2020 (18)
1 (2)
2 (6)
4 (1)
6 (1)
7 (2)
8 (2)
12 (4)
2019 (17)
1 (3)
2 (4)
3 (2)
4 (2)
5 (1)
6 (1)
8 (1)
10 (1)
12 (2)
2018 (21)
1 (3)
2 (2)
3 (2)
4 (1)
5 (1)
6 (6)
8 (1)
9 (1)
10 (2)
12 (2)
2017 (32)
1 (2)
2 (1)
4 (2)
5 (1)
6 (6)
7 (3)
8 (5)
9 (3)
10 (2)
11 (2)
12 (5)
2016 (41)
1 (5)
2 (5)
3 (2)
4 (3)
5 (4)
6 (6)
7 (2)
8 (2)
9 (3)
10 (1)
11 (4)
12 (4)
2015 (99)
1 (11)
2 (12)
3 (9)
4 (6)
5 (8)
6 (8)
7 (3)
8 (5)
9 (16)
10 (6)
11 (1)
12 (14)
2014 (112)
1 (16)
2 (5)
3 (6)
4 (12)
5 (16)
6 (19)
7 (9)
8 (6)
9 (4)
10 (8)
11 (6)
12 (5)
2013 (145)
1 (24)
2 (15)
3 (18)
4 (23)
5 (14)
6 (11)
7 (7)
8 (11)
9 (5)
10 (4)
11 (6)
12 (7)
2012 (103)
1 (1)
2 (1)
3 (4)
4 (3)
5 (7)
6 (26)
7 (17)
8 (5)
9 (8)
10 (10)
11 (11)
12 (10)
2011 (54)
1 (4)
3 (7)
4 (4)
5 (14)
6 (6)
7 (3)
8 (3)
9 (1)
10 (4)
11 (2)
12 (6)
2010 (70)
1 (12)
2 (7)
3 (6)
4 (6)
5 (3)
6 (10)
7 (6)
8 (4)
9 (3)
10 (4)
11 (3)
12 (6)
2009 (144)
1 (15)
2 (12)
3 (12)
4 (6)
5 (15)
6 (6)
7 (10)
8 (9)
9 (17)
10 (12)
11 (14)
12 (16)
2008 (148)
1 (10)
2 (6)
3 (10)
4 (11)
5 (13)
6 (10)
7 (13)
8 (19)
9 (18)
10 (12)
11 (13)
12 (13)
2007 (106)
1 (7)
2 (5)
3 (3)
4 (7)
5 (5)
6 (9)
7 (8)
8 (13)
9 (18)
10 (11)
11 (8)
12 (12)
2006 (158)
1 (28)
2 (28)
3 (25)
4 (7)
5 (9)
6 (7)
7 (12)
8 (13)
9 (10)
10 (7)
11 (6)
12 (6)
2005 (350)
1 (31)
2 (26)
3 (26)
4 (27)
5 (29)
6 (30)
7 (32)
8 (30)
9 (30)
10 (32)
11 (29)
12 (28)
2004 (292)
1 (24)
2 (24)
3 (29)
4 (27)
5 (28)
6 (25)
7 (26)
8 (24)
9 (12)
10 (19)
11 (26)
12 (28)
2003 (318)
1 (22)
2 (25)
3 (21)
4 (28)
5 (28)
6 (28)
7 (28)
8 (29)
9 (26)
10 (29)
11 (28)
12 (26)
2002 (317)
1 (29)
2 (26)
3 (26)
4 (25)
5 (28)
6 (30)
7 (27)
8 (21)
9 (25)
10 (27)
11 (28)
12 (25)
2001 (277)
1 (17)
2 (21)
3 (23)
4 (20)
5 (31)
6 (18)
7 (26)
8 (25)
9 (29)
10 (19)
11 (24)
12 (24)
2000 (53)
6 (9)
7 (4)
8 (2)
9 (3)
10 (1)
11 (15)
12 (19)
1999 (3)
7 (1)
10 (2)
1998 (18)
9 (9)
10 (7)
11 (2)