改行コード変換のタイミングについて教えてください。
前提:
\n: ラインフィード \r: キャリッジリターン
UNIX \n
Winodws \r\n
MAC \r
PerlスクリプトによるCGIで、ブラウザに出力します。
このとき、生成するHTMLのFORM要素.INPUT要素.VALUE属性
に変数データを代入しています。
これは、文字列になっており、当初、\nを区切り文字として使用し、
HTMLとなってからJavaScriptでこの区切り文字を頼りに配列化しました。
ところが、MAC環境の方に確認をお願いしたところ、期待通りの動作をして
おらず、調べたところ、\nがすべて\rに変換されていたため、JavaScriptで
\nを探しても見つからなかったということがわかりました。
Windowsも\r\nに変換されています。
この改行コードの変換がなにを基準に、どのタイミングで起きているのかがよくわかりません
スクリプトの文字コードとget要求をしてきたOSを見て、Apacheが行っているのか、
それとも、ブラウザがやっているのか。
はたまた、アプリケーション層に行くまでの下層プロトコルがやっているのか。
判断基準はGETの中にあるのか、出力されたcontent-typeなのか・・・・。
変換がなに依存なのかわからないと、どんなとき変換が起き、どんなときは起こらないのかが
わからないので、このあたりの仕組みの詳細に詳しい方、ご教授願えませんか。
自分でもある程度調べたのですが、環境が限定されますし、ドキュメントもhttpプロトコル
を調べるべきなのか、TCP/IPなのか、HTML(のFORMリクエスト)なのか、httpデーモン
なのか、httpdが動いているUNIXサーバOSなのか、それともIEやNNの仕様を調べる必要があるのか・・・
どこがやっていることなのかわからないもので。
No.2ベストアンサー
- 回答日時:
そう言う事でしたか。
。理解力不足で申し訳ありませんでした。
このコード変換は、サーバーサイドではなく、クライアントサイドで行われます。
IEやNNでの仕様と思って貰えば良いと思います。
この回答への補足
いぇ、こちらこそ、お答えいただきありがとうございます。
再びの補足で申し訳ないのですが、
>このコード変換は、サーバーサイドではなく、クライアントサイドで行われます。
とのことですが、
この仕様についてを実際に確認できるドキュメントなどはどこかに公開されているでしょうか?
また、調べるための方法&ツール(ブラウザのパーサー部が解析する前の通信状態を表示することができるブラウザなど)はないでしょうか?
よろしくお願いします。>皆様
とりあえず、締め切ることとします。
実験手法や公式(に近い)情報ソースがわからなかったのは残念ですけど、クライアントサイドで行われる、とおっしゃってくださった方がいたことだけでも大収穫です。
やはり、汎用性を考えると、どこでであれ、自動的に変換解釈が行われないような方法を採った方がいいですね。
どうもありがとうございました。
No.1
- 回答日時:
CGIプログラムの中で、改行コード変換を行った上でのお話ですか?
それとも、CGIの中で改行コードの変換ロジックを入れていないのでしょうか?
<<改行コード変換ロジック>>
$val =~ s/\r\n/\n/g;
$val =~ s/\r/\n/g;
もし、改行コードの変換をされていないのであれば、そのロジックを入れないと正しく動作されないと思います。
変換を行うタイミングは、GET 又は POSTでデータを取得した後、そのデータを変数データとして扱う処理を行うタイミングで良いと思いますが・・・・
「こんな事は当然やった上での話だ!」と思われてしまったら、ごめんなさい。
この回答への補足
ご回答ありがとうございます。説明不足で申し訳ありません。
Perlスクリプト内ではコード変換は行っておりません。
これは、FROMからくる入力データには複数行文字列はないため、当然改行もなく、
必要がないためです。
あくまでも、"出力時"にUNIXサーバ上に保存されているデータを\nを使い連結して
一つのデータとしてHTML出力し、後からJavaScriptで配列化しております。
そのため、UNIXサーバでperlスクリプトが動作して、TCP/IPプロトコルにのっかって
httpでクライアントに送られ、ブラウザがそのデータを取得し、解析される
までの一連の過程の中で起こっている文字コード変換の、タイミングと発生条件が
今回の質問の中心です。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
「彡」って文字はなんという文...
-
VBAでbmp画像をASCIIデータとし...
-
フォームのコントロールのバッ...
-
EBCDIC⇒SJIS変換の方法
-
セル内の文字列が日本語か英語...
-
VBでIMEの変換文字列を拾いたい
-
COBOLによる全角・半角混...
-
EBCDICへの変換
-
VBでバイナリデータについて。
-
1をA、2をB・・・に変換したい
-
VS 2008(VB.NET)
-
CString ←→ BSTRの変換について
-
PS4コントローラーをPCでゲーム...
-
MMDでavi出力が出来ない
-
履歴書の志望動機の所で、「ま...
-
Chr(13)とChr(10)の違いは?
-
4Kの外部モニターに出力すると...
-
エクセルでアルファベットか数...
-
どっちが正しいですか? チョン...
-
1文字って1バイトだったっけ?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
「彡」って文字はなんという文...
-
EBCDIC⇒SJIS変換の方法
-
セル内の文字列が日本語か英語...
-
std::stringからLPCWSTR型への変換
-
ExcelVBA実行後に時々落ちる
-
VS 2008(VB.NET)
-
Symfowareでのデータ型変換につ...
-
2バイト文字をJEFからSJISに変...
-
COBOLによる全角・半角混...
-
VB.NETのコンソールアプリケー...
-
フォームのコントロールのバッ...
-
ふりがなをアルファベット化す...
-
sedで日本語の置換方法について
-
PL/SQLでSJISの文字コードを取...
-
数字5桁文字コード?
-
画像データ(png)をcsvファイル...
-
CString ←→ BSTRの変換について
-
英数字を含む文字列(0-9,A-Z)...
-
error C2679 がとれません><
-
RubyでUTF8のコード値を文字に...
おすすめ情報