サイトのローカル試験と実ウェブ上の差を縮める手法(Perl)


公開 (UL): 2022-04-04
更新 (UD): 2022-04-04
閲覧 (DL): 2023-12-02

この記事のもくじ

→本文へ
当サイトは SNS の公式アカウントがないので,「議論ネタ」にする際は,皆さんのブログ,メーリングリスト,SNS や掲示板などで,適当にハッシュタグを付けたりリンクを掲載するなどしてご利用ください。

前の記事

2021-12-17
Perl で利用宣言時にモジュールをカスタマイズする

次の記事

2022-08-09
代表的な画像ファイル形式一覧

最近の記事

2023-09-15
Perl の正規表現での A と Z の扱い
2023-01-16
Android のキーボード・ショートカット一覧
2021-06-01
Base54
2021-06-01
PPOP
2021-03-04
全角⇔半角の変換
新着情報
She appears also the top page.

新着情報 Recent docs.

Sorry, but almost these pages are only Japanese.
Perl の正規表現での \A と \Z の扱い «Easy manipulation for GET-query or POST-form data with \A and \Z in regular expressoin.»
\A と \Z を使ったクエリーやフォームデータの直接的な簡単操作。 (エンジニア向け)
倫理意識の社会的低下 «One day, I set to stop DM from a banking corporation, but those continue to be sent after that. I'm feeling falling sense of ethics in Japanese society.»
某銀行からの DM が,およそ金融とは関係なく興味のないものだらけ。しかし,止める設定をしても直ぐ止まらないシステムに,倫理意識の社会的低下を感じた話。
「マイナンバー」が危険なこれだけの理由-2 «Wny is Japanese taxpayer ID system "My number" repeating to leak private info and misregistration.»
最近多発している問題でいかに深刻な影響があり基本的対策の欠如だったかを解説。
オヤクショの「上から目線」という殺傷光線 «Tokyo government gifted me "Okome(rice) coupon". But I have allergic to rice. The government officers often make services considering insufficiently, then people is leaded wrong by that.»
東京都から届いた「おこめクーポン」は,食品の詳細不明でアレルギー持ちは不安,ウェブは「申し込めない」トラップだらけ……こんなオヤクショの「上から目線」の原因を考察。
給使乖離現象 «"Server and User Design Gap" phenomenon (abbr: SUDG), it's the trend to lack of considerations in design for user of the service.»
愚かな経営者たちが考えた劣悪なウェブサービスにより,人々が一方的に不利益を被るという話。
個人情報の提示要求者側に求められる責任 «The responsibilities of the government that wants some private infomations.»
給付金の手続きに突然「旧住所」の提示を求めて来たお役所の対応の疑問からその「責任」を考える。
日本の「IT 人材不足」の正体 «The simple reason why Japanese companies lack IT-skill.»
保険会社からのセキュリティガバガバメールが「IT 人材不足」の正体を暴く。

人気記事 Frequent view pages.

表計算で「令和」に対応する方法
How to adapt the Gengo era "Reiwa" on spreadsheet applicaiton.

古いアプリも OK。「表計算 令和」の検索結果上位御礼!
表計算ソフトで予定表を自動作成する超便利な方法 «How to make the schedule table automatically on spread-sheet.»
「毎月第○×曜日」的な法則は自動で作らせてラクしよう!
表計算ソフトに「個人情報保護機能」を仕込む方法 «Prevention to leak private-data with spread-​sheet macro function.»
「漏えい」のためのフェイルセーフ。「表計算 個人情報」の検索結果上位御礼!
Wary-Basher (ワリバッシャー)
DIY device that enables the handicapped to operate many things with a switch like push-button.

障害者の様々な操作をスイッチ操作で実現する器具。キットも発売中! 「作り方」PDF ダウンロード多数御礼!←地方教育委で人気。
貧乏人を殺す行政の構造 «Structurally, the administrators kill the poors in Japan.»
ヘタすると多摩川に流されるところだった台風 19 号

この記事に対する → 調布市の反応

おすすめ! Recommend

現在当サイト人気 No.1!
Android のキーボード・ショートカット一覧 «The list of Android Keyboard Shortcuts (EN ready).»
Android のスマホやタブレットにキーボードをつないだ時に知っていると便利なキー操作。
[PDF 118KB] 生活保護申請時のオヤクショ対策
申請の「水際作戦」を突破するための心得。「ホームレス総合相談ネットワーク」製作の図解を小サイズ化したもの。

