位置: 编程技术 - 正文

PHP写微信公众号文章页采集方法(php推送微信公众号客户消息)

编辑:rootadmin

推荐整理分享PHP写微信公众号文章页采集方法(php推送微信公众号客户消息),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php推送微信公众号客户消息,微信公众号开发php源码,php写微信公众号怎么写,微信公众号开发php源码,php 微信公众号,php公众号推送完整示例,php公众号开发,php公众号开发,内容如对您有帮助,希望把文章链接给更多的朋友!

通过搜狗搜索采集公众号历史消息有几个问题:

1、有验证码;

2、历史消息列表只有最近条群发内容;

3、文章地址是有有效期的;

4、据说批量采集还要换ip;

通过我前面文章的方法就没有这些问题,虽然采集系统搭建不如传统采集器写个规则去爬就可以了那么简单。但是一次搭建好之后批量采集的效率还是可以的。而且采集的文章地址是永久有效的,并且可以采集到一个公众号所有的历史消息。我们还是从一个公众号文章的链接地址开始看:

1、从微信右上角菜单复制到的链接地址:

1)原文内容:

原文内容是包含在一个<div id='js_content'></div>标签中的,通过php代码获取:

正则的开头识别<div id='js_content'>,结尾识别<script/iUs,匹配到之后前面再补充一个<div id='js_content'>;我的正则匹配水平有限,只能写成这样的了。希望有高人能指点更好的正则匹配方法。

另外注意:这个匹配规则会可能在一段时间之后有变化。这篇文章会尽量保持更新。如果你根据我的文章制作了采集系统之后,当某一天失效了,别忘了回来再看看文章是否有更新。

2)内容处理:

通过上面的方法我们获得了文章内容的html,但是你将文章内容显示出来之后就会发现,图片和视频不能正常显示。因为这个html还需要一些加工:

PHP写微信公众号文章页采集方法(php推送微信公众号客户消息)

首先是图片,微信文章中的<img>标签中的src属性全部都用了data-src属性代替。只有在显示的时候才会被替换过来。所以我们也有两个方案,将源代码直接替换过来,或者用js在显示时候再替换。下面我先介绍直接替换html的方法:

然后是视频,视频的显示不正常,经过长期测试后发现只要替换一个页面地址就能解决,过程就不说了,直接说结果:

通过这两个替换之后,文章内容html中的图片和视频就都正常了。

3) 公众号相关信息:

通过本专栏之前的文章,介绍了我们使用微信客户端,任意打开一个公众号的历史消息页之后。系统从数据库中识别biz的值,发现数据库中没有记录,就会插入一条新的纪录。之后的采集队列就会定期根据这个biz来获取这个公众号的历史消息列表。

但是我们只获得了这个公众号的biz,公众号的名称,头像这两个重要信息还是没有获取到。主要原因是历史消息页面中没有这两个信息。但是我们可以从文章页面中获取到。

在微信文章页面html的底部,有一些js的变量赋值的代码,通过正则匹配之后我们就可以获得这两个公众号的信息:

通过这两个正则匹配,我们就能获取到公众号的头像和昵称,然后根据文章地址中的biz,可以保存到对应的微信号数据表中。

3、文章的保存和处理

前面的代码已经将文章内容获取到变量中了。如何保存其实每个人也许都有自己的想法。我这里介绍一下我的保存内容的方法:

将文章内容的html以数据库id为文件名保存成html文件,以biz字段为目录。

以上代码是一个标准的php建立文件夹保存文件的代码,大家可以根据自己的实际情况安排保存方法。

在这之后我们就可以在自己的服务器上得到一个html文件,内容就是公众号的文章内容。我们可以从浏览器中打开看一下。这时你也许会发现图片防盗链了!无法正常显示!包括数据库中保存的文章封面图,公众号的头像都是防盗链的。

别急,这个问题很好解决,只需要将图片也保存到自己的服务器,无非是将来会占用自己的服务器空间和带宽。

图片防盗链的原理是当图片在网页中显示的时候,图片服务器会检测到引用这张图片的服务器域名,当发现服务器域名不包含

