Kaj*_*nus 4 browser firefox tor
如果浏览器是Tor浏览器,我想禁用我正在构建的Web应用程序的某些功能.我可以在浏览器内部(客户端,而不是服务器端)查看浏览器是否是Tor浏览器?
我更喜欢没有发出任何HTTP请求的解决方案,以使浏览器的IP与Tor出口节点相匹配.
背景:在我的例子中,Tor Browser会弹出一个对话框,询问用户"Tor Tor Browser是否允许此网站提取HTML5画布图像数据?" 因为,Tor Browser说,画布图像数据可用于唯一标识浏览器.
更新:阅读下面的答案后:在我的情况下,也许最好的解决方案是保留服务器端的Tor出口节点列表(最新列表,定期刷新),当浏览器加载页面时,我设置<script>标签中的变量,如果浏览器的IP与这样的出口节点匹配:var isProbablyTorBrowser = true.然后,客户端,不需要额外的请求或复杂的逻辑.
Tor浏览器的设计不是不可检测的(这是不可能的).相反,它的设计使得所有副本都无法区分:您无法通过浏览器指纹识别从一个站点到另一个站点或从一个站点访问浏览器.
这使它具有独特的指纹.截至目前,一个浏览器
Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/31.0navigator.plugins是空的)可能是TBB浏览器.当下一个ESR版本的Firefox发布时,用户代理字符串可能会发生变化,最有可能发生Mozilla/5.0 (Windows NT 6.1; rv:31.0) Gecko/20100101 Firefox/38.0.
单独的屏幕分辨率/浏览器窗口匹配可以唯一地识别TBB:即使在全屏模式下,Firefox中的窗口高度和屏幕高度之间也存在一个像素差异.
检测tor的"官方"方法是检查用户的IP地址,看看它是否是出口节点.Tor 为此目的运行TorDNSEL.
下面是一个教程着TorDNSEL查找的PHP实现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];
}
Run Code Online (Sandbox Code Playgroud)
如果你不使用PHP,你仍然可以相对容易地适应这一点.
另一种检测Tor的方法是让脚本每半小时左右下载一次Tor出口节点列表,然后根据该列表检查每个用户的IP地址.但是,这可能不太可靠,因为并非所有出口节点都已发布.你可以使用一个列表和说明,可以在dan.me.uk上找到.
编辑:由于您更新了您的问题,第二个选项(您在本地托管的列表)将更可取.
也许有一个相当可靠的方法。检查当您尝试使用画布对其进行 Base64 处理时,它是否返回空白(白色)图像。 当您这样做时,会显示一条通知。
无论用户选择什么,JS 都会返回白色图像。因此,您可以尝试对非白色图像进行 Base64(<-- 这是一个动词;)),然后检查是否返回白色 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';Run Code Online (Sandbox Code Playgroud)
<div id="tor-browser-test"></div>Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
5563 次 |
| 最近记录: |