python自动预约公众号

需要的工具

  • fiddler
  • python 3.8

    第一步——抓包

    由于之前我在大学的时候就有用python写脚本抢图书馆座位的经验,所以大概了解这种公共预约平台,其实就一个get或者post请求就能搞定拉。

所以用fiddler抓一下预约的api就好。

你问我为啥不用F12?见下图

这个预约平台不允许其他浏览器访问哦

 

所以接下来在微信PC端先手动预约成功一下,然后到fiddler中就可以找到api了。
抓取成功


 

这其中我碰到的坑

报错:只能用微信客户端打开


这个还是比较容易解决的,只要将header中的 "User-Agent" 改成fiddler 中的样子就OK了。

服务器持续返回405


一开始百度,说是将post方式改成get方式。我试了一下不行,而且fiddler提交方式也是post。

后面再百度,说可能是这个链接就不支持post方式

我一想是不是api搞错了,去fiddler一看,果然我复制粘贴少了,赶紧改了,果然服务器返回200,访问成功。

服务器返回未知错误


这个可就哭死我了,看到200本来乐了一下,结果对方服务器居然不认。
服务器返回不认识我的内容

解体思路: 这种情况一般都是服务器看了你提交的信息,然后说:”滚,我看不懂。“这时候看看是不是数据漏了什么,或者格式是不是有问题。

按照这个思路检查代码,果然提交的时候格式不匹配。

我用python提交的是dict类型,但是服务器只认json。

将dict转成json后,果然预约成功了!

预约成功

附上代码

import requests
import time
import json

# 先创建url 和 headers,然后直接request看行不行。
url = 'https://appointment-users.dataesb.com/api/appointment/pub_add/'

header = {
    "Accept": "*/*",
    "Accept-Encoding": "gzip, deflate, br",
    "Accept-Language": "zh-CN,zh;q=0.9,en-US;q=0.8,en;q=0.7",
    "User-Agent": "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36 NetType/WIFI MicroMessenger/7.0.20.1781(0x6700143B) WindowsWechat(0x6305002e)",
    "Referer": "https://appointment-users.dataesb.com/",
    "unionid": "oF-BrwA9WTNTX2DXed_Rad_pHp4g",
    "Content-Length" : "175",
    "Content-Type": "application/json;charset=UTF-8",
    "Origin": "https://appointment-users.dataesb.com" ,
    "Sec-Fetch-Dest" : "empty" ,
    "Sec-Fetch-Mode" : "cors" ,
    "Sec-Fetch-Site" : "same-site" , 
    "Connection": "keep-alive" ,
    "Host": "appointment-backend-cdn.dataesb.com"
}

post_data = {"subLibId":"1089",
             "scheduleId":1268766,
             "children":0,
             "card":"",
             "cardType":"IDCARD",
             "name":"",
             "phone":"",
             "childrenConfig":False,
             "code":""}

time_str_13 = int(float(time.time()) * 1000) #创建时间戳
param = {
    "timestamp" : time_str_13,
    "callback" : "#/index/1089?counter=1646524800000"
}

# 然后这样执行就好啦
r = requests.post(url, json = post_data, headers = header, params = param, verify = False)

  • 14
    点赞
  • 93
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python可以用于爬取微信公众号的文章。有几种方式可以实现这一目标,其中一种方式是通过登录微信公众号平台,在里面搜索要爬取的公众号,然后进行抓包。另外一种方式是使用安卓模拟器进行抓包。还可以使用搜狗的微信模块来获取数据。 在使用第一种方式时,首先需要拥有一个微信公众号的账。然后,通过工具如pycharm和fiddler等,登录微信公众号平台,进入创作管理,选择图文素材,然后创建或编辑文章。最后,通过添加引用和查找公众号文章等步骤,进行数据的爬取和收集。 在实现这些步骤之前,你需要了解微信公众号平台的主要功能和界面布局。主面板可以划分为七大块,每个块都有不同的功能。在后续的操作中,你可以使用Python代码来模拟微信请求,并实现数据的爬取和分析。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [欢度国庆⭐️共享爬虫之美⭐️基于 Python 实现微信公众号爬虫(Python无所不能爬)](https://blog.csdn.net/xiejiachao/article/details/120573509)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [【爬虫】python爬取微信公众号](https://blog.csdn.net/qq_36269293/article/details/109244944)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值