如何采集微信公众号历史消息页 采集微信文章和采集网站内容一样,都需要从一个列表页开始。而微信文章的列表页就是公众号里的查看历史消息页。现在网络上的其它微信采集器有

php提取身份证号码中的生日日期以及验证是否为成年人的函数 php提取身份证号码中的生日日期以及确定是否成年的一个函数。可以同时确定位和位的身份证,经本人亲测,非常好用,分享函数代码如下:php//用ph

php猜单词游戏 直接复制本地运行就可以了phpsession_start();header("Content-type:text/html;charset=utf-");$url='

标签: php推送微信公众号客户消息

本文链接地址:https://www.jiuchutong.com/biancheng/275969.html 转载请保留说明!

上一篇:用好anyproxy提高公众号文章采集效率

下一篇:如何采集微信公众号历史消息页(公众号采集文章手机操作)

  • 需要出口
  • 还有什么技术
  • 金蝶专业版仓库反审核怎么做
  • 淘宝发票收取的税点是谁来交
  • 合作社免税收入需要成本吗?
  • 转出未交增值税是借方还是贷方
  • 销售商品的成本计入什么科目
  • 投资性房地产计量模式的转换
  • 神州优车开具的客运服务费入什么科目?
  • 固定资产计提折旧的方法
  • 奖励给优质供应商会计处理怎么做?
  • 公司将固定资产卖出,要交什么税
  • 分公司和总公司的财务是分开的吗
  • 商业保险税前扣除限额
  • 固定资产怎么填报
  • 电器供应
  • 委托付款分录
  • 影响盈利能力的外部因素
  • 固定资产少计提了怎么办
  • 以前年度损益调整怎么做账
  • 应交税费和应交税金的区别属于什么科目
  • 冲红发票会计分录大全
  • php使用composer
  • 广告公司物料报价清单
  • 路由器重启后电视放不出来咋办
  • vue项目页面写在哪里
  • 公司房产税如何征收税率
  • vue数据更新会触发什么生命周期
  • vue的watch监听
  • 企业合并支付的资产评估费计入
  • 红字发票步骤
  • 巴塞罗那城市布局
  • css实现轮播图侧边阴影效果
  • 小规模企业需要交几个点
  • 权利许可证照印花税优惠政策
  • 第三方代收的款项是什么意思
  • yolo v1 pytorch源代码
  • 睿智目标检测yolov8
  • unrar解压命令
  • 小规模纳税人没达到起征点怎么申报
  • 小规模纳税人企业所得税2023
  • 供应商发票多开了3毛钱能做到财务费吗
  • mysql怎么修改
  • 银行手续费未开发票前计入什么科目
  • 已核准未登记名称我可以注册吗
  • 库存股属于什么类科目,借贷方向
  • 国际结算手续费收入增值税
  • 电子承兑背书了能撤回吗
  • 城建税50%减免条件
  • 跨月发票作废怎么做会计分录
  • 上年记错账了,本年如何调整
  • 注册资本实缴后钱怎么出来
  • 其他应付款时间长了怎么处理?
  • centos安装NVIDIA驱动
  • linux如何安装c语言编译器
  • 系统审核策略配置
  • bios界面uefi
  • w10预览版21343下载
  • xp主题设置
  • Linux系统怎么重启网卡
  • win7 64位系统QQ自动退出重新登录提示您已登录不能重复登录的解决方法
  • win7系统桌面右键没有个性化
  • linux系统问题汇总
  • 鼠标双击速度
  • win8系统安装的软件在哪里
  • win8.1安装包
  • texturepackergui
  • [置顶] [笔记]
  • bc1998录制的css视频教程推荐新手看下
  • python生成器怎么用
  • nodejs获取post数据
  • BaseAdapter数据刷新,自定义BaseAdapter
  • js 实现复制到粘贴功能
  • recyclerview和scrollview
  • javascript数据结构与算法第三版
  • javascript:void(0)点击登录没反应怎么解决
  • javascript的基本规范
  • jquery有自定义选择器吗
  • 广东国家税务局电子税务局官网入口
  • 自治区地方税务局于立民简介
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设