分享

微信端域名拦截检测PHP源码

 fanfl0517 2022-11-21 发布于江苏

当域名被微信封禁时,访问的链接会先经过微信服务器检测,如果正常就放行,否则会重定向跳转到拦截页面。

原理

访问的域名会首先经过微信服务器的检测,前提是只有打开的过程中才会检测,这正是这件事儿的难点。换个思路想下,如果我们能够让微信自己的域名经过微信的检测,那么这件事就成了。翻遍了微信官方各种api,功夫不负有心人,找到了【长链接转成短链接】,可以把我们的链接转成微信自己的链接,这样判断短链接的重定向链接即可得知是否被封禁。

实现方案

长链转短链需要三个参数

关键的问题来了,access_token是从微信获取来的,获取access_token需要在微信后台配置白名单,并且每天限额是1000000次
access_token是公众号的全局唯一接口调用凭据,公众号调用各接口时都需使用access_token
但是,很多网站是没有公众号的,或者说100万的调用次数都不够我挥霍的,那怎么办?答案是我们可以使用微信公众平台测试账号,它的优势是无需公众账号、快速申请接口(只要有微信号就可以),可以直接体验和测试公众平台所有高级接口功能,而且不需要绑定ip白名单也可以获得access_token,最大的优势是长链转短链的服务貌似没有调用次数限制(我亲测试了很多,发现使用次数并没有变化,虽然文档上写了1000次)。
微信公众平台测试账号链接:http://mp.weixin.qq.com/
所有的准备工作已经ready,那么可以show代码了,以下代码摘自github
获取access_token

  1. /**
  2. * 根据appid和app appsecret来获取acess_token
  3. * return @param {String}
  4. */
  5. async getAccessToken() {
  6. let query = {
  7. appid: this.appid,
  8. secret: this.appsecret,
  9. grant_type: 'client_credential'
  10. };
  11. let url = `https://api.weixin.qq.com/cgi-bin/token?${querystring.stringify(query)}`;
  12. return await this.request(url);
  13. }

长链转短链

  1. /**
  2. * 通过微信api生成短链
  3. * @param {String} req_url 待检测url
  4. */
  5. async createShortUrl(req_url) {
  6. var requestData = {
  7. 'access_token': this.access_token,
  8. 'action': 'long2short',
  9. 'long_url': req_url
  10. }
  11. const url = `https://api.weixin.qq.com/cgi-bin/shorturl?access_token=${this.access_token}`;
  12. let body = await this.request(url, {
  13. method: 'POST',
  14. json: true,
  15. headers: {
  16. 'content-type': 'application/json',
  17. },
  18. body: requestData
  19. });
  20. return body && body.short_url;
  21. }

检测重定向链接来判断是否被微信封禁

  1. /**
  2. * 根据重定向之后的host是否为weixin110.qq.com来检测url是否被微信封禁
  3. * @param {String} url 待检测短链接url
  4. */
  5. checkDomainBanned(url) {
  6. return new Promise(function (resolve, reject) {
  7. return request(url, function(err, res, body) {
  8. if (!err) {
  9. if (res && res.request && res.request.uri && res.request.uri.host === 'weixin110.qq.com') {
  10. resolve({ code: -1, msg: 'banned' });
  11. } else {
  12. resolve({ code: 0, msg: 'ok' });
  13. }
  14. } else {
  15. reject(err);
  16. }
  17. })
  18. })
  19. }

尾声

很多网站提供类似的付费服务,而且价格不菲!
因为对PHP感兴趣,所以参考大佬的思路写了一个PHP版的。代码写的比较随意,但是不影响功能。有BUG欢迎反馈。需要的可以下载测试。

PHP版源码

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多