にしし ふぁくとりー(西村文宏 個人サイト)

Presented by Nishishi via Movable Type. Last Updated: 2015/09/22. 13:20:08.

Undefined subroutine &jcode::convert と言われた

ローカルのPerl環境や、うちのウェブサーバでは問題なく動作するCGIが、なぜかクライアントのサーバではエラーを吐きます。500 Internal Server Errorになってしまいます。
サーバのエラーログを調べてみたところ、以下のようなエラーが記録されていました。

Undefined subroutine &jcode::convert called at hoge.cgi line 119.

jcode.plのconvertサブルーチンを呼び出している箇所でエラーになっているようです。
でも、うちのウェブサーバでは動きますし、ローカル環境でもエラーは出ません。
jcodeの使い方自体に間違いはないと思うんですが。

このエラーが出ている119行目は以下のように記述していました。

&jcode'convert(*name,'sjis');

これをふと、以下のように書き換えてみたところ、

&jcode::convert(*name,'sjis');

なんと、エラーが消えて、うまく動作するようになりました!(爆)
アポストロフィー記号「 ' 」をコロン2つ「 :: 」に書き換えただけです。
こ、こんなところに原因が?

しかし不思議なのは、このPerlソース内には、まだ119行目以降に、

&jcode'convert(*constr,'jis');
&jcode'convert(*notes,'sjis');

……のように、アポストロフィー記号を使っている箇所は残ってるんですが。
全部を「 :: 」に書き換えたのではなく、最初に出てくる1個だけを書き換えただけです。
これで問題なく動作するようになるって、どういうわけだ……?

コメント

コメント数: 0件

コメント投稿欄 この日記に対するコメント投稿を歓迎します。

保存しますか?



※本文中にURLは書けません。(書くと投稿が拒否されますのでご注意下さい。)

※投稿内容は、実際にページ上に掲載される前に、管理者によって確認される設定にしている場合があります。その場合は、投稿後にその旨が表示されます。たいてい1~2日以内には表示されるはずですので、気長にお待ち願います。m(_ _)m

トラックバック

このエントリーへのトラックバックURLを表示するにはここをクリック
※スパム防止のため、トラックバックURLは別ウインドウで表示します。(JavaScriptが有効でないと表示されません。)

--- 当サイト内を検索 ---