惯性聚合 高效追踪和阅读你感兴趣的博客、新闻、科技资讯
阅读原文 在惯性聚合中打开

推荐订阅源

博客园 - Franky
N
Netflix TechBlog - Medium
Google Online Security Blog
Google Online Security Blog
月光博客
月光博客
量子位
酷 壳 – CoolShell
酷 壳 – CoolShell
V
V2EX
腾讯CDC
OSCHINA 社区最新新闻
OSCHINA 社区最新新闻
博客园 - 聂微东
让小产品的独立变现更简单 - ezindie.com
让小产品的独立变现更简单 - ezindie.com
M
MIT News - Artificial intelligence
Vercel News
Vercel News
The GitHub Blog
The GitHub Blog
Hugging Face - Blog
Hugging Face - Blog
博客园 - 【当耐特】
Apple Machine Learning Research
Apple Machine Learning Research
aimingoo的专栏
aimingoo的专栏
博客园 - 三生石上(FineUI控件)
CTFtime.org: upcoming CTF events
CTFtime.org: upcoming CTF events
MongoDB | Blog
MongoDB | Blog
H
Help Net Security
The Cloudflare Blog
Blog — PlanetScale
Blog — PlanetScale
F
Full Disclosure
G
Google Developers Blog
罗磊的独立博客
Jina AI
Jina AI
钛媒体:引领未来商业与生活新知
钛媒体:引领未来商业与生活新知
Y
Y Combinator Blog
H
Hackread – Cybersecurity News, Data Breaches, AI and More
J
Java Code Geeks
A
About on SuperTechFans
IT之家
IT之家
大猫的无限游戏
大猫的无限游戏
S
SegmentFault 最新的问题
有赞技术团队
有赞技术团队
GbyAI
GbyAI
雷峰网
雷峰网
T
The Blog of Author Tim Ferriss
The Register - Security
The Register - Security
U
Unit 42
D
Docker
Martin Fowler
Martin Fowler
L
LINUX DO - 热门话题
NISL@THU
NISL@THU
阮一峰的网络日志
阮一峰的网络日志
C
Cybersecurity and Infrastructure Security Agency CISA
博客园_首页
Google DeepMind News
Google DeepMind News

Fooleap's Blog

