NAME
Webqq::Qun - api for qq qun management,add member,remove member,set administrator,etc
SYNOPSIS
use Webqq::Qun;
use Digest::MD5 qw(md5_hex);
#使用QQ号和密码进行初始化,密码先进行md5加密
my $qun = Webqq::Qun->new(qq=>12345678,pwd=>md5_hex('my password'),debug=>0);
#授权是第一步
$qun->authorize() or die "authorize fail\n";
#查找指定的群
my $q = $qun->find_qun(qun_name=>"PERL学习交流");
#使用chain方式
my $q = $qun->authorize->find_qun(qun_name=>"PERL学习交流");
#在指定的群中查找指定的群成员
my $member = $q->find_member(nick => "小灰");
$q->set_admin($member); #设置该成员为管理员,需要管理员或群主权限
$q->del_admin($member); #取消该成员的管理员身份,需要管理员或群主权限
$q->set_card($member); #设置该成员的群名片,需要管理员或群主权限
$q->del_member($member);#将该成员从群中移除,需要管理员或群主权限
#直接在所有的群中搜索
my $member = $qun->find_member(qun_name=>"PERL学习交流",nick=>"小灰");
$member->dump();
#高级条件过滤
$qun->each_qun(sub{
my $q = shift;
print $q->{qun_name} if $q->{qun_type} eq "manage";#打印我管理的群
print $q->{qun_name} if $q->{qun_type} eq "attend";#打印我加入的群(非管理员或群主)
print $q->{qun_name} if $q->{qun_type} eq "create";#打印我创建的群
});
$qun->each_member(sub{
my $member = shift;
#dump出所有存在不良记录的群成员结构
$member->dump if $member->{bad_record};
#dump出所有最近一天内发言的成员
$member->dump if time-86400 > $member->{last_speek_time};
});
DESCRIPTION
腾讯提供了基于web的群管理方式,可以参见页面http://qun.qq.com/member.html
可进行群成员添加、查询、筛选、设置管理员、取消管理员、设置群名片等常用功能
本模块对该页面的功能进行了封装,提供面向对象的接口,方便实现对群成员管理的自动化操作
操作的基本流程是:
=> 1.登录(授权)
=> 2.生成token
=> 3.获取个人信息
=> 4.获取好友信息
=> 5.获取群列表信息
=> 6.获取群成员信息
=> 7.对群成员进行各种操作
CLASS AND METHOD
Webqq::Util (提供实用函数)
Webqq::Encryption(提供授权密码算法)
.-+--Webqq::Qun::Base (基类)
| |--Webqq::Qun::Authorize (提供授权功能)
| |--Webqq::Qun::Operate (提供群成功操作相关的功能)
| `----Webqq::Qun (继承自Webqq::Qun::Base Webqq::Qun::Operate Webqq::Qun::Authorize)
| `--Webqq::Qun::One (继承自Webqq::Qun,单个群绑定的类)
`--Webqq::Qun::Member (继承自Webqq::Qun::Base,单个群成员绑定的类)
- Webqq::Qun->new(debug=>0|1,qq=>xxx,pwd=>xxx)
-
构造函数,提供了几个关键参数:
qq 你的qq号 pwd 你的qq号密码的32位小写md5 debug 0|1,默认是0
返回一个Webqq::Qun的对象
my $qun = Webqq::Qun->new(debug=>1,qq=>xxx,pwd=>xxx);
-
进行授权,这是->new()之后第一件要做的事情,只有授权成功才能够顺利进行后续的操作
授权过程比较复杂,采用了和Webqq相同的MD5+RSA+BASE64的组合加密,计算需要花费一定的时间
因此authorize的过程可能需要等待10s甚至更久,取决于你的运行环境
你可以安装如下几个模块,程序会自动检查并进行调用,能够极大的提升RSA加密的计算速度
MIME::Base64 Crypt::RSA(或者 Crypt::OpenSSL::RSA Crypt::OpenSSL::Bignum )
另外,如果授权所在的网络环境和平时你的QQ号登录环境变化较大,腾讯会认为你的帐号存在异地登录异常
在授权的过程中会要求输入验证码,这种情况下会自动下载验证码文件到本地,需要自己手动输入验证码
请尽量保持和PC QQ相同的运行环境
#执行成功返回$qun本身,执行失败返回假 $qun->authorize() or die "authorize fail";
- $qun->find_qun(qun_type=>xxx,qun_number=>xxx,qun_name=>xxx)
-
在所有群中查找指定的群,支持几个固定的过滤参数
qun_type #群类型,包括create|attend|manage,分别表示创建的群|加入的群|管理的群 qun_number #群号码,纯数字 qun_name #群名称,中文需要使用UTF8编码
在列表上下文返回所有匹配的查询列表,列表中每一个元素是一个Webqq::Qun::One的对象
在标量上下文返回所有匹配结果中的第一个元素,该元素也是一个Webqq::Qun::One的对象
一个Webqq::Qun::One的对象实际上是一个hash的引用,结构如下:
{ owner #群主的qq号 qun_type #群的类型 create|attend|manage count #群成员数量 qun_name #群名称 adm_num #管理员数量 adm_max #管理员最大数量 qun_number #群号码 max_count #最大群成员数量 members=>[ #每个群成员都是一个Webqq::Qun::Member的对象,存储在members数组中 Webqq::Qun::Member obj1, Webqq::Qun::Member obj2, Webqq::Qun::Member obj3, ... } }
Webqq::Qun::Member的结构如下:
{ bad_record #0|1,是否有不良记录 qq #群成员的qq号 qun_name #群成员所在的群的名称,一个群成员可能同时存在多个群 qage #Q龄 join_time #加入群的时间 nick #昵称 sex #性别 male|female last_speak_time #最后一次发言时间 card #群名片,UTF8编码 level #群等级,潜水|传说|活跃... qun_number #群号码 role #角色 admin|owner|member }
具体的调用示例
my @match_qun = $qun->find_qun(qun_type=>"attend"); for my $q(@match_qun){ #$q是一个Webqq::Qun::One的对象,Webqq::Qun::One继承自Webqq::Qun,因此$q也具备$qun的所有方法 print $q->{qun_name},"\n" #$q->dump(); 使用dump打印对象结构 } my $match_qun = $qun->find_qun(qun_name=>"PERL学习交流"); #由于qun_name=>"PERL学习交流"的群,一般情况下也就是一个 #因此设定成在标量上下文只返回查询结果的第一个元素
- $qun->find_member()
-
在所有的群中查找匹配的的群成员,支持的过滤参数包括
sex #性别male|female card #群名片 UTF8编码 qq #qq号 nick #昵称 role #角色admin|owner|member bad_record #0|1 是否有不良记录 qun_name #群名称 qun_number #群号码
列表上下文返回所有匹配的结果,标量上下文返回匹配结果的第一个
my $member = $qun->find_member(qun_name=>"PERL学习交流",nick=>"小灰"); $member->dump();#$member是一个Webqq::Qun::Member的对象,也是一个普通的hash引用
- $q->find_member()
-
在特定的群中查找匹配的群成员,支持的过滤参数包括
sex #性别male|female card #群名片 UTF8编码 qq #qq号 nick #昵称 role #角色admin|owner|member bad_record #0|1 是否有不良记录
- $qun->each_qun(sub{...}) =item $qun->each_member(sub{..}) =item $q->each_member(sub{..})
-
find_qun()/find_member()只能按固定的参数进行过滤,如果需要更高级的过滤方式
可以通过each_qun/each_member,自己写过滤函数
#在所有的群里查找所有Q龄大于5年的群成员 $qun->each_member(sub{ my $member = shift; if($membe->{qage}>5){ ...; } });
- $q->set_admin(Webqq::Qun::Member obj)
-
设置指定的群成员为管理员,需要自身帐号具有管理员权限
my $member = $q->find_member(nick=>"小灰"); $q->set_admin($member) or die "set admin fail\n";
- $q->del_admin(Webqq::Qun::Member obj)
-
取消指定群成员的管理员身份,需要自身帐号具有管理员权限
my $member = $q->find_member(nick=>"小灰"); $q->del_admin($member) or die "cancel admin fail\n";
- $q->set_card(Webqq::Qun::Member obj,$card)
-
设置指定群成员的群名片,需要自身帐号具有管理员权限
my $member = $q->find_member(nick=>"小灰"); $q->set_card($member,"机器人-小灰") or die "set card fail\n";
- $q->del_member(Webqq::Qun::Member obj1,Webqq::Qun::Member obj2,...)
-
移除指定的群成员,需要自身帐号具有管理员权限
my $member = $q->find_member(nick=>"小灰"); $q->del_member($member) or die "remove member fail\n";
SEE ALSO
https://github.com/sjdy521/Webqq-Qun
AUTHOR
sjdy521, <sjdy521@163.com>
COPYRIGHT AND LICENSE
Copyright (C) 2014 by Perfi
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself, either Perl version 5.8.8 or, at your option, any later version of Perl 5 you may have available.