使用Perl语言编写的Smartqq客户端框架

Posted OSC开源社区

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用Perl语言编写的Smartqq客户端框架相关的知识,希望对你有一定的参考价值。

Mojo-Webqq v1.7.0 

使用Perl语言编写的Smartqq客户端框架,基于Mojolicious,要求Perl版本5.10.1+,可通过插件提供基于HTTP协议的api接口供其他语言或系统调用

郑重声明

本项目完全遵循网页QQ官方提供的原始聊天功能,不包含任何破解、偷盗等行为,本项目完全开源,目的是为了促进技术交流学习,禁止任何商业盈利目的以及一切非法用途传播,否则后果自负

插件列表

  名称                 优先级   当前状态    github作者    功能说明
  ------------------------------------------------------------------------------
  ShowMsg              100      已发布      sjdy521       打印客户端接收和发送的消息
  GroupManage          100      已发布      sjdy521       群管理,入群欢迎、限制发图频率等
  MsgSync              99       已发布      sjdy521       实现qq群和irc消息同步
  IRCShell             99       已发布      sjdy521       Linux环境下通过irc客户端使用qq
  Openqq               98       已发布      sjdy521       提供qq发送消息api接口
  Perlcode             97       已发布      sjdy521       通过qq消息执行perl代码
  Perldoc              96       已发布      sjdy521       通过qq消息查询perl文档
  StockInfo            95       已发布      shalk         查询股票信息
  ProgramCode          94       已发布      limengyu1990  通过qq消息执行代码,支持26种语言
  Translation          93       已发布      sjdy521       多国语言翻译功能
  MobileInfo           93       已发布      limengyu1990  手机号码归属地查询
  KnowledgeBase        2        已发布      sjdy521       通过qq消息自定义问答知识库
  FuckDaShen           1        已发布      sjdy521       对消息中的"大神"关键词进行鄙视
  PostImgVerifycode    0        已发布      sjdy521       登录验证码发送到邮箱实现远程登录
  PostQRcode           0        已发布      sjdy521       登录二维码发送到邮箱实现远程扫码
  SmartReply           0        已发布      sjdy521       智能聊天回复

效果展示

[15/09/30 15:11:59] [info] 初始化 smartqq 客户端参数...
[15/09/30 15:11:59] [info] 检查验证码...
[15/09/30 15:11:59] [info] 检查结果: 很幸运,本次登录不需要验证码
[15/09/30 15:11:59] [info] 正在获取登录二维码...
[15/09/30 15:11:59] [info] 二维码已下载到本地[ /tmp/mojo_webqq_qrcode_xxx.png ]
[15/09/30 15:12:00] [info] 登录二维码已经发送到邮箱: ******
[15/09/30 15:12:00] [info] 等待手机QQ扫描二维码...
[15/09/30 15:12:43] [info] 手机QQ扫码成功,请在手机上点击[允许登录smartQQ]按钮...
[15/09/30 15:12:46] [info] 检查安全代码...
[15/09/30 15:12:47] [info] 设置登录验证参数...
[15/09/30 15:12:47] [info] 尝试进行登录(2)...
[15/09/30 15:12:47] [info] 登录成功
[15/09/30 15:12:47] [info] 更新个人信息...
[15/09/30 15:12:47] [info] 更新好友信息...
[15/09/30 15:12:47] [info] 更新[ PERL学习交流 ]信息
[15/09/30 15:12:52] [info] 更新[ Mojolicious ]信息
[15/09/30 15:12:55] [info] 开始接收消息...
[15/09/30 14:09:20] [群消息] 小灰|PERL学习交流 : Mojo::Webqq不错哦
[15/09/30 14:10:20] [群消息] 我->PERL学习交流 : 多谢多谢

通过irc客户端在linux终端上使用QQ

安装方法

