✏️
ougege
  • README
  • Docs
    • index
    • Articles
      • AI
        • 体验Chrome AI
        • 体验Cloudflare Workers AI
        • 体验deepseek
      • CSS
        • CSS优化-PurgeCSS
        • 实用效果
        • 开发常用样式
      • Deepin
        • deepin20安装mysql
        • deepin使用tensorflow入门机器学习
        • deepin安装cuda和cuDNN
        • deepin安装lamp
        • deepin安装nvidia驱动
        • deepin安装oh my Zsh
        • deepin安装p7zip
        • deepin换源
        • 安装deepin系统后要做的事
      • Docker
        • CI/CD搭建配置
        • deepin搭建docker环境
        • docker安装和使用gitlab
        • docker搭建nginx+php环境
      • Essay
        • IOS申请邓白氏编码
        • Markdown-Mermaid
        • Markdown Use
        • webview白屏的问题查找和修复
        • 前端开发对接问题和解决办法汇总
        • 国务院机构改革方案
        • 国家级智库
        • 实用网站推荐
        • 常用Markdown数学公式语法
        • 强烈推荐前端要安装的vscode扩展
        • 新建销售计划-页面卡死问题分析
        • 海淘入坑手册
        • 竞品研究
        • 足球知识速成
      • Git
        • GitBook安装和常用命令
        • GitKraken免费版本
        • Git安装和配置
        • Git异常处理
        • Git Worktree使用
        • 前端工程化相关的实用git命令
      • JS
        • ESM模块导出方式对比
        • Emoji多端统一处理
        • JS发布订阅模式
        • JS性能优化
        • JS标准内置对象
        • JS链式调用原理
        • Promise介绍和使用
        • Range的使用
        • Vue+Oauth登录实现
        • Vue实现富文本插入Emoji
        • chrome扩展入门
        • es5新特性
        • es6常用特性
        • es常用片段
        • uniapp使用eslint校验代码
        • 与移动端通信
        • 优秀js库moment
        • 使用vue-socketio
        • 实现一个中间件
        • 小程序webview调试
        • 常用snippets
        • 常用正则
        • 常用的设计模式
        • 微信jssdk封装使用
        • 浏览器宏任务和微任务
        • 浏览器的5种Observer
        • 深入理解赋值、浅拷贝、深拷贝
        • 解析vue指令clickoutside源码
        • 键盘事件与KeyBoardWrapper交互
        • 高德地图常用方法封装
        • 高阶函数片段
      • Network
        • 使用Lighthouse分析前端性能
        • 前后端启用https
        • 宝塔nginx安装ngx_brotli
        • 比较gz与br加载速度
        • 浏览器https提示不安全
        • 浏览器提示HSTS
        • 简单使用tcpdump
        • 静态资源gzip优化
      • Node
        • CommonJS模块导出方式对比
        • Taro command not found 多平台解决方案
        • koa使用和API实现
        • node安装报错Unexpected-token
        • 使用nvm和nrm
        • 使用uniapp给小程序添加云函数
        • 使用verdaccio搭建本地npm仓库
        • 使用vue-cli搭建vue项目
        • 安装Node.js和npm配置
        • 编译成cjs和mjs的思路解析
        • 让你的npmPackage同时支持cjs和mjs
        • 通过GithubAction将内容部署到vps
      • Python
        • Python源管理
        • Python版本管理
        • mitmproxy抓包
        • 微信公众平台开发爬坑经历
      • Shell
        • Ubuntu安装deepin桌面环境
        • Ubuntu安装flatpak软件
        • Ubuntu安装wireshark
        • Ubuntu常见问题汇总
        • dell G3装系统无法识别第二块硬盘
        • linux下virtualbox用gho还原系统
        • mysql常用命令
        • navicat连接一键集成环境的mysql
        • nginx常用命令
        • pm2常用命令
        • virtualbox虚拟机和宿主机互相复制粘贴
        • vps内资源通过mega快传到本地
        • vps报错temporary failure in name resolution
        • vscode修改文件监控数
        • windows+linux双系统引导修复
        • zsh常用插件和命令
        • 一键搭建ChatGPT web版
        • 使用V2ray,CloudFlare Warp解锁GPT
        • 使用vscode进行java开发
        • 利用zx和SSHKey发布代码到服务器
        • 反爬虫一些方案总结和尝试
        • 安装1Panel
        • 安装Bt面板
        • 安装Ubuntu22.04后要做的事
        • 无显示器linux设置默认分辨率
        • 特别实用的shell命令
        • 解决linux安装xmind缺少依赖报错
      • Standards
        • CSS格式化之stylelint
        • CSS规范
        • HTML规范
        • JS规范
        • commit规范
        • 使用husky+commitlint规范代码提交
        • 使用semantic-release自动管理版本号
        • 命名规范
        • 图片规范
        • 版本编号规范
      • Wall
        • 科学上网-Cloudflare-Pages
        • 科学上网-Cloudflare-Warp
        • 科学上网-Geph
        • 科学上网-RackNerd
        • 科学上网-Slicehosting
        • 科学上网-Surfshark
        • 科学上网-Tor
        • 科学上网-XX-NET
        • 科学上网-heroku
        • 科学上网-shadowsock
        • 科学上网-v2ray使用
        • 科学上网-v2ray搭建
        • 科学上网-浏览器代理
        • 科学上网-让终端走代理
      • Windows
        • SourceTree破解免登录(windows版)
        • git bash交互提示符不工作
        • nexus 7 2013 wifi 刷机
        • tree命令生成文件目录
        • 利用charles抓包app
        • 安装Openssl
        • 安装msi文件报错2503和2502
        • 神器vimium使用说明
        • 自用host
        • 解决win10扩展出来的屏幕模糊
        • 解决安装Adobe Air时发生错误
    • Snippets
      • zsh
        • docker
        • extract
        • git-commit
        • git
        • mysql-macports
        • npm
        • nvm
        • pip
        • pm2
        • systemd
        • ubuntu
        • vscode
