位置: 编程技术 - 正文

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提高公众号文章采集效率

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

  • 出口退税哪些资料要留底
  • 税前弥补亏损是净利润吗
  • 小规模企业收入怎么做账
  • 投资收益收到的现金小于投资收益
  • 定额怎么确定
  • 加工费暂估入库的会计分录
  • 职工集资建房款属公款吗
  • 厂房无偿租赁合同
  • 酒店里的水电费怎么收
  • 财务费用汇兑损益是什么意思
  • 定额材料损耗率国家标准
  • 作废的发票怎么处理
  • 工程款填入申报表应税服务还是应税劳务一栏?
  • 去年没有交社保,今年交了有用吗
  • 债务免除的税务处理
  • 存货相关的会计科目
  • 企业的主营业务收入
  • 融资租赁抵押车辆逾期收车
  • 支付工程款时有哪些费用
  • 固定资产盘亏盘盈账务处理
  • 培训的餐费入什么科目
  • 非房地产开发企业土地增值税扣除项目
  • 保税区内的货物交易
  • 2023增值税免税政策
  • js app框架
  • 怎样调整以前年度多计的收入
  • Win11安卓子系统怎么安装apk
  • 电脑任务栏在右边怎么调回下边
  • 胆固醇为什么会高
  • 民办学校的财务制度
  • window7无法正常启动怎么办
  • 存货的毁损通过什么科目核算
  • 利息支出属于成本项目吗
  • 对公账户转入对私账户
  • 图像的生成原理
  • 前端 教程
  • css过渡动画属性
  • opencv讲解
  • linux如何使用
  • nginx怎么运行php
  • 贷款利息现金流量项目
  • 分配现金股利的分录
  • 应付短期租入固定资产的租金计入什么科目
  • 车间领用材料应编制什么凭证
  • php如何判断是移动还是pc
  • 四种股利分配政策及适用情况
  • 租赁合同印花税率多少
  • 水电费专用发票模板
  • 个人所得税进一步改革方向
  • sql server 递归
  • MySQL5.6 Replication主从复制(读写分离) 配置完整版
  • MYSQL数据库使用教程
  • 汽车销量多少才能赚钱
  • 小规模纳税人的认定标准是什么
  • 企业所得税季报是填累计数吗
  • 税控盘反写是不是说明税都已经成功申报了
  • 库存商品过期报废的会计分录是什么
  • 银行存款账面余额是企业还是银行
  • 无进项发票开具销项发票
  • 农业银行多级账簿可以代发工资吗
  • 数据库表的查询操作实验
  • Windows Server 2003将于7月14日停服 想用收费
  • win10电脑出现invalid partition table怎么弄
  • win8开机启动
  • linux磁盘配额实验报告
  • shine.exe - shine是什么进程 有什么用
  • win8取消开始界面
  • 从五方面解析Linux防火墙框架问题
  • win10画图功能
  • win7系统电脑开机后直接进入系统修复怎么办
  • windows8.1如何安装
  • win7打开软件总提示错误怎么解决
  • js经典案例代码大全
  • shell脚本 -mtime
  • node爬取数据
  • 国税总局商品编码是什么
  • 企业取得了哪些成绩
  • 换电员工作时间自由吗
  • 国地税账号密码
  • 国家税务总局176号公告
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设