渴望理想 | Fooleap's Blog 19 年底一些事 | Fooleap's Blog 藉秋风,跑起来 | Fooleap's Blog 一个人去跑步 | Fooleap's Blog 8 月的跑量仿佛是那暑假的作业 | Fooleap's Blog 三伏天跑步那么难受,为何还要跑? | Fooleap's Blog 解决小程序开发“当前系统代理不是安全代理” | Fooleap's Blog 忘却配速的夏日跑步 | Fooleap's Blog 六月天时“带水”跑步更爽 | Fooleap's Blog 出来混迟早要还的 | Fooleap's Blog 跑步不能当饭吃 | Fooleap's Blog 将京东移动端详情页链接转为 PC 端 | Fooleap's Blog 不是热就是雨 | Fooleap's Blog 这半月,我跑了 11 个 520 | Fooleap's Blog 跑完流汗一时爽,一直流汗一直爽 | Fooleap's Blog 初夏夜跑 | Fooleap's Blog Electron 中打开 QQ 临时会话 | Fooleap's Blog 春节期间的培隆角 | Fooleap's Blog 从春天跑到夏天 | Fooleap's Blog 晨雾中奔跑 | Fooleap's Blog 漫步春雨中 | Fooleap's Blog 跑在木棉花下 | Fooleap's Blog 我在春节依然坚持跑步 | Fooleap's Blog 伴随着日出跑步 | Fooleap's Blog 没有最好,只有更好 | Fooleap's Blog 电子气温计 | Fooleap's Blog 渡亭小学的金凤花 | Fooleap's Blog 随心而跑 | Fooleap's Blog 2018 跑步小结 | Fooleap's Blog 在 gVim 中使用“非等宽字体” | Fooleap's Blog 动车进汕,喜大普奔 | Fooleap's Blog 雨战汕马,漫步鮀城 | Fooleap's Blog 准备出发汕马 | Fooleap's Blog 环苏溪跑个半马 | Fooleap's Blog 不义之财 | Fooleap's Blog 跑去培隆看日落 | Fooleap's Blog 雨后跑土路 | Fooleap's Blog 秋意渐浓 | Fooleap's Blog 在夕阳下奔跑 | Fooleap's Blog 准备参加 2018 汕马 | Fooleap's Blog 不可立见的 spoiler 标签 | Fooleap's Blog TomTom Spark 表带 | Fooleap's Blog Disqus 支持新浪微博图床 | Fooleap's Blog 暂存 Disqus 匿名评论者邮箱地址 | Fooleap's Blog 组一台迷你主机 DeskMini 310 | Fooleap's Blog 我的个人信息卖给了谁? | Fooleap's Blog 我发了违法短信? | Fooleap's Blog 使用 Python 合并地图瓦片 | Fooleap's Blog 使用 Python 合并瓦片图 | Fooleap's Blog 拆电热水壶 | Fooleap's Blog 使用树莓派做监控显示 | Fooleap's Blog 南方的冷 | Fooleap's Blog 蓝牙耳机 Avantree Jogger Plus | Fooleap's Blog 新厝布网 | Fooleap's Blog 报装移动宽带 | Fooleap's Blog 双十一战绩 | Fooleap's Blog 郁闷的心情 | Fooleap's Blog 像 Disqus 一样获取链接颜色 | Fooleap's Blog Disqus 的 URL 编码问题 | Fooleap's Blog 选择框的全选联动 | Fooleap's Blog 弹出层中的视频全屏问题 | Fooleap's Blog 2016 年台风海马 | Fooleap's Blog 纯 CSS 实现导航图标动画 | Fooleap's Blog 湾头晨跑路线推荐:南湾小学跑道 | Fooleap's Blog Jekyll 显示每一年的文章数 | Fooleap's Blog 湾头晨跑路线推荐:南湾堤顶 | Fooleap's Blog Disqus 的 @ 提及功能 | Fooleap's Blog 近日渡亭堤顶的夕阳 | Fooleap's Blog 使用 Disqus API 上传图片 | Fooleap's Blog Disqus API 评论嵌套问题 | Fooleap's Blog Disqus API 的权限问题 | Fooleap's Blog 湾头晨跑路线推荐:环三湾 | Fooleap's Blog 如何下载 Apple Emoji 的 PNG 图片 公众号文章二维码 | Fooleap's Blog Disqus 的评论预审核 | Fooleap's Blog 湾头最好的跑道 | Fooleap's Blog 结合七牛和高德地图 API 显示照片位置 | Fooleap's Blog Zip 压缩排除特定目录 | Fooleap's Blog 流水涸摸蚬热 | Fooleap's Blog 2017 跨年跑 | Fooleap's Blog Jekyll 的中文字数统计 | Fooleap's Blog 为 Jekyll 文章页添加相关文章 | Fooleap's Blog 为 Jekyll 添加一个标签页面 | Fooleap's Blog 干了这瓶蛇草水 | Fooleap's Blog 在 macOS 上使用 NTFS 差点丢数据 Disqus Moderator Badge Text 已支持中文 为 Jekyll 添加一个简单的 API | Fooleap's Blog 为 Jekyll 加上简单搜索功能 | Fooleap's Blog 解决 Jemoji 的出错 | Fooleap's Blog 解决 This socket is closed 问题 更好的 Markdown 插图方式 | Fooleap's Blog 转换 Nike+ 的坐标数据 | Fooleap's Blog 高德地图 API 显示跑步路线 | Fooleap's Blog 善用 Google 搜索工具 | Fooleap's Blog 利用 Nike+ API 获取跑步路线数据 | Fooleap's Blog 七牛 API 生成页面 URL 二维码 旧年 12 月跑步笔记 | Fooleap's Blog 科学使用 Disqus | Fooleap's Blog 培隆角的日出 | Fooleap's Blog 11 月跑步笔记 | Fooleap's Blog
检测网络是否能够访问 Disqus | Fooleap's Blog
fooleap · 2017-05-07 · via Fooleap's Blog

此前,顺着科学使用 Disuqs 的思路,鄙人利用 Disqus API 实现了基本的访客留言功能,虽不完美,但也够用。后来,还是想在网络条件允许的情况下加载 Disqus 原生评论框,网络条件不佳的情况下加载自制评论框。

存在问题

利用 Disqus API 实现的评论框,所谓的不完美主要有以下:

  1. Disqus 原生评论框已不为访客用户调用 Gravatar 头像
  2. 尚未实现发送访客自己 IP 给 Disqus
  3. 未实现推荐、点赞等功能

第一点,Disqus 评论框以前根据访客用的邮箱信息调用 Gravatar 头像,但在某次更新之后,就没有再调用 Gravatar 头像。若博客评论都采用 Disqus 访客留言的 API,那么在 Disqus 原生评论框上显示就是默认头像,虽可指定,但强迫症你懂的。

第二点,IP 信息 Disqus API 有提供参数,发送请求却返回权限不足,同理还有位置信息等数据。是的,这个并不是重点,所以我也没有花再多时间去研究。

第三点,因所有访客用户的 HTTP Headers 及 IP 信息都一样,故推荐、点赞等功能无法实现。若能实现第二点,才有可能实现推荐、点赞等功能。