Powered by GitBook
On this page
  • 简介
  • 成果展示
  • 安装Python3
  • 安装Werobot
  • 安装FTP
  • 使用FileZilla连接FTP服务器
  • 获取微信公众平台配置
  • 创建简单案例hello.py
  • 创建目录结构
  • 完善帮助提示help.py
  • 完善短网址功能shortUrl.py
  • 完善搜歌功能music163.py
  • 完善主入口hello.py
  • 暗坑
  • 参考文档

Was this helpful?

  1. Docs
  2. Articles
  3. Python

微信公众平台开发爬坑经历

Previousmitmproxy抓包NextShell

Last updated 10 months ago

Was this helpful?

简介

本文总结了开发微信公众号的后台接入过程的步骤和经验,主要包括:

  1. VPS 服务器搭建 Python + Werobot 环境,搭建 FTP 服务器,使用FileZilla 方便代码上传(环境为 Ubuntu 16.04LTS );

  2. 订阅号后台接入,并通过微信公众平台的验证;

  3. 开发完成短网址和搜歌服务;

  4. 开发过程中遇到的坑和解决办法

成果展示

如下图所示:

安装Python3

  # 切换到root
  sudo -i
  apt-get install python3 python3-pip python3-dev

安装Werobot

  pip3 install werobot

安装FTP

博主已经预装 lnmp 环境,直接选择压缩文件的 pureftpd.sh 执行

  ./pureftpd.sh

注意:执行 lnmp ftp add 操作前先创建一个网站目录,否则安装完后要重新添加软连接

创建 ftp 账号, 按步骤输入 name , password , directory

  lnmp ftp add

注意:第三步目录位置要写绝对路径

  # 列出所有ftp账户
  lnmp ftp list

  # 删除某个ftp账户
  lnmp ftp del

使用FileZilla连接FTP服务器

获取微信公众平台配置

注意:先别点击提交,会提示 token 验证失败,需要后面操作完成后在保存

创建简单案例hello.py

  #coding:utf-8
  # Filename:hello_world.py
  # 验证服务器,并且收到的所有消息都回复'Hello World!'

  import werobot
  # token 来自于微信公众平台基本配置
  robot = werobot.WeRoBot(token='your token')

  # @robot.handler 处理所有消息
  @robot.handler
  def hello(message):
      return 'Hello World!'

  # 让服务器监听在 0.0.0.0:80
  robot.config['HOST'] = '0.0.0.0'
  robot.config['PORT'] = 80
  robot.run()
  python3 hello.py # 运行

此时在公众平台点击提交,提示 token 验证成功,然后点击启用

创建目录结构

完善帮助提示help.py

  class Help:
    def start():
      reply = '帮助文档\n'
      reply_1 = '【1】 查询天气: 城市+天气,例如“杭州天气”\n'
      reply_2 = '【2】 短网址: 输入“短网址+链接”转成短网址\n'
      reply_3 = '【3】 搜歌: 输入“歌曲:歌名”搜索歌曲,例如(歌曲-男孩)\n'
      return reply + reply_1 + reply_2 + reply_3

