如果浏览器是Tor浏览器,我想要禁用我正在构建的网络应用的某些功能。我可以在浏览器内部(客户端,而不是服务器端)查明浏览器是否是Tor浏览器?
我更希望找到一个解决方案,它不会发出任何HTTP请求,以使浏览器的IP与Tor出口节点相匹配。
背景:就我而言,Tor浏览器会弹出一个对话框,询问用户" Tor浏览器是否允许此网站提取HTML5画布图像数据?" ,因为, Tor Browser说,画布图像数据可用于唯一标识浏览器。
更新:阅读下面的答案后:在我的情况下,也许最好的解决方案是保留服务器端的Tor出口节点列表(最新列表,定期刷新),当浏览器加载页面时,如果浏览器的IP与这样的退出节点<script>
匹配,我在var isProbablyTorBrowser = true
标记中设置变量。然后,客户端,不需要额外的请求或复杂的逻辑。
答案 0 :(得分:8)
Tor浏览器的设计不是不可检测的(这是不可能的)。相反,它的设计使得所有副本彼此无法区分:您无法通过browser fingerprinting跟踪浏览器从一个站点到另一个站点,或从一个访问到另一个站点。
这给它一个独特的指纹。截至目前,一个浏览器
Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/31.0
navigator.plugins
为空)可能是TBB浏览器。当下一个ESR版本的Firefox发布时,User-Agent字符串可能会发生变化,最有可能是Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/38.0
。
单独的屏幕分辨率/浏览器窗口匹配可以唯一地识别TBB:即使在全屏模式下,Firefox中的窗口高度和屏幕高度之间也存在一个像素差异。
答案 1 :(得分:6)
&#34;官方&#34;检测tor的方法是检查用户的IP地址,看看它是否是一个出口节点。 Tor为此目的运行TorDNSEL。
以下是Irongeek教程中TorDNSEL查找的PHP实现
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。
编辑:由于您更新了问题,因此第二个选项(您在本地托管的列表)将更受欢迎。
答案 2 :(得分:2)
没有可靠的方法来检测TOR浏览器......这是该浏览器的目标。如果你找到一种可靠的方法,那么其他人也很有可能找到它,告诉TOR开发人员他们关闭它。
E.g。所有TOR Browser捆绑包都报告虚假,但合理的用户代理。当前的发行版本,例如无论你实际使用什么操作系统,它都是Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/31.0
。
您可以应用一些启发式方法以一定的概率检测TOR浏览器,但也会产生一些误报......
navigator.plugins
将为空(但某些用户可能会再次重新启用插件)。当然,您必须更新您的支票,因此需要相当多的维护工作。
就个人而言,鉴于用户的检测结果,维护负担和非常适度的体验改进不是很好,我不会尝试以不同的方式处理TOR浏览器。
答案 3 :(得分:1)
可能有一种非常可靠的方式。当您尝试使用画布使用Base64时,检查它是否返回空白(白色)图像。 When you do so an notification is shown.
无论用户选择什么,JS都会返回白色图像。因此,您可以尝试base64(&lt; - 它是动词;))非白色图像,然后检查是否返回了白色base64图像。
UPD。 这是我为自己做的一个例子。对我来说,重要的是检测我是否可以访问图像,但它可以用于某种方式的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>
答案 4 :(得分:0)
通过firefox资源包,你可以检查它。
Firefox使用resource:// URI方案从内部模块和扩展中调用磁盘资源。
但是其中一些资源也可能包含在任何网页中并通过脚本标记执行。 Mozilla开发人员并未将资源视为指纹矢量,尽管其中一些资源可以揭示用户不希望的内容。例如,内置首选项文件的差异清楚地表明您正在使用Windows或Linux或Mac,即使您不在Tor浏览器之后。