若直接在网页中使用 AJAX 去请求 Disqus API,应该能实现二、三点所提及的功能。但这样就得翻墙,倒不如直接加载 Disqus 原生评论框。

屏蔽现状

我们总说 Disqus 被墙,那么 Disqus 被墙的域名是什么?目前,Disqus 三个域名目前在国内的情况大致如下:

域名 说明 使用
disqus.com Disqus 主域名,国内大多数网络无法访问 网站、API 等
disquscdn.com Disqus 静态资源 CDN,国内大多数网络可以访问 头像、图片
disq.us Disqus 出站链接,国内大多数网络可以访问 跳转链接

从上表可以看出,最为主要还是主域名 disqus.com,想要实现检测网络是否能够访问 Disqus,干脆就直接检测能否连接 disqus.com

实现流程

能想到的方法就是在网页中通过 AJAX GET 请求 disqus.com 一个小文件,若能成功返回,则加载 Disqus 原生评论框;若返回失败,则加载自制评论框。

其大致流程如下:

st=>start: 开始
e=>end: 结束
op1=>operation: 请求
cond1=>condition: 响应
op2=>operation: Disqus 评论框
op3=>operation: 自制评论框

st->op1(right)->cond1
cond1(yes)->op2->e
cond1(no)->op3->e

具体代码

我发现 Disqus 评论框加载的时候,都会请求一个小文件:

https://disqus.com/next/config.json

经测试,这个文件不存在跨域的权限问题,在自己网站上亦可发送异步请求。

在这里,直接使用XMLHttpRequest 这个 API 来发送请求便可,具体应用起来需要考虑的就没有上面流程图那么简单任性,必须配合 XMLHttpRequest 的具体事件来做一些适配,以下是一个简单的例子:

var xhr = new XMLHttpRequest();
xhr.open('GET', '//disqus.com/next/config.json?' + new Date().getTime(), true);
xhr.timeout = 3000;
xhr.onreadystatechange = function () {
    if (xhr.readyState == 4 && xhr.status == 200) {
        // 加载 Disqus 评论框
    }
}
xhr.ontimeout = function () {
    xhr.abort();
    // 加载自制评论框
}
xhr.onerror = function() {
    // 加载自制评论框
}
xhr.send(null);

采用超时的方法来判断是否能连接上 Disqus,是因为我想 3 秒内无法成功 GET 这个小文件,就算翻了墙,评论框的加载速度也不容乐观。

更加合理

加载 Disqus 评论框最初就是需要加载一个 js 文件,何不在根据它的状态来判断呢?onload 便是能加载,这不就能省去一步了吗?搞起:

var disqus_onload = false;
var disqus = document.createElement('script');
disqus.src = '//shortname.disqus.com/embed.js';
disqus.setAttribute('data-timestamp', +new Date());
disqus.onload = function(){
    disqus_onload = true;
}
disqus.onerror = function(){
    disqus_onload = false;
}
document.head.appendChild(disqus);

setTimeout(function(){
    if ( !disqus_onload ){
        disqus_onload = true;
        // 加载自制评论框,隐藏掉 Disqus 原生评论框的 div
    }
}, 3000);

Disqus JS 文件三秒内没有 onload,则加载自制评论框。这里有一个 bug,有可能只是网速慢点,Disqus 评论框会继续加载,所以加载自制评论框的同时可以隐藏掉原生评论框。

事实上,若灵活利用 Disqus 相关的回调函数,或许能带来更好的体验。比如说 onReady 时,给个可以切换的提示。

这些天感觉就算翻了墙,有时候访问 Disqus 还是挺慢的。我想了另一种方案,就是无论如何,同时加载两种评论框,Disqus 评论框做隐藏,监听 Disqus 的事件,当某个事件发生时切换至 Disqus 评论框。

st=>start: 开始
e=>end: 结束
op1=>operation: 加载两种评论框
cond1=>condition: Disqus 加载失败
op2=>operation: 某事件切换到 Disqus 评论框

st->op1(right)->cond1
cond1(no,right)->op2->e
cond1(yes)->e

流程图看起来是否简单了很多?有时间我会把这些想法打成包。

后来,我发现如果打开页面就请求加载 Disqus 的 JS 文件,若无法访问,会导致菊花一直转,转一段时间后才会停止,这样对用户来说是不好的。所以我还是觉得第一种方法比较好,后面也把想法打包实现了三种加载方案。

本文历史

  • 2017 年 05 月 07 日 完成初稿
  • 2017 年 05 月 11 日 完善
  • 2017 年 05 月 24 日 另一种方案
  • 2017 年 06 月 19 日 更新

最近更新

猜你喜欢