現在のディレクトリ内のすべてのファイルから複数の文字列を検索するbashスクリプトを作成する方法は?

現在のディレクトリ内のすべてのファイルから複数の文字列を検索するbashスクリプトを作成する方法は?

Bashスクリプトが欲しい:

  1. 現在のディレクトリ内のすべてのファイルに対して「strings」コマンドを実行します。
  2. grepを使用して、各ファイルの文字列出力から特定の用語を検索します。

以下がありますが、スクリプト出力に一致する項目は表示されません。

#!/bin/bash

echo "Searching files in directory for secrets and urls"

for file in ./*
do
   echo "=====$file====="
   strings ${file} | egrep -wi --color 'secret\|password\|key\|credential|\http'
done

私もそれを試しましたがうまくstrings $file | egrep -wi --color 'secret\|password\|key\|credential|\http'いかeval "strings ${file} | egrep -wi --color 'secret\|password\|key\|credential|\http'"ないようです。スクリプトはファイル名を出力しますが、一致するものは出力しません。

答え1

を使用するegrepのと同じですgrep -E。つまり、拡張正規表現を使用できます。

拡張|正規表現は代替項目(使用する項目)であり、\|リテラル|文字と一致します。

だからあなたは欲しい

grep -w -i -E 'secret|password|key|credential|http'

または

grep -i -E '\<(secret|password|key|credential|http)\>'

where\<\>単語の境界と一致します。

または

grep -w -i -F \
    -e secret      \
    -e password    \
    -e key         \
    -e credential  \
    -e http

...正規表現一致ではなく文字列比較を実行したい場合。

また、変数の拡張には常に二重引用符を使用することをお勧めします。また、名前にスペース文字(スペース、タブ、改行)を含むファイルと、ファイル名ワイルドカード(*、、、)を含む?ファイルを正しく処理できます。[...]

#!/bin/sh

for name in ./*; do
    [ ! -f "$name" ] && continue    # skip non-regular files

    printf '==== %s ====\n' "$name"
    strings "$name" | grep ...
done

また、見ることができます

答え2

ループはfor不要です。ファイル名と小数点オフセットを出力するために使用されstrings、3文字以上の文字列を次にパイプしますegrep

strings -n 3 -f -t d ./* 2> /dev/null | 
egrep '[[:alnum:][:punct:]]*(secret|password|key|credential|http)'\
'[[:alnum:][:punct:]]*$' 

欠落を防ぐには、デフォルトの4文字ではなく3文字が必要です。「鍵」

サンプル入力ファイルがないため、以下はディレクトリの最初の10ヒットを示すデモです/bin/

strings -n 3 -f -t d /bin/* 2> /dev/null |  
egrep '[[:alnum:][:punct:]]*(secret|password|key|credential|http)'\
'[[:alnum:][:punct:]]*$' | 
head

私のシステムの出力:

/bin/bash:   78590 rl_discard_keymap
/bin/bash:   78720 rl_executing_key
/bin/bash:   79076 rl_bind_key
/bin/bash:   79847 emacs_standard_keymap
/bin/bash:   79905 _rl_keymap
/bin/bash:   81110 _rl_executing_keyseq_size
/bin/bash:   81598 rl_bind_keyseq_if_unbound
/bin/bash:   81640 rl_bind_keyseq
/bin/bash:   81736 bind_keyseq_to_unix_command
/bin/bash:   81863 _rl_dispatching_keymap

関連情報