コンソールのログイン画面で上矢印を押したときに^ [[Aが表示される理由はありますか?


32

コンソールにログインしているときはいつもup、以前に入力したコマンドを見るために意図的に矢印を押します。しかし、私はこれを見る^[[A

しかし、Ctrl Alt Print Screen Scroll Lock Pause Break Page Up Page Down Winキーを押しても文字がエコーされません。

背後にある理由は何でしょうか?

DOESの^[[A文字のソートは何を意味しますか?

ここに画像の説明を入力してください

回答:


20

これは、端末がキーボードから送信されたUpキーの生のキーコードを表す方法です。基本的に、シェルは通常キー押下をインターセプトしますが、ログインプロンプトでそれを行うことはありません。したがって、入力した文字は、他の文字(または数字など)とまったく同じようにコンソールに出力されます。


3
@RubanSavvy Ctrl、Alt、Win(GNU / Linuxの世界ではよくSuperと呼ばれます)は修飾子です。それらとキーを押すと、画面上に異なるものが印刷されます。スクロールロックは、tty制御のためにカーネルまたは他の低レベルのものによって解釈されると思いますが、わかりません。ページの上下は、おそらく、gettyまたはloginに飲み込まれますが、理由はわかりません。経験に基づいた推測では、印刷画面は歴史的な理由でカーネルによって特別に解釈されます。ただし、修飾子以外は、100%確信はありません。
strugee

3
上記はおそらく回答に編集する必要があります。
strugee


19

キーボードはイベントをコンピューターに送信します。イベントには、「スキャンコードnnnダウン」または「スキャンコードnnnアップ」と表示されます。チェーンのもう一方の端では、端末で実行されているアプリケーションは、文字シーケンスの形式で入力を期待します。(Xサーバーのように、生のアクセスを要求していない限り。)を押すAと、キーボードは「スキャンコード38ダウン」という情報を送信します。コンソールドライバーはキーマップを検索し、これを「キャラクター」に変換しますa」に(修飾キーが押されていない場合)。

文字にならないキーまたはキーの組み合わせを押すと、情報は文字の観点からエンコードされる必要があります。いくつかのキーとキーの組み合わせには、対応する制御文字があります。たとえば、Ctrl+ Aは文字(バイト値1)をReturn送信し、文字(Ctrl + M、バイト値13)を送信します。(エスケープ、バイト値27)文字で始まる文字のシーケンス。たとえば、キーUpはエスケープシーケンスに変換されます␛[A(3文字:エスケープ、開き括弧、大文字のA)。

コンソールのユーザー名プロンプトは愚かであり、ほとんどのエスケープシーケンスを理解しません。慣れ親しんだラインエディションと履歴機能はありません。これらはシェルによって提供され、ログインするまでシェルはありません。そのため、エスケープシーケンスが表示されるだけです。文字にはグリフがないため、として表示され^[ます。^記号は、伝統的に制御文字の接頭辞として使用され、脱出がある^[ので、そのバイト値の:それはバイトの値だ[、マイナス64。

Upシェルプロンプトでを押すと、同じ3文字のシーケンスがシェルに送信されます。シェルはこれをコマンドシーケンスとして解釈します(通常、前の履歴項目を呼び出すため)。押すとCtrl+ Vその後、Upシェルプロンプトで、このインサートは、プロンプトでエスケープシーケンス:Ctrl+は、V文字通り、代わりにコマンドとしてそれを解釈するの次の文字を挿入するためのコマンドであるので、文字はエスケープシーケンスの開始と解釈されていません。

一部のキーは修飾子のみであり、ターミナルアプリケーションに送信されません。たとえば、を押すとShift、この情報はターミナルドライバーに残り、その後を押すAと考慮されるため、ドライバーAはの代わりにアプリケーションに送信されますa

さらに、一部のファンクションキーがコンソールにマップされない場合があります。

GUIでの同様のビューについては、bashのメタキーとはをご覧ください


これは素晴らしい答えです、いつものようにGillesに感謝します。
JoshuaRLi

5

キーが「ターミナル」(つまり、ターミナルエミュレータアプリケーション)によってどのように表されるかではありません。表示されているのは、1行上に移動するための ANSIコード(ANSIエスケープシーケンス)ですが、印刷可能な形式に変換されています。

  1. キーボードハードウェアは「スキャンコード」を送信しますが、それらは翻訳され、コマンドラインレベルのアプリケーションに文字として表示されます。キーAは1バイトになりAます。Shiftキーが押されている場合(またはShift Lock)、aそれ以外の場合。

  2. ANSI準拠の端末では、矢印キーは1文字(ASCII文字セットには矢印のコードはありません)ではなく、3文字の「エスケープシーケンス」を送信しますescape-[-A。他の3つの矢印キーはescape-[-B, C, Dです。

  3. 同じ文字シーケンスは、古い物理ANSI端末に送信(エコー)されると、カーソルを1行上に移動します。ターミナルエミュレータを含む多くのプログラムは、これらの文字シーケンスを認識して適切な処理を行います。ターミナルエミュレータはカーソルを上に移動します(これによりcursesライブラリがカーソルを移動します)が、bash代わりにそれをインターセプトして履歴をスクロールします。

  4. 画面上でカーソルを移動するのに使用できないプログラムでカーソルがいたるところに収まるのを避けるために、キーボード入力にESCが印刷可能なシーケンスとして表示されることがよくあります^[(エスケープがに対応するためcontrol-[)。これは、実際には端末デバイスインターフェイスによって処理されます。を参照してくださいstty(1)。その結果、上矢印はとして表示され^[[Aます。を入力しcat、リターンキーを押して矢印キーを押すと、コマンドラインからこれが表示されます。これは、コンソールのログイン画面で見たものでもあります。

最後に:ControlAlt、あなたが言及した他のキーは、文字列にマップされません。これらは、別のキー押下によって送信される文字に影響を与えます(上記のa/ A例のように)か、単にテキストへのマッピングがありません。このようなキー押下は、キーボードイベントをリッスンするプログラムによってのみ検出できます。それらは、標準入力から読み取ることで見ることはできません(またはファイルに書き込むこともできません)。


3

この動作はシェルごとに異なります。ほとんどのシェルreadlineは、プロンプト内の行を編集するために呼び出されるライブラリを使用します。このライブラリの完全なコマンドリファレンスを次に示します。そのため、アプリケーションが使用しているときに、readlineこのコマンドを使用して行を編集およびナビゲートできます。

コマンド履歴をナビゲートするために、垂直矢印キーがreadlineで構成されます。また、ログインプロンプトにはコマンド履歴がありません。そのため、文字^[[A^[[Bは画面に印刷されます。どういう^[[A意味ですか?

bashのマニュアルページには、PROMPTING次のように記載されています。

\[     begin a sequence of non-printing characters, which could be used to embed
       a terminal control sequence into the prompt

ANSIの矢印キーのエスケープシーケンスは次のとおりです。

  • [ValueAカーソルを上に(Value空にすることができます)

  • [ValueBカーソルを下に移動(Value空になる場合があります)


5
ログインプロンプトはによって印刷され、処理されますがlogin、これはには関係ありませんbash
リストサルミネン

1
bashまたlogin、同じライブラリ(readline)を使用して行を編集しています。違いはlogin、垂直矢印キーをコマンドのように解釈しないことですbash
カオス

はい、認めます。
リストサルミネン

bash構文はの^[表現のように見えることを意図しescapeていますが、それらは異なるものです。Bashはどんな構文でも使用できたはずです。あなたが書くこと、に\[A:、3つの文字の出力はbash ^[、(すなわちエスケープ)[A
アレクシス

0

これらはANSIエスケープコードです。^[シェルがESCバイト(ASCIIバイト27)を表示するために使用する表記法です。あなたの例は、テキストが続くESCバイトです[A。Wikipediaの記事で見ることができるように、^[[(にESC続いて[)はControl Sequence IntroducerまたはCSIです。CSI Aカーソルを1列上に移動することを意味します。

端末にエスケープコードを表示する場合は、CTRL + Vを入力してから、別のキーシーケンスを入力します。たとえば、CTRL + Vの後に上矢印が続くと、が表示されます^[[A


0

Bashなどのコマンドシェルは、上矢印をアクション「前のコマンドを取得」に変換するプログラムです。コマンドシェルが実行されていません。


0

TLDR

おそらくsh、上矢印キーを押したときに生成された生のキーコードを出力するものを実行しています。

bashこれらのキーコードをインターセプトし、それらで何かを行うような、より高度なシェルです。たとえば、履歴の最後のコマンドを表示します。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.