推荐使用在线安装模块

  1. 安装cpanm工具

    方法a: 通过cpan安装cpanm

    $ cpan -i App::cpanminus

    方法b: 直接在线安装cpanm

    $ curl -L http://cpanmin.us | perl - App::cpanminus
  2. 使用cpanm在线安装 Mojo::Webqq 模块

    $ cpanm -v Mojo::Webqq
  3. 安装失败可能有帮助的解决方法

    如果你运气不佳,通过cpanm没有一次性安装成功,这里提供了一些可能有用的信息

    在安装 Mojo::Webqq 的过程中,cpan或者cpanm会帮助我们自动安装很多其他的依赖模块

    在众多的依赖模块中,安装经常容易出现问题的主要是 IO::Socket::SSL

    IO::Socket::SSL 主要提供了 https 支持,在安装过程中可能会涉及到SSL相关库的编译

    对于 Linux 用户,通常采用的是编译安装的方式,系统缺少编译安装必要的环境,则会导致编译失败

    对于 Windows 用户,由于不具备良好的编译安装环境,推荐采用一些已经打包比较全面的Perl运行环境

    例如比较流行的 strawberryperl 或者 activeperl 的最新版本都默认包含 Mojo::Webqq 的核心依赖模块

    RedHat/Centos:

    $ yum install -y openssl-devel

    Ubuntu:

    $ sudo apt-get install libssl-dev

    Window:

    这里以 strawberryperl 为例

    安装 ,这是一个已经包含  所需核心依赖的较全面的Windows Perl运行环境

    或者自己到  下载适合自己的最新版本

    安装前最好先卸载系统中已经安装的其他Perl版本以免互相影响

    搞定了编译和运行环境之后,再重新回到 步骤2 安装Mojo::Webqq即可

如何使用

  1. 我对Perl很熟悉,是一个专业的Perler

    该项目是一个纯粹的Perl模块,已经发布到了cpan上,请仔细阅读 Mojo::Weqq 模块的

    除此之外,你可以看下  目录下的更多代码示例

  2. 我是对Perl不熟悉,是一个其他语言的开发者,只对提供的消息发送/接收接口感兴趣

    可以直接把如下代码保存成一个源码文件,使用 perl 解释器来运行

    #!/usr/bin/env perluse Mojo::Webqq;my ($qq,$host,$port,$post_api);$qq = 12345678;    #修改为你自己的实际QQ号码$host = "0.0.0.0"; #发送消息接口监听地址,修改为自己希望监听的地址$port = 5000;      #发送消息接口监听端口,修改为自己希望监听的端口$post_api = 'http://xxxx';  #接收到的消息上报接口,如果不需要接收消息上报,可以删除此行my $client = Mojo::Webqq->new(qq=>$qq);
    $client->login();
    $client->load("ShowMsg");
    $client->load("Openqq",data=>{listen=>[{host=>$host,port=>$port}], post_api=>$post_api});$client->run();
    $ perl xxxx.pl

    发送好友消息的接口调用示例

    http://127.0.0.1:5000/openqq/send_message?qq=>xxxxx&content=hello
    
    * About to connect() to 127.0.0.1 port 5000 (#0)
    *   Trying 127.0.0.1...
    * Connected to 127.0.0.1 (127.0.0.1) port 5000 (#0)
    > GET /openqq/send_message?qq=>xxxxx&content=hello HTTP/1.1
    > User-Agent: curl/7.29.0
    > Host: 127.0.0.1:5000
    > Accept: */*
    > 
    < HTTP/1.1 200 OK
    < Content-Type: application/json;charset=UTF-8
    < Date: Sun, 13 Dec 2015 04:54:38 GMT
    < Content-Length: 52
    < Server: Mojolicious (Perl)
    <
    * Connection #0 to host 127.0.0.1 left intact
    
    {"status":"发送成功","msg_id":23910327,"code":0}

    更多接口参数说明参加

  3. 我是一个极客,我只想能够在命令行上通过 IRC 的方式来玩转 QQ 聊天

    $ cpanm -v Mojo::IRC::Server::Chinese #先安装 IRC 依赖模块
    
    $ perl -MMojo::Webqq -e 'Mojo::Webqq->new(qq=>$ARGV[0])->login->load(["ShowMsg","IRCShell"])->run()' xxxx #我的QQ号码作为命令第一个参数

    使用weechat、irssi、mIRC 等任意支持IRC的客户端来连接本机的6667端口,即可像普通的IRC一样的方式来使用QQ

  4. 我是一个 QQ 群主或管理员,我想给自己的群加个机器人群管理功能

    请关注 

核心依赖模块


以上是关于使用Perl语言编写的Smartqq客户端框架的主要内容,如果未能解决你的问题,请参考以下文章

Thrift远程过程调用

QBot:基于SmartQQ协议的QQ机器人

用Perl语言编写冰雹猜想程序

Perl - Win32 - 如何从另一个进程非阻塞读取文件句柄?

Perl 6 Deep Dive

Selenium自动化测试框架-01