完善短网址功能shortUrl.py

  #!/usr/bin/python
  # -*- coding: utf-8 -*-
  import requests
  import json

  class ShortUrl:
    def create(address):
      newAddress = address.split('短网址', 1)
      host = 'https://dwz.cn'
      path = '/admin/v2/create'
      url = host + path
      method = 'POST'
      content_type = 'application/json'

      # TODO: 设置Token
      token = '填入百度开发者的token'

      # TODO:设置待创建的长网址
      bodys = {'Url':newAddress[1],'TermOfValidity':'1-year'}

      # 配置headers
      headers = {'Content-Type':content_type, 'Token':token}
      
      # 发起请求
      response = requests.post(url=url, data=json.dumps(bodys), headers=headers)

      # 读取响应
      # print(response.text['ErrMsg'])
      resDict = json.loads(response.text)
      if (resDict['ErrMsg'] == ''):
        return resDict['ShortUrl']
      else:
        return resDict['ErrMsg']

完善搜歌功能music163.py

  #!/usr/bin/python
  # -*- coding: utf-8 -*-
  import requests
  import json

  class Music163:
    # 歌曲Id
    def searchSong(musicName):
      newMusicName = musicName.split('歌曲-', 1)
      defaulUrl = 'https://v1.itooi.cn/netease/search?type=song&pageSize=1&page=0&'
      searchStr = 'keyword=' + newMusicName[1]
      url = defaulUrl + searchStr
      method = 'GET'

      # 发起请求
      response = requests.get(url)

      # 读取响应
      resDict = json.loads(response.text)
      songIds = resDict['data']['songs']
      name = songIds[0]['name']
      singer = songIds[0]['ar'][0]['name']
      id = songIds[0]['id']
      singleSong = {'name': name, 'singer': singer, 'id': id}
      return singleSong

    # 歌曲地址
    def songUrl(singleSong):
      tempArr = []
      defaulUrl = 'https://v1.itooi.cn/netease/url?quality=320&isRedirect=0&'
      searchStr = 'id=' + str(singleSong['id'])
      url = defaulUrl + searchStr
      method = 'GET'

      # 发起请求
      response = requests.get(url)

      # 读取响应
      resDict = json.loads(response.text)
      name = singleSong['name']
      singer = singleSong['singer']
      url = resDict['data']
      return [name, singer, url]

完善主入口hello.py

  #coding:utf-8
  import sys, random, json, re
  sys.path.append('./util/')
  from werobot import WeRoBot
  from werobot.replies import TextReply, ArticlesReply, Article, MusicReply

  # 帮助wiki
  from help import Help

  # 转换短网址
  from shortUrl import ShortUrl

  # 歌曲搜索
  from music163 import Music163

  robot = WeRoBot(token='填入公众号token')

  # 文本消息
  @robot.filter('天气')
  def start():
      return Help.start()

  # 短网址
  @robot.filter(re.compile('短网址.*?'))
  def transUrl(message):
      # return message.content
      reply = TextReply(message=message, content=ShortUrl.create(message.content))
      return reply

  # 歌曲搜索
  @robot.filter(re.compile('歌曲-.*?'))
  def searchMusic(message):
      singleSong = Music163.searchSong(message.content)
      dealArr = Music163.songUrl(singleSong)
      return dealArr

  # 图片消息
  @robot.image
  def img(message):
      return message.img

  # 被关注
  @robot.subscribe
  def showWiki():
      return Help.start()

  robot.config['HOST'] = '0.0.0.0'
  robot.config['PORT'] = 80
  robot.run()

暗坑

  1. token 验证仅支持 80 端口和 443 端口,否则会一直出现 token验证失败

  2. python3 在 print 的内容必须用括号包裹(调试常遇到)

  3. 在 python3 hello.py 运行报错端口被占用,解决如下:

    netstat -lnp|grep 80  # 查看80端口被哪些服务占用
    # 大概率是nginx,杀掉即可
    nginx -s stop
    # 重新运行
    python3 hello.py
  4. 报错类似 'ascii' codec can't encode character 请检查返回值是否正确 string

  5. 有时候线上运行代码报错,但是调试其实只需要改动一点点,避免 ftp 重复劳动,直接 putty 连接使用 vi 修改

  6. 其实最一开始我是选的 Django + wechatpy 开发的,写了 Demo ,token 验证也能通过,就是在消息 reply 处理总是出现各种莫名问题,很烦,然后继续找框架,才用上 werobot

参考文档

如下图所示:

如下图所示:

如下图所示:

在开发前一定要统一环境,确定使用 python2 还是 python3 ,否则写代码和调试很容易出问题,我本地 python2 运行正常,线上 python3 报错,后来发现 python3 有些方法没有了:

python 在同一 class 中的 def 调用,使用 self 传递:

一键安装lnmp环境
百度短网址API
音乐集成API
示例
Python中self的解释
python参考
werobot文档
微信开发者文档