位置: 编程技术 - 正文

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

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

  • 自来水适用高税率吗
  • 税前利润计算公式变动成本法
  • 所得税申报资产不允许为0?
  • 折旧费计算主要有几种方法?分别有什么特点?
  • 应发工资包含请年假吗
  • 企业筹建期间利息支出税前扣除怎么算
  • 固定资产一次性折旧政策2023
  • 珠宝属于什么行业领域
  • 尚未收到货款,填什么凭证
  • 加工样品全流程总结
  • 企业法人个人帐户是什么
  • 土地租赁需要交土地使用税吗
  • 印花税这个月没交怎么办
  • 国有企业出租房屋管理规定
  • 减免税期间是什么意思
  • 购进旅客运输服务抵扣会计分录
  • 税务稽查执法要以什么为依据,按照法定的职责
  • 办理核定企业所需资料
  • 分配利润账务处理
  • 有进项税额转出怎么结转增值税
  • 技术合同与购销合同区别
  • 增值税的附加税有哪些,税费多少
  • 缴纳社保的账务处理办法
  • 以无形资产进行投资
  • 怎么清除更新记录
  • 缴纳的权利许可有哪些
  • php程序员不应该做的事
  • php数组原理
  • win7系统中怎样
  • 采购合同付款违约条款怎么签
  • 政府补助资金能否作为资本金
  • 资产减值损失的借贷方向
  • 外商投资企业有哪些出资方式
  • 预收的购货款属于收入吗
  • 被税怎么办
  • uni-app打包h5
  • elementui常用组件有哪些
  • 一维卷积padding
  • 2023年网络安全专题教育
  • php curl 封装
  • 小微企业具体指
  • 销售服饰
  • 房屋出租怎么开电子发票
  • 上期未申报怎么办
  • 不能加计扣除的研发费用在辅助账怎么反映
  • 预提跨年工资怎么处理
  • 帝国cms使用手册
  • mongodb简单使用
  • mysql中文乱码解决
  • 抵扣进项税额是啥意思
  • 未确认融资费用账务处理
  • 广告牌制作计入什么科目
  • 黄金珠宝加工销售怎么样
  • 员工预支钱要写什么单据
  • 应交税费减免税额在借方还是贷方
  • 研发费用的会计处理对公司经营成果的影响
  • 多做费用有什么好处
  • 营业外支出包括哪些内容
  • 代理记账企业如何通过互联网创新发展
  • mysql中具体到删某一个数据
  • ubuntu14.04升级18.04
  • macos rootless
  • IPad怎么连接电视机看看影视
  • linux就该这么
  • Win8用Ribbon Disabler工具关闭Ribbon功能区界面
  • Win10 Mobile RedStone 14283已修复与已知问题汇总
  • js让按钮不能点击
  • cocos html
  • opengl learning中文
  • Extjs4中的分页应用结合前后台
  • ie11滚动条样式
  • node.js中的http.response.write方法使用说明
  • jquery获取自定义标签的值
  • Android优化蓝牙
  • python3.5升级
  • bootstrap快速入门
  • google it automation with python
  • 百旺怎么导出数据
  • 进口增值税如何勾选认证
  • 浙江税务开票系统
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设