出典 ☞ 路上からもできるわたしの生活保護申請ガイド (2017 年版) (外部リンク)
文字ベース天気予報 «Weather forecast in text mainly from JMA Json-data.»
古いブラウザやスマホ,音読ソフトでも大丈夫! 気象庁の JSON データを利用した文字ベースの天気予報(試験版)。
「事故防シート」について «Cared persons taking with "Jiko-​Bow-​Sheet" prevents from accidents.»
介護現場の負担軽減と事故防止のアイデア
【連載】 キーボードの「キー」の詳しい使い方 «The detial of usage each key on keybord.»
各キーの機能詳細。機能別五十音順一覧。
和易ゐ記 (WAI-WIKI) «WAI-WIKI is light­weight markup language for Japanese, and generates HTML on this server on-​demand.»
当サイトで開発/使用中の日本語向けに特化した軽量マークアップ言語

ご連絡 Contact

▼ メールフォームはこちら
SSL 証明書の更新に不具合が多いため,期限切れエラーが出た際は,お手数ですが「例外指定」をお願いいたします。

ファイルの暗号化
当サイト管理者(石川)宛にメール添付で送信するファイルを暗号化したい時は,唯一のパスワードを PPOP で取得できます。 PPOP gives a password for encryption of the file(s) attached your mail to the admini­strator of this site M.Ishikawa.
PPOP

MEMO / Email to the Author
あとで調べたい点のメモなどに利用可能。
下部ボタンでそのまま著者にメールできます。


CAPTCHA: easy math prob in Japanese

時事川柳 News Senryu

子育ての  
「ヒマ・カネ」吹き飛ぶ
  インボイス
Rearing kids. For blocking it the Japanese "invoice" system inducted.

 今は個人でウェブサービスを設計し, 多数の利用者を相手に薄利多売で稼ぐことも原理的には可能だ。 一方,某会計ソフト会社の試算では, 「インボイス」の書類作成は約 20 分かかるとか。 もしウェブサービスの利用者が9千人いて,対応を求められると,年間 3000 時間になる。1日8時間労働,週休2日とすれば,年間約 2000 時間労働が標準だろうが, 「インボイス」への対応だけでそれをはるかに上回ってしまう。 「薄利多売」は資本主義下のビジネス原理のはずが, それに則って収入を増やそうとすると,「インボイス」制度に阻まれる。 手続きで忙殺されるのを避けたいと考えると事業拡大できないから, 個人が家庭を築くために余裕ある資金源を確保することも許されない。 「ビジネス原理」を無視し,「少子化」を悪化させて, 「職業選択の自由」をも否定する違憲制度, それが「インボイス」である。

(⌚2023-09-28)
前掲載: 自民県 絶対しないぞ ふるさと税

ご支援 Support this site.

まだまだ コロナ失業中!!
CORONA-NEET, seeking works now!

この活動をご支援いただける方はこちらへ Could you support this site, see here (but Japanese).
都道府県庁さん, 地方自治体さんや教育委員会さん, 障害者就労支援機関さんやその他公的機関,省官庁さん, 「タダ見」しているだけでは, 格差が広がるだけだと思いませんか?
Welcome!
Amazon    Google
The companies, thanks for many accesses every months! Are the articles I wrote helping for increasing your income? Although, I cannot get even a penny and jobs from that.

 サイトを構築する際,ウェブで実運用する前に手元のローカル環境で振る舞いを試験することは当然あるわけだが,試験がうまくいったとして,それをそのままウェブにアップすればうまくいくかというと,そう簡単じゃない。ローカル環境からウェブ環境向けのカスタマイズが要るわけで,その環境設定の変更時に,ローカルで気付かなかった不具合が出る可能性も多々ある。その調整の負担はなるべく軽くしたいところ。

 ここでは,筆者が試した手法を備忘録しておこうと思う。

● サイトごとの環境を自動設定

 要は,環境設定を自動でしてくれる仕組みにすればいいわけだ。
 とはいえ,それもまた一筋縄ではない。だいたい,誰でも見れる CGI では,環境変数(%ENV)にユーザ名やホームディレクトリ(/home/user など)が渡されないため,どちら(ローカルかウェブ上か)の環境下で実行されているのかをスクリプト自身が知る方法が限られる。

 ひとつの方法としては,「ホスト名」は環境変数で渡されるのでそれを利用することが考えられる。まず CGI スクリプトを置いたディレクトリ(/cgi-bin など)に以下のソースを置く。

