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


公開 (UL): 2022-04-04
更新 (UD): 2022-04-04
閲覧 (DL): 2024-09-16

この記事のもくじ

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

前の記事

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

次の記事

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

最近の記事

2024-02-11
XMPP - 長く使える安心チャット
2023-09-15
Perl の正規表現での A と Z の扱い
2023-01-16
Android のキーボード・ショートカット一覧
2021-06-01
Base54
2021-06-01
PPOP
新着情報
She appears also the top page.

新着情報 Recent docs.

Sorry, but most of these pages are only Japanese.
「ぱそはだ」シリーズ «PASOHaDA: Parts Assignment and Soldering Only Handmade Design Assist.»
高度な技能不要の電子工作で自立介護 DIY。
簡単にできるネット防犯対策 «Simple measures against phishing mails and malwares.»
フィッシングメールを暴き,ウイルスの侵入を阻止する簡単な対策を紹介。
福祉改善を阻むオヤクショ思考 «Japanese subsidy system of communication aid device for disabilities cannot be applied those if it's with features except communication, IDK why.»
「意志伝達」しかできない高額な装置にのみ税金が使われる謎制度。
「理不尽採点」教育と「英語力低下」 «Japanese English skill ranking in the world has been down. I guess one of the reason is that the government's education policy lacks coherence.»
日本人の英語力が低下,しかも小学校から英語が必修になった世代ほど。「教育方針の一貫性のなさが原因」とする考察。
倫理意識の社会的低下 «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 が,およそ金融と関係ないもの多数。停止設定後も何ヶ月も配信が続く状況に,倫理意識の社会的低下を感じた話。
給使乖離現象 «"Server and User Design Gap" phenomenon (abbr: SUDG), it's the trend to lack of considerations in design for user of the service.»
愚かな経営者たちが考えた劣悪なウェブサービスにより,人々が一方的に不利益を被るという話。
日本の「IT 人材不足」の正体 «The simple reason why Japanese companies lack IT-skill.»
保険会社からのセキュリティガバガバメールが「IT 人材不足」の正体を暴く。

人気記事 Frequent view pages.

現在当サイト人気 No.1!
Android のキーボード・ショートカット一覧 «The list of Android Keyboard Shortcuts (EN ready).»
Android のスマホやタブレットにキーボードをつないだ時に知っていると便利なキー操作。
表計算で「令和」に対応する方法
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 ダウンロード多数御礼!←地方教育委で人気。

おすすめ! Recommend

貧乏人を殺す行政の構造 «Structurally, the administrators kill the poors in Japan.»
ヘタすると多摩川に流されるところだった台風 19 号

この記事に対する → 調布市の反応
[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 証明書の更新に不具合が多いため,期限切れエラーが出た際は,お手数ですが「例外指定」をお願いいたします。 一時期,送信できなかったようです。すみません。今は大丈夫だと思います(テストは OK)。

ファイルの暗号化
当サイト管理者(石川)宛にメール添付で送信するファイルを暗号化したい時は,唯一のパスワードを 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
あとで調べたい点のメモなどに利用可能。
下部ボタンでそのまま著者にメールできます。 一時期,送信できなかったようです。すみません。今は大丈夫だと思います(テストは OK)。


CAPTCHA: easy math prob in Japanese

時事川柳 News Senryu

パーティー券  
民意も一緒に
  蹴り返し
Kick back both party tickets and people's opinions.

 自民党の一部(?)派閥がパーティー券のノルマを上回る分の売上げを議員にキックバックしておきながら政治資金収支報告書に不記載だった問題が広がりを見せている。なるほど,こうしたことが党内で常套化していたのだとすれば,岸田総理はじめ同党政治家にことごとく「民意を蹴り返すクセ」が付いているのは当然という感じもする。これっぽっちも「悪いこと」と思わなかったのだろうな。そんな人たちに誰が票を入れるのだろうか。少なくとも,岸田の広島と「頭悪いねぇ」と暴言を吐いた議員を選出した長崎に「ふるさと納税」はしないことにしよう。
参考: 自民県 絶対しないぞ ふるさと税

今回はもう一句!

危機感の  
ワリに二階は
  誰も居ず
Having sense of crisis, but nobody takes shelter of 2F.

 大雨などで危機感を持ったら二階のような高い所へ避難すべき的な話を聞いたよーな気がするのだが? パーティー券のノルマ上回り分キックバックの政治資金収支報告書不記載問題で,安倍派は何人も辞任したのに,同じく捜索を受けている二階派に辞任する話があるかというと,今のところ誰もいない。総理は「危機感を持って」とか言っているらしいが,どこが「危機感」なのやら。

(⌚2023-12-19)

ご支援 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 2024.