A estrutura do cliente WeChat escrita em linguagem Perl, baseada em Mojolicious, requer Perl versão 5.10+ e pode fornecer uma interface API baseada no protocolo HTTP por meio de plug-ins para outras linguagens ou sistemas chamarem
Este projeto segue integralmente as funções originais fornecidas oficialmente pelo WeChat e não inclui quaisquer atos de sabotagem, roubo de conta, etc. Este projeto é totalmente de código aberto. O objetivo é promover o intercâmbio técnico e o aprendizado. país, empresas, indivíduos, etc. é proibido, caso contrário, haverá consequências pretensiosas.
nome | prioridade | Estado atual | autor do github | Descrição da função |
---|---|---|---|---|
Mostrar mensagem | 100 | Publicado | sjdy521 | Imprimir mensagens recebidas e enviadas pelo cliente |
IRCShell | 99 | Publicado | sjdy521 | Usando WeChat através do cliente irc em ambiente Linux |
Openwx | 98 | Publicado | sjdy521 | Fornece interface API de envio de mensagens WeChat |
Beleza | 95 | Publicado | sjdy521 | Identifique palavras-chave específicas e envie fotos de mulheres bonitas |
Tradução | 93 | Publicado | sjdy521 | Função de tradução multilíngue |
Base de Conhecimento | 2 | Publicado | sjdy521 | Personalize a base de conhecimento de perguntas e respostas por meio de mensagens do WeChat |
Verificação automática | 1 | Publicado | sjdy521 | Aprovar automaticamente ao receber uma solicitação de verificação de amizade |
PósQRcode | 0 | Publicado | sjdy521 | Faça login no código QR e envie-o para seu e-mail para digitalização remota. |
Carregar QRcode | 0 | Publicado | sjdy521 | Carregue o código QR na base de imagens para obter o URL de acesso à rede pública |
XiaoiceResponder | 1 | Publicado | sjdy521 | Use o Microsoft XiaoIce para implementar respostas de bate-papo inteligentes |
Mostrar código QR | 0 | Publicado | sjdy521 | Chame o programa de visualização de imagens do sistema para exibir o código QR (atualmente suporta apenas win) |
Resposta inteligente | 0 | Publicado | sjdy521 | Resposta de bate-papo inteligente |
Para mais plug-ins, consulte a lista completa de plug-ins
Basta digitar um único comando para iniciar um chatbot inteligente, tanto Perl quanto você são tão elegantes.
cpanm Mojo::Weixin && perl -MMojo::Weixin -e "Mojo::Weixin->new->load('ShowMsg')->load('SmartReply')->run()"
[16/01/19 23:10:49] [info] 客户端准备登录...
[16/01/19 23:10:50] [info] 清除残留的历史二维码图片
[16/01/19 23:10:30] [info] 二维码已下载到本地[ /tmp/mojo_weixin_qrcode.jpg ]
[16/01/19 23:11:20] [info] 等待手机微信扫描二维码...
[16/01/19 23:12:09] [info] 手机微信扫码成功,请在手机微信上点击 [登录] 按钮...
[16/01/19 23:12:10] [info] 正在进行登录...
[16/01/19 23:12:10] [info] 微信登录成功
[16/01/19 23:13:40] [info] 获取联系人信息...
[16/01/19 23:13:40] [info] 更新个人信息成功
[16/01/19 23:14:41] [info] 更新好友信息成功
[16/01/19 23:15:42] [info] 更新群组[ 红包群 ]信息成功
[16/01/19 23:15:42] [info] 更新群组[ Perl语言交流 ]信息成功
[16/01/19 23:15:42] [info] 开始接收消息...
[16/01/19 23:15:00] [群消息] 小灰|Perl语言交流 : Mojo::Weixin不错哦
[16/01/19 23:15:58] [群消息] 我->Perl语言交流 : 多谢多谢
+-------------------+ +----------------+
| Tencent | | Any IRC Client |
| Weixin Server | | wechat、irssi |
+---v-------------^-+ +-v------------^-+
| | | |
| 微信协议交互| |IRC协议交互 |
+-- --- |-- - - -- | - - - -- - - --- | --- ----- | --+
| +---v-------------^--+ +----v------------^-+ |
| | <——————————————————< | |
| | Weixin Client | Weixin - IRC | IRC Server | |
| | | 协议转换 | 监听本机6667端口 | |
| | >——————————————————> | |
| +--------------------+ +-------------------+ |
| |
| 我们程序实现的部分 |
+--- - - - - -- - -- ---- ------ ------- ------ --- ----+
Recomenda-se usar cpanm para instalar o módulo Mojo::Weixin online. Se você usar o docker, consulte Instalação e uso da imagem do Docker.
Instalar perl
Antes da instalação, confirme se o Perl já está instalado em seu sistema, pois exceto o Windows, a maioria das outras plataformas podem tê-lo pré-instalado por padrão.
E sua versão Perl é pelo menos 5.10.1+, 5.14+ é recomendado
A página de download do site oficial do Perl contém instruções de instalação relativamente abrangentes e detalhadas para múltiplas plataformas Unix/Linux, Mac OS X e Windows.
Recomenda-se que você tente escolher a versão Binários (binários pré-compilados), que pode ser utilizada imediatamente após a instalação, o que é mais conveniente.
Se a sua versão do perl for inferior no Linux e você quiser atualizar o perl, você pode considerar usar a ferramenta perlbrew
plataforma | Escolha recomendada | Endereço de download |
---|---|---|
Windows | 1. MorangoPerl 2. ActivePerl 3. Mojo-MorangoPerl | Endereço de download do StrawberryPerl Endereço de download Mojo-StrawberryPerl Endereço de download do ActivePerl |
Linux | 1. O sistema vem com 2. Gerenciadores de pacotes como yum/apt 3. Compilação oficial do código-fonte 4. ActivePerl 5. DWIM-Perl | Endereço de download do ActivePerl Endereço de download DWIM-Perl |
Mac | 1. O sistema vem com 2. ActivePerl | Endereço de download do ActivePerl |
Perceber:
Mojo-StrawberryPerl é simplificado e empacotado com base em StrawberryPerl e é adequado para sistemas Windows de 32/64 bits.
Instale a ferramenta cpanm (você pode ignorar esta etapa se o cpanm já estiver instalado no sistema)
Método a: Instale o cpanm via cpan (somente para usuários root)
$ cpan -i App::cpanminus
Método b: Instale o cpanm diretamente online
$ curl -kL http://cpanmin.us | perl - App::cpanminus
官方服务器在国外,如果无法访问,可以选择下面的命令:
$ curl http://share-10066126.cos.myqcloud.com/cpanm.pl|perl - App::cpanminus
Use cpanm para instalar o módulo Mojo::Weixin online (se o sistema já tiver instalado o módulo, executar esta etapa atualizará o módulo)
$ cpanm Mojo::Weixin
Se continuar avisando que o download falhou durante o processo de instalação, provavelmente é porque o acesso da rede ao servidor externo é ruim.
Nesse caso, você pode tentar especificar manualmente o site espelho doméstico da seguinte maneira:
$ cpanm --mirror http://mirrors.163.com/cpan/ Mojo::Weixin
Soluções com falha na instalação que podem ajudar
Se você não tiver sorte e não conseguir uma instalação inicial via cpanm, aqui estão algumas informações que podem ser úteis
Durante a instalação do Mojo::Weixin, cpan ou cpanm nos ajudará a instalar automaticamente muitos outros módulos dependentes
Entre os muitos módulos dependentes, aquele que costuma estar sujeito a problemas de instalação é IO::Socket::SSL.
IO::Socket::SSL fornece principalmente suporte a https. O processo de instalação pode envolver a compilação de bibliotecas relacionadas a SSL.
Para usuários do Linux, geralmente são usadas compilação e instalação. Se o sistema não tiver o ambiente necessário para compilação e instalação, a compilação falhará.
Para usuários do Windows, como não existe um bom ambiente de compilação e instalação, é recomendado usar alguns ambientes de execução Perl que foram empacotados de forma mais abrangente.
Por exemplo, as versões mais recentes do mais popular StrawberryPerl ou ActivePerl incluem o módulo de dependência principal do Mojo::Weixin por padrão.
RedHat/Centos:
$ yum install -y openssl-devel
Ubuntu:
$ sudo apt-get install libssl-dev
Depois de corrigir o ambiente de compilação e execução, volte para a etapa 2 e instale o Mojo::Weixin.
Por favor, tente instalar e usá-lo como root. Para instalação e uso sem root, consulte o FAQ.
Se ainda tiver problemas, você pode tentar executar o seguinte script no Linux para verificar os módulos dependentes
$ curl -ks "https://raw.githubusercontent.com/sjdy521/Mojo-Weixin/master/script/check_dependencies.pl"|perl -
Estou muito familiarizado com Perl e sou um Perler profissional
Este projeto é um módulo Perl puro que foi lançado para cpan. Leia atentamente a documentação de uso do módulo Mojo::Weixin
.
Além disso, você pode conferir mais exemplos de código no diretório demo
Não estou familiarizado com Perl e sou desenvolvedor de outras linguagens. Estou interessado apenas na interface de envio/recebimento de mensagens fornecida.
Você pode salvar diretamente o código a seguir em um arquivo de código-fonte (deve usar a codificação UTF8) e usar o interpretador Perl para executá-lo
#!/usr/bin/env perl
use Mojo::Weixin;
my ($host,$port,$post_api);
$host = "0.0.0.0"; #发送消息接口监听地址,没有特殊需要请不要修改
$port = 3000; #发送消息接口监听端口,修改为自己希望监听的端口
#$post_api = 'http://xxxx'; #接收到的消息上报接口,如果不需要接收消息上报,可以删除或注释此行
my $client = Mojo::Weixin->new(log_level=>"info",http_debug=>0);
$client->load("ShowMsg");
$client->load("Openwx",data=>{listen=>[{host=>$host,port=>$port}], post_api=>$post_api});
$client->run();
Salve o código acima como um arquivo xxxx.pl e use perl para executá-lo. O login do WeChat será concluído e um servidor http escutando a porta de endereço especificada será gerado na máquina local.
$ perl xxxx.pl
Exemplo de chamada de interface para envio de mensagens de amigos
http://127.0.0.1:3000/openwx/send_friend_message?id=xxxx&content=hello
* About to connect() to 127.0.0.1 port 3000 (#0)
* Trying 127.0.0.1...
* Connected to 127.0.0.1 (127.0.0.1) port 3000 (#0)
> GET /openwx/send_friend_message?id=xxxxx&content=hello HTTP/1.1
> User-Agent: curl/7.29.0
> Host: 127.0.0.1:3000
> 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":"发送成功","id":23910327,"code":0}
Para obter mais descrições de parâmetros de interface, consulte a documentação da API do plug-in Openwx.
Sou um geek, só quero poder jogar o chat do WeChat através do IRC na linha de comando
Leia as etapas para usar o plug-in IRCShell
JavaScript
Pitão
Java
Você pode patrocinar digitalizando o código QR de pagamento Alipay. Obrigado por seu apoio e incentivo.
Agradecimentos especiais aos amigos que patrocinaram
Direitos autorais (C) 2014 por sjdy521
Esta biblioteca é um software livre; você pode redistribuí-la e/ou modificá-la sob a licença MIT e a licença Anti 996.