20
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

シーエー・アドバンス Advent Calendar 2022Advent Calendar 2022

Day 19

Webアプリケーションの脆弱性クイズアプリを作ってみました

Last updated at Posted at 2022-12-19

はじめに

こんにちは、株式会社シーエー・アドバンス技術統括本部の宮里です。

普段は業務でWebアプリケーションやAndroid,iOSアプリなどの脆弱性診断を行っています。
今回はWebアプリケーションの脆弱性クイズアプリを簡単に作ってみましたので紹介します。

脆弱性とは

脆弱性とは、OSやソフトウェア、プログラムの不具合や設計上のミスが原因となって発生する悪用できるバグを指します。

詳しい解説はこちらが参考になると思うので、興味がある方はぜひ見てみてください。
https://www.soumu.go.jp/main_sosiki/joho_tsusin/security/basic/risk/11.html

作った経緯

個人的に趣味でUnityを触る機会があったので、アドベントカレンダーをきっかけに普段の業務の紹介に繋がるような簡単なアプリを作ってみようと思ったのがきっかけでした。

スクリプトはC#で書いています。

クイズについて

今回は、以下の脆弱性についてのクイズを用意しました。

  1. クロスサイトスクリプティング(XSS)
  2. クロスサイト・リクエストフォージェリ(CSRF)
  3. SQLインジェクション
  4. メールヘッダ・インジェクション
  5. アクセス制御の不備

「アクセス制御の不備」に関しては、パッとイメージつきにくいかもしれませんが、ぜひアプリをインストールして確認してみてください!!

誰が、どういう操作を行う事ができるのが適切か を考えるとヒントになると思います!

また、今回はiOSには対応しておらずAndroidアプリのみになりインストールの手順は省略します。

アプリの作成について

Unityを利用してアプリを作成する際にスクリプトをいくつか書きました。
初めての経験でUnityならではの部分もあって楽しく作成することが出来ました。

Unity側で用意したオブジェクトをスクリプト上で取得したり、変更したりする場合、スクリプト上で変数を定義した後にUI上からドラッグ&ドロップで当てはめる必要があったり、

(答えが載っちゃってますかね?気のせいですよ)

正解音、不正解音は著作権フリーの素材から探したりして普段と違う作業をしている感じが新鮮でした。
今回はこちらから利用させていただきました。
https://soundeffect-lab.info/

画面の崩壊もしっかり経験しました(端末によって線がずれてしまう)

ゲームとしての作りこみ

今回、もっと出来たなと思う所は以下の点でした。

  1. 4択の回答が毎回同じ並びなのでランダムに出来たら良かった
  2. 画面が味気ない
  3. 結果を表示する時、点数を最後に出すなどのアニメーションを作れたら良かった

世の中のゲームを作る人達は気を遣ってゲームを作っているんだなと感じる事が出来て面白かったです!

最後に

apkはこちらにあります、良かったら遊んでみてください~
https://github.com/miyazato1014/quiz/releases/tag/apk

20
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
20
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?