▼ siteconf.pl
   if( !($_ = $ENV{ HTTP_HOST }) ){ $_=`hostname`; chomp; }
   if( /^(shanaiserver01|localhost|127\.0\.0\.1)$/ ){
	#	ローカル試験環境の設定
   }
   elsif( /^www\.hostname\.co\.jp$/ ){
	#	実際のウェブ運用上の設定
   }

 で,「Apache の場合」または実行させるスクリプトが「シンボリックリンクではない場合」は,同じディレクトリに置いた CGI スクリプトで,最初のほうに必ず以下を置くようにして上記を呼び出せば,ローカル環境と実ウェブ上のサイトの設定が自動的にされる。

▼ CGI スクリプト側の処理
   do "./siteconf.pl";

 この方法の利点は,「内容が全く同一のファイルを単純コピーすれば済む」という点。環境に応じて設定ファイルを作り直す必要がない。

◆ hostname を再利用

 siteconf.pl 処理終了時に,グローバル変数に hostname を保存しておけば,siteconf.pl の実行から戻ってから CGI 内で個別の環境設定に利用できる。

▼ siteconf.pl の2行めに挿入
   ${^_HOSTNAME}= $_;
▼ CGI スクリプト側の処理
   do "./siteconf.pl";
   if( ${^_HOSTNAME}=~/^(shanaiserver01|localhost|127\.0\.0\.1)$/ ){
	#	CGI 特有のローカル環境の設定
   }
   elsif( ... (以下「他ホスト環境下の設定」省略)

 この ${^_HOSTNAME} のように ^_ で始まる変数は,必ずグローバル扱いになるらしい。詳しくは以下を参照。

▼ Perl で利用宣言時にモジュールをカスタマイズする
http://treeware.jp-help.net/?ssss11

 あるいは呼び出す側で,たとえば $HOSTNAME などを our 宣言しておいて,そこに siteconf.pl 内で代入しても可能ではある。

◆ Apache 以外,シンボリックリンクは注意

 ただ,Apache 以外の HTTP サーバソフトで,同じディレクトリ上にシンボリックリンクを置いて,実際のスクリプトファイルがそこにない状態で使っていた場合,上記「CGI スクリプト側の処理」のような書き方では,うまくいきそうにないケースがあった。筆者のローカル環境で使っている minihttpd というホストは,シンボリックリンクを辿った先で CGI が実行されてしまうらしい。たとえば,以下のような場合。

▼ スクリプトのある場所
   $> ls /home/user/cgis
   -rwxr-xr-x userreg.cgi
   $> ls /home/user/public_html/cgi-bin
   -rw-r--r-- siteconf.pl
   lrwxrwxrwx userreg.cgi -> /home/user/cgis/userreg.cgi

 userreg.cgi の最初のほうで,前述した do "./siteconf.pl" を実行しているものとする。このスクリプトは,実際は /home/user/cgis にあるが,CGI 公開用ディレクトリの /home/user/public_html/cgi-bin にそのシンボリックリンクを置き,それをブラウザから呼び出した場合は,Apache ではうまくいくが,minihttpd ではダメらしい。調べると環境変数に以下のような違いがあった。

▼ minihttpd の場合
   $ENV{ SCRIPT_FILENAME }="/home/user/cgis/userreg.cgi"
▼ Apache の場合
   $ENV{ SCRIPT_FILENAME }="/home/user/public_html/cgi-bin/userreg.cgi"

 minihttpd ではリンク先のディレクトリ上でスクリプトが実行されるようで,そこに siteconf.pl はなく do "……" が無視されるために,サイトの設定が正しく行なわれない。
 これを回避するには,何らかの方法でスクリプトが呼び出されたディレクトリの情報を知る必要がある。シェルの pwd コマンドか,Perl のモジュールにある Cwd.pm を使うとうまくいくみたいだ。

▼ CGI スクリプト側の処理(pwd)
   $_ = `pwd`; chomp; do "$_/siteconf.pl";
▼ CGI スクリプト側の処理(Cwd)
   use Cwd; do cwd."/siteconf.pl";

 ただ,Cwd の場合は,他のメソッドも含めた準備などで,600 行ものソースを読むので,ひょっとすると pwd のほうが軽いかもしれない。
 実行されているスクリプト名が実ファイルの場所ならディレクトリもそっちになり,そこに siteconf.pl はなさそうに思うが,上記のやり方で siteconf.pl と同じ位置が示されるから,これでいいのだろう。

 ちなみに $0(=スクリプト名)を見ると,minihttpd ではディレクトリのないファイル名のみだった。Apache ではフルパス名だった。



© M.Ishikawa; TREEWARE 2023.