查看题目
给了一堆php代码:data:image/s3,"s3://crabby-images/5c851/5c8512805e49ca7a6f03cc77a7aa38c2ff22eeca" alt="请添加图片描述"
- include():
data:image/s3,"s3://crabby-images/d872d/d872d0fc17d9cca85f18f9f3fa2f17786485c3cc" alt="请添加图片描述" - 类似include($_GET[‘value’]; )的问题
1.可以用php://input伪协议: data:image/s3,"s3://crabby-images/853e0/853e0dc63fd35d6db9efe6be63e2f1f4850b7564" alt="请添加图片描述" data:image/s3,"s3://crabby-images/ee1d5/ee1d59f071701a7cd053ae9626f0c214716c9c79" alt="请添加图片描述"
data:image/s3,"s3://crabby-images/762ab/762abf89b8d19731b32b32214db0278a754f4579" alt="请添加图片描述"
2.可以用data://伪协议来操作: data:image/s3,"s3://crabby-images/94dc0/94dc068c2c9cea3869117e9480b2bf7c1c6ec238" alt="请添加图片描述"
接下来用data://伪协议将一句话木马写入(base64编码)data:image/s3,"s3://crabby-images/ee102/ee1026926e9aecaf2462ebb82689a1b0265a09a0" alt="请添加图片描述" 用中国蚁剑链接 data:image/s3,"s3://crabby-images/56891/56891f8bc76bfab6f8f9c9a0a954bc1a740c1ac8" alt="请添加图片描述" ——其实不用base64编码也可以:输入 http://111.200.241.244:53101/?page=data://text/plain,<?php system('ls');?>同样奏效 data:image/s3,"s3://crabby-images/90267/902677daab8219e795dff9c8994b880adfdd7d12" alt="请添加图片描述"
system() passthru() exec() shell_exec() popen() proc_open() pcntl_exec() 例如system(): data:image/s3,"s3://crabby-images/54395/543957ecbdebb857bbd41a0dbb9af88c59e7a0b9" alt="在这里插入图片描述"
伪协议常常用于文件包含漏洞之中。 在php中能够造成文件包含的函数有include、require、include_once、require_once、highlight_file、show_source、file_get_contents、fopen、file、readfile 可以放在PHP脚本的任意位置,一般放在流程控制的处理部分中。 当PHP脚本执行到include指定引入的文件时,才将它包含并尝试执行。形如标准协议HTTP、FTP的自定义协议叫做伪协议 data:image/s3,"s3://crabby-images/9444a/9444abc26a1b446df546d3e2063577d90bd9b34f" alt="请添加图片描述" file://协议: data:image/s3,"s3://crabby-images/7e770/7e770d5cfdc5618947baa9dd08145f49ecea74b9" alt="请添加图片描述"
|