Perlのファイルオープン時のコマンドインジェクション対策
スポンサーリンク
Perlでのファイル処理で、コマンド実行をさせたくない(コマンドインジェクションを避けたい)場合は、open()ではなく、sysopen()を使うことを推奨します。
なぜopen()は危険なのか?
Perlでファイルを開くときにopen()を使ったりすると思いますが、このopen()はくせ者です。
なにがくせ者かというと、 | (pipe, パイプ) があると、その文字列を実行してくれます。
パラメータで渡ってきた文字列をopen()するプログラムを書いてしまうと、問題になることがあります。
パラメータで本来 foo だけ欲しい(とする)のですが、ここでは、
open()の代わりにどうすればいいのか?
入力された文字列に、パイプがあるかどうかチェックするのもいいですが、ここでの対策では、sysopen()を使うやり方を紹介します。
sysopen()はopen()と違って、第2引数の文字列がパイプで始まっていても外部コマンドを実行しません。
なぜopen()は危険なのか?
Perlでファイルを開くときにopen()を使ったりすると思いますが、このopen()はくせ者です。
なにがくせ者かというと、 | (pipe, パイプ) があると、その文字列を実行してくれます。
パラメータで渡ってきた文字列をopen()するプログラムを書いてしまうと、問題になることがあります。
パラメータで本来 foo だけ欲しい(とする)のですが、ここでは、
|cat /etc/passwd;foo
が渡ってきたとします。このサンプルでは、/etc/passwdの内容を出力してしまいます。
#!/usr/local/bin/perl use strict; use warnings; my $file = "|cat /etc/passwd;foo"; open (F, "$file.txt") or die "can not open"; while (my $line = <F>) { print $line; } close (F);
open()の代わりにどうすればいいのか?
入力された文字列に、パイプがあるかどうかチェックするのもいいですが、ここでの対策では、sysopen()を使うやり方を紹介します。
sysopen()はopen()と違って、第2引数の文字列がパイプで始まっていても外部コマンドを実行しません。
#!/usr/local/bin/perl use strict; use warnings; use Fcntl; my $file = "|cat /etc/passwd;foo"; sysopen (F, "$file.txt", O_RDONLY) or die "can not open"; while (my $line = <F>) { print $line; } close (F);
スポンサーリンク
スポンサーリンク
いつもシェア、ありがとうございます!
もっと情報を探しませんか?
関連記事
最近の記事
- パナソニック ジェットウォッシャードルツ EW-DJ61-Wのホースの修理
- LinuxセキュリティモジュールIntegrity Policy Enforcement
- アマゾンのEcho Show 5を買ったのでレビューします
- アマゾンのサイバーマンデーはAlexa Echo Show 5が安い
- Android スマートフォン OnePlus 7T と OnePlus 7の違い
- Android スマートフォン OnePlus 7 をAndroid10にアップデートしてみた
- クレジットカードのバーチャルカードの比較のまとめ
- 活動量計 Xiaomi Mi Band 4を買ってみたのでレビュー
- Android スマートフォン OnePlus 7 のレビュー
- AliExpressでスマートフォンを買い物してみた
- パソコンのホコリ対策 レンジフードフィルターと養生テープ
- 80PLUS GOLDのPC電源ユニットAntec NeoEco 750 Goldのレビュー
- イギリスの付加価値税 VAT は払い戻しを受けられる
- イギリスのロンドンでスーツケースなど荷物を預けられる場所は
- イギリスのロンドンで地下鉄やバスに乗るならオイスターカードを使おう
- イギリスのヒースロー空港からロンドン市内への行き方
- 航空便でほかの航空会社に乗り継ぎがある場合のオンラインチェックイン
- SFC会員がANA便ではなくベトナム航空のコードシェアを試して解ったこと
- ベトナムの入国審査でeチケットの掲示が必要だった話
- シアトルの交通ICカードはオルカカード(Orca)です
人気のページ
- Windows7 IME 辞書ツールで単語の登録に失敗しました
- C言語 popen()でコマンドを実行して出力を読み込む
- Windows7で休止状態にする方法
- CentOS MySQLの起動、停止、再起動
- loggerコマンドでsyslogにエラーを出力する方法
- パソコンパーツの買取をしてくれる店のまとめ
- Java Mapの使い方 get(),put(),remove(),size(),clear()
- 楽天のRポイントカードを作ってみた
- iPhone 5 から iPhone 6 に乗り換えたのでレビュー
- netstatコマンドのステータスの意味
スポンサーリンク
過去ログ
2020 : 01 02 03 04 05 06 07 08 09 10 11 122019 : 01 02 03 04 05 06 07 08 09 10 11 12
2018 : 01 02 03 04 05 06 07 08 09 10 11 12
2017 : 01 02 03 04 05 06 07 08 09 10 11 12
2016 : 01 02 03 04 05 06 07 08 09 10 11 12
2015 : 01 02 03 04 05 06 07 08 09 10 11 12
2014 : 01 02 03 04 05 06 07 08 09 10 11 12
2013 : 01 02 03 04 05 06 07 08 09 10 11 12
2012 : 01 02 03 04 05 06 07 08 09 10 11 12
2011 : 01 02 03 04 05 06 07 08 09 10 11 12
2010 : 01 02 03 04 05 06 07 08 09 10 11 12
2009 : 01 02 03 04 05 06 07 08 09 10 11 12
2008 : 01 02 03 04 05 06 07 08 09 10 11 12
2007 : 01 02 03 04 05 06 07 08 09 10 11 12
2006 : 01 02 03 04 05 06 07 08 09 10 11 12
2005 : 01 02 03 04 05 06 07 08 09 10 11 12
2004 : 01 02 03 04 05 06 07 08 09 10 11 12
2003 : 01 02 03 04 05 06 07 08 09 10 11 12