我想我可以通过 Javascript 检测浏览器本身内部的 Tor 浏览器吗?
Can I detect Tor Browser inside the browser itself, via Javascript I suppose?
如果浏览器是 Tor 浏览器,我想禁用我正在构建的 Web 应用程序的某些功能。我可以在浏览器内部(客户端,而不是服务器端)查明浏览器是否是 Tor 浏览器吗?
我更喜欢不发出任何 HTTP 请求来匹配浏览器 IP 与 Tor 出口节点的解决方案。
背景:在我的例子中,Tor 浏览器弹出一个对话框,询问用户 "Should Tor Browser allow this website to extract HTML5 canvas image data?",因为 Tor 浏览器说,canvas 图像数据可用于唯一标识浏览器。
更新: 阅读以下答案后:也许对我来说最好的解决方案是在服务器端保留 Tor 出口节点列表(最新列表,定期刷新),当浏览器加载页面时,我在 <script>
标记中设置一个变量,如果浏览器的 IP 匹配这样一个出口节点:var isProbablyTorBrowser = true
。然后客户端,不需要额外的请求,也不需要复杂的逻辑。
检测tor的"official"方法是检查用户的IP地址,看看它是否是tor出口节点。为此,Tor 运行 TorDNSEL。
这是 PHP TorDNSEL 查找的实现,来自 Irongeek
的教程
function IsTorExitPoint(){
if (gethostbyname(ReverseIPOctets($_SERVER['REMOTE_ADDR']).".".$_SERVER['SERVER_PORT'].".".ReverseIPOctets($_SERVER['SERVER_ADDR']).".ip-port.exitlist.torproject.org")=="127.0.0.2") {
return true;
} else {
return false;
}
}
function ReverseIPOctets($inputip){
$ipoc = explode(".",$inputip);
return $ipoc[3].".".$ipoc[2].".".$ipoc[1].".".$ipoc[0];
}
如果您不使用 PHP,您应该仍然能够相对轻松地适应它。
另一种检测 Tor 的方法是让脚本每半小时左右下载一次 Tor 出口节点列表,然后根据该列表检查每个用户的 IP 地址。不过,这可能不太可靠,因为并非所有出口节点都已发布。在 dan.me.uk.
上有一个您可以使用的列表和说明
编辑:由于您更新了问题,因此第二个选项(您在本地托管的列表)将更可取。
没有可靠的方法来检测 TOR 浏览器...这就是该浏览器的目标。如果你找到了一个可靠的方法,其他人也有可能找到它,告诉 TOR 开发人员然后他们关闭它。
例如所有 TOR 浏览器捆绑报告虚假但合理的用户代理。当前发行版本,例如说它是 Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/31.0
不管你实际使用什么 OS。
您可以应用一些启发式方法以一定的概率检测到 TOR 浏览器,但也会产生一些误报...
- 检查用户代理。 TOR 浏览器将在某个 OS 上报告最新的 Firefox ESR,目前是 Windows 7 32 位(但一些用户可能已经再次更改,其他用户可能只是使用 ESR 版本而不是 TOR 浏览器)
- 插件已禁用,因此
navigator.plugins
将为空(但某些用户可能再次重新启用了插件)。
- 等等
- 实际检测浏览器uses the TOR network。
当然,您必须及时更新支票,因此需要大量的维护工作。
就个人而言,鉴于检测结果不尽如人意、维护负担和用户体验改进非常有限,我根本不会尝试以不同方式处理 TOR 浏览器。
Tor 浏览器并非设计为不可检测(这是不可能做到的)。相反,它的设计使所有副本彼此无法区分:您无法严格通过 browser fingerprinting.
来跟踪浏览器从一个站点到另一个站点,或从一次访问到另一次访问。
这给了它自己独特的指纹。截至目前,
的浏览器
- 拥有
Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/31.0
的用户代理
- 具有与浏览器 window 大小匹配的屏幕分辨率(特别是如果该大小为 1000x800)
- 时区为“0”(格林威治标准时间)
- 没有插件(
navigator.plugins
为空)
应该是TBB浏览器。下一个 ESR 版本的 Firefox 发布时,User-Agent 字符串可能会更改,最有可能 Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/38.0
.
屏幕 resolution/browser window 单独匹配可以唯一标识 TBB:即使在全屏模式下,window 高度与 Firefox 中的屏幕高度之间存在一个像素的差异。
通过firefox资源包可以查看。
Firefox 使用 resource:// URI 方案从内部模块和扩展调用磁盘资源。
但其中一些资源也可能包含在任何网页中并通过脚本标签执行。 Mozilla 开发人员并未将资源视为指纹向量,尽管事实上其中一些资源可以揭示用户不希望看到的内容。例如,内置首选项文件的差异清楚地表明您正在使用 Windows 或 Linux 或 Mac,即使您使用的是 Tor 浏览器。
可能有一个比较靠谱的方法。当您尝试使用 canvas 对其进行 Base64 编码时,请检查它 returns 是否为空白(白色)图像。
When you do so an notification is shown.
无论什么用户选择JS returns 一个白色图像。因此,您可以尝试对非白色图像进行 base64(<-- 这是一个动词 ;)),然后检查是否返回了白色 base64 图像。
更新。
这是我为自己制作的示例。对我来说,检测我是否有权访问图像很重要,但它可以以某种方式用于 Tor 检测。
UPD2。
甚至可能没有显示通知,如下面的代码片段所示。可能是因为它在 iframe 中 运行。
function isTorBrowser() {
var img = document.createElement("img");
// Creates a black 1x1 px image
img.src = '';
var canvas = document.createElement("canvas");
canvas.width = 1;
canvas.height = 1;
var ctx = canvas.getContext("2d");
var imagedata = ctx.getImageData(0, 0, canvas.width, canvas.height);
return imagedata.data[0] == 255
&& imagedata.data[1] == 255
&& imagedata.data[2] == 255
&& imagedata.data[3] == 255;
}
document.getElementById('tor-browser-test').innerHTML = isTorBrowser() ? 'Is Tor' : 'Not Tor';
<div id="tor-browser-test"></div>
如果浏览器是 Tor 浏览器,我想禁用我正在构建的 Web 应用程序的某些功能。我可以在浏览器内部(客户端,而不是服务器端)查明浏览器是否是 Tor 浏览器吗?
我更喜欢不发出任何 HTTP 请求来匹配浏览器 IP 与 Tor 出口节点的解决方案。
背景:在我的例子中,Tor 浏览器弹出一个对话框,询问用户 "Should Tor Browser allow this website to extract HTML5 canvas image data?",因为 Tor 浏览器说,canvas 图像数据可用于唯一标识浏览器。
更新: 阅读以下答案后:也许对我来说最好的解决方案是在服务器端保留 Tor 出口节点列表(最新列表,定期刷新),当浏览器加载页面时,我在 <script>
标记中设置一个变量,如果浏览器的 IP 匹配这样一个出口节点:var isProbablyTorBrowser = true
。然后客户端,不需要额外的请求,也不需要复杂的逻辑。
检测tor的"official"方法是检查用户的IP地址,看看它是否是tor出口节点。为此,Tor 运行 TorDNSEL。
这是 PHP TorDNSEL 查找的实现,来自 Irongeek
的教程function IsTorExitPoint(){
if (gethostbyname(ReverseIPOctets($_SERVER['REMOTE_ADDR']).".".$_SERVER['SERVER_PORT'].".".ReverseIPOctets($_SERVER['SERVER_ADDR']).".ip-port.exitlist.torproject.org")=="127.0.0.2") {
return true;
} else {
return false;
}
}
function ReverseIPOctets($inputip){
$ipoc = explode(".",$inputip);
return $ipoc[3].".".$ipoc[2].".".$ipoc[1].".".$ipoc[0];
}
如果您不使用 PHP,您应该仍然能够相对轻松地适应它。
另一种检测 Tor 的方法是让脚本每半小时左右下载一次 Tor 出口节点列表,然后根据该列表检查每个用户的 IP 地址。不过,这可能不太可靠,因为并非所有出口节点都已发布。在 dan.me.uk.
上有一个您可以使用的列表和说明编辑:由于您更新了问题,因此第二个选项(您在本地托管的列表)将更可取。
没有可靠的方法来检测 TOR 浏览器...这就是该浏览器的目标。如果你找到了一个可靠的方法,其他人也有可能找到它,告诉 TOR 开发人员然后他们关闭它。
例如所有 TOR 浏览器捆绑报告虚假但合理的用户代理。当前发行版本,例如说它是 Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/31.0
不管你实际使用什么 OS。
您可以应用一些启发式方法以一定的概率检测到 TOR 浏览器,但也会产生一些误报...
- 检查用户代理。 TOR 浏览器将在某个 OS 上报告最新的 Firefox ESR,目前是 Windows 7 32 位(但一些用户可能已经再次更改,其他用户可能只是使用 ESR 版本而不是 TOR 浏览器)
- 插件已禁用,因此
navigator.plugins
将为空(但某些用户可能再次重新启用了插件)。 - 等等
- 实际检测浏览器uses the TOR network。
当然,您必须及时更新支票,因此需要大量的维护工作。
就个人而言,鉴于检测结果不尽如人意、维护负担和用户体验改进非常有限,我根本不会尝试以不同方式处理 TOR 浏览器。
Tor 浏览器并非设计为不可检测(这是不可能做到的)。相反,它的设计使所有副本彼此无法区分:您无法严格通过 browser fingerprinting.
来跟踪浏览器从一个站点到另一个站点,或从一次访问到另一次访问。这给了它自己独特的指纹。截至目前,
的浏览器- 拥有
Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/31.0
的用户代理
- 具有与浏览器 window 大小匹配的屏幕分辨率(特别是如果该大小为 1000x800)
- 时区为“0”(格林威治标准时间)
- 没有插件(
navigator.plugins
为空)
应该是TBB浏览器。下一个 ESR 版本的 Firefox 发布时,User-Agent 字符串可能会更改,最有可能 Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/38.0
.
屏幕 resolution/browser window 单独匹配可以唯一标识 TBB:即使在全屏模式下,window 高度与 Firefox 中的屏幕高度之间存在一个像素的差异。
通过firefox资源包可以查看。
Firefox 使用 resource:// URI 方案从内部模块和扩展调用磁盘资源。
但其中一些资源也可能包含在任何网页中并通过脚本标签执行。 Mozilla 开发人员并未将资源视为指纹向量,尽管事实上其中一些资源可以揭示用户不希望看到的内容。例如,内置首选项文件的差异清楚地表明您正在使用 Windows 或 Linux 或 Mac,即使您使用的是 Tor 浏览器。
可能有一个比较靠谱的方法。当您尝试使用 canvas 对其进行 Base64 编码时,请检查它 returns 是否为空白(白色)图像。 When you do so an notification is shown.
无论什么用户选择JS returns 一个白色图像。因此,您可以尝试对非白色图像进行 base64(<-- 这是一个动词 ;)),然后检查是否返回了白色 base64 图像。
更新。 这是我为自己制作的示例。对我来说,检测我是否有权访问图像很重要,但它可以以某种方式用于 Tor 检测。
UPD2。 甚至可能没有显示通知,如下面的代码片段所示。可能是因为它在 iframe 中 运行。
function isTorBrowser() {
var img = document.createElement("img");
// Creates a black 1x1 px image
img.src = '';
var canvas = document.createElement("canvas");
canvas.width = 1;
canvas.height = 1;
var ctx = canvas.getContext("2d");
var imagedata = ctx.getImageData(0, 0, canvas.width, canvas.height);
return imagedata.data[0] == 255
&& imagedata.data[1] == 255
&& imagedata.data[2] == 255
&& imagedata.data[3] == 255;
}
document.getElementById('tor-browser-test').innerHTML = isTorBrowser() ? 'Is Tor' : 'Not Tor';
<div id="tor-browser-test"></div>