質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

3回答

4156閲覧

リッチテキストエディタを利用する場合で、サーバー側にアップロードする場合のXSS対策について

pegy

総合スコア245

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2021/04/12 08:04

現在、リッチテキストエディタを利用したウェブサイトを構築しようと検討しています。
私が利用を予定しているのはquill.jsという商業利用も制限がないものになります。

HTML

1<form> 2 <div id="editor" style="height: 200px;"></div> 3 <input type="hidden" name="main" id="editor-input"> 4 <button type="submit" name="subbtn">投稿する</button> 5<form> 6 7<script> 8var editor = document.getElementById('editor'); 9var editorInput = document.getElementById('editor-input'); 10 11var quill = new Quill(editor, { 12 theme: 'snow' 13}); 14 15quill.on('text-change', function(delta, oldDelta, source) { 16 var editorHtml = editor.querySelector('.ql-editor').innerHTML; 17 editorInput.value = editorHtml; 18}); 19<script/>

上記のようにhiddenを用意してあげて、最終的にJSを使ってテキストに変更がある度に値を格納しているんのですが、その後submitでサーバーサイドにあげる際に問題となります。もちろん<タグ>を残したままデータベースに格納することはその後出力する際にXSSのリスクに晒されるため、無害化しなければならないと考えているのですが、特に上記quillのドキュメンテーションやガイドを読む限り、サーバーにあげる場合の無害化する方法については、何らの記載がありません。
quill.js以外でも一般的にリッチテキストエディタを利用してサーバーにアップする場合には、想定されるタグを全てリストとして準備してこれを無害化・変換してアップロードする方法を自分自身で準備するのが一般的なのでしょうか?

「リッチテキストエディタ サーバーアップロード」、「quill php」など、いろいろ検索しても、これといったものが見つからなかったため、実務的にみなさまがどのように対応されているかを知りたくご質問させていただきました。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答3

0

ベストアンサー

想定されるタグを全てリストとして準備してこれを無害化・変換してアップロードする方法を自分自身で準備するのが一般的なのでしょうか?

そうですね、許可するタグ・属性はホワイトリストで規定する必要があります(ブラックリストでやると、古いブラウザで使えるものや最新のものを取り逃すことが考えられます)。

そのようなフィルタリングライブラリも、探せばあるかと思います。

投稿2021/04/12 08:06

maisumakun

総合スコア146063

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

pegy

2021/04/12 08:53

有難うございます。kawax様のように出力時のみホワイトリストを使用するというお考えでしょうか? 一方レンタルサーバーによってはそもそもタグ付き文字列がdb格納を認めない場合もあるようですので、その場合格納時から対策が必要にもなろうかとは思います。 宜しくお願い申し上げます。
maisumakun

2021/04/12 09:01

そもそも論にはなりますが、Quillは本来のデータ構造があるもの(で、そのままフォーム送信するためのものではない)なので、innerHTMLでHTMLを取り出して、という使い方そのものが本筋から外れていることは指摘しておきます。 > 一方レンタルサーバーによってはそもそもタグ付き文字列がdb格納を認めない場合もあるようですので そんなでたらめな「セキュリティ対策のような、まともに使えない処理」を施しているレンタルサーバを使う方が悪いです。
pegy

2021/04/12 09:16

重ねて有難うございます。 レンタルサーバーの仕様については、やはり考えづらいのでもう一度調べてみます。 本当に申し訳ございません。前段のそもそも論の文脈がどうしても理解出来なかったのですが、構造を持っているため、innerHTMLを使わずにそのまま取得すれば良いじゃないか、という意味でしょうか? また、最後に格納時、出力時の無害化のタイミングについて、実務的なアドバイスを理由を含めてご教示願えますでしょうか?サーバーの仕様は、上記の通り曖昧なコメントをしてしまい、誠に申し訳ございません。一旦その観点はご放念ください。 宜しくお願い申し上げます。
maisumakun

2021/04/12 09:20

> 構造を持っているため、innerHTMLを使わずにそのまま取得すれば良いじゃないか、という意味でしょうか? そうですね。HTMLとして取り出してしまえば再編集も困難になりますので、「Quillのデータ構造」で保存して引き回せるのならそのほうが望ましいです。
pegy

2021/04/12 09:43

理解出来ました、有難うございます。 無害化の格納時、出力時のタイミングは申し訳ございません、自分で今一度調べて考えてみます。
guest

0

DBに保存してるだけなら危険はない。
絶対に許可すべきではないタグはこの段階で消してもいいけど、基本的には入力時には余計なことは何もしなくていい。
大事なのは出力時のエスケープ。

投稿2021/04/12 08:31

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

pegy

2021/04/12 08:49

有難うございます。格納時、出力時またはいずれに於いても変換すべき説もあるのですが、実際には確かに出力時に意図しない動作をしなければ問題はない認識です。一般的にscriptタグ以外絶対許可すべきでないものとして、一般的に認識されているものはあるのでしょうか?
guest

0

具体的に入力して試しましたか?

text

1<script>alert("hoge");</script>

のように入力しても editorInput.value

text

1"<p>&lt;script&gt;alert('hoge');&lt;/script&gt;</p>"

のようになるようですが…。

投稿2021/04/12 08:15

mather

総合スコア6759

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

pegy

2021/04/12 08:46

コメントありがとうございます。結果は確かに仰る通りでした。 まだまだ不案内で申し訳ないのですが、quill.onメソッドの中で実際に無害化されており、結果scriptタグは変換され、pタグは残っているという事でしょうか? ただ、それが正しいとしてもサーバーサイドでも無害化処理は入れなければならないという認識なのですが、如何でしょうか?
maisumakun

2021/04/12 08:52

> ただ、それが正しいとしてもサーバーサイドでも無害化処理は入れなければならないという認識なのですが、如何でしょうか? そのとおりです。攻撃者はフォームを使わずに任意のHTMLを送信可能です。
mather

2021/04/12 09:03

p タグは残っている、というよりリッチエディタが p タグを付与しています。(表示されるテキストエリアにはpタグは直接は入力していません) なんにせよ、任意のデータはPOSTリクエストで送信可能です。リッチエディタが付与するタグ以外の送信を禁じるのであれば、送られてきたデータ(HTML)をサーバーサイドで精査して拒否するしか無いと思います。
pegy

2021/04/12 09:44

承知を致しました、時間を頂きアドバイスをくださり誠に有難うございました。 宜しくお願い申し上げます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問