The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.

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);    
$qun->authorize()

进行授权,这是->new()之后第一件要做的事情,只有授权成功才能够顺利进行后续的操作

授权过程比较复杂,采用了和Webqq相同的MD5+RSA+TEA+BASE64的组合加密,计算需要花费一定的时间

因此authorize的过程可能需要等待10s甚至更久,取决于你的运行环境

你可以安装如下几个模块,程序会自动检查并进行调用,能够极大的提升RSA加密的计算速度

Crypt::RSA(或者 Crypt::OpenSSL::RSACrypt::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

Webqq::Client

http://qun.qq.com/member.html

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.