使用perl-ldap修改a user's password in MS Active Directory

1.安装perl-ldap
  下载地址:http://search.cpan.org/~gbarr/perl-ldap/
  前提是已经安装perl工具包。首先查看perl版本
  [root@local~]perl -V
  Built under linux
  Compiled at Nov  8 2007 06:49:06
  @INC:
    /usr/lib64/perl5/site_perl/5.8.8/x86_64-linux-thread-multi
    /usr/lib/perl5/site_perl/5.8.8
    /usr/lib/perl5/site_perl
    /usr/lib64/perl5/vendor_perl/5.8.8/x86_64-linux-thread-multi
    /usr/lib/perl5/vendor_perl/5.8.8
    /usr/lib/perl5/vendor_perl
    /usr/lib64/perl5/5.8.8/x86_64-linux-thread-multi
    /usr/lib/perl5/5.8.8
  接着,解压安装(安装方式是手动,不需要执行make)
  [root@local~]tar -zxvpf perl-ldap-0.39.tar.gz
  [root@local~]cd perl-ldap-0.39/lib
  [root@local~]cp -a * /usr/lib/perl5/site_perl/5.8.8
2.安装perl-ldap依赖的Convert::ASN1模块
   下载地址:http://search.cpan.org/search?module=Convert::ASN1
   [root@local~]tar -zxvpf Convert-ASN1-0.22.tar.gz     
   [root@local~]cd Convert-ASN1-0.22
   [root@local~]perl Makefile.PL
   [root@local~]make
   [root@local~]make install
3. 使用perl-ldap修改a user's password in MS Active Directory
   [root@local~]$ vim chg_passwd.pl

#!/usr/bin/perl -w

use strict;
use Net::LDAPS;

my($Ad,$mesg,$uid,$pass,$npass,$dn,$rtn);

#($uid,$pass) = split(" ",<STDIN>);
$uid="test";
$pass="123456";

if (($uid eq "") or ($pass eq "")) {
    print "Uid and/or password missing in input/n"; exit 1;
}

print "Trying to set $uid to password $pass/n";
# 1. Bind to the AD server
    $Ad = Net::LDAPS->new("ad02.example.com",  port=>636,version => 3) or print "Unable to connect to AD server/n",exit 2;
    $Ad->bind(dn => "cn=administrator,ou=finance,dc=example,dc=com",password => "123456") or print "Unable to bind to AD server/n",exit 2;

#2. Do a AD lookup to get the dn for this user     $mesg = $Ad->search(base => "DC=example,DC=com",filter => "cn=$uid");     print $mesg->count;     print "/n";         if($mesg->count != 1) {         print "AD lookup failed for user $uid/n"; exit 3;     } #4. Add quotes and uniCode     map { $npass .= "$_/000" } split(//,"/"$pass/""); #5. Now change their password.     $dn = $mesg->entry(0)->dn;     $rtn = $Ad->modify($dn,replace => [ "unicodePwd" => $npass ]);     if($rtn->{'resultCode'} != 0) {         print "User $uid,setting password failed/n"; exit 2;     } #6. free    $Ad->unbind();    print "Password for $uid changed in AD/n";    exit 0;

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...