- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我希望了解企业搜索解决方案如何解决用户权限问题。
我的问题是为用户显示搜索结果。天真的方法会向用户显示搜索结果,然后如果用户单击他无权查看的文档,他将无法打开它。但是,如果用户没有阅读权限,甚至禁止显示文档的标题或摘录。各种企业搜索引擎也是如此:
选项 #2 对我来说更有意义,但似乎也比选项 #1 慢得多。
选项 #1 需要不断更新索引文档的权限更改。
我希望了解当今市场上现有解决方案的通用方法是什么。还有第三种选择吗?
最佳答案
我很惊讶地看到这个 5 年前的问题没有得到任何答案,因为我认为这是企业搜索中相当普遍和重要的问题。
如问题中所述,有两种处理文档级安全性的常用方法:
从不建议仅在内容方面处理安全性,因为那时 secret 信息可能已经泄露(例如搜索结果中文档的标题或预览)。
使用后期绑定(bind)方法 实现安全性的优势在于,它非常灵活,因为无需根据更改的 ACL 重新索引内容。然而,最大的缺点是,这样做可能会通过面值泄露 secret 信息,并且无法检索和显示正确面数。正确填充结果列表和处理分页也更加困难。最后但同样重要的是,这种方法会显着降低性能。
使用早期绑定(bind)方法 实现安全性的优势在于,它以一旦 ACL 更改就重新索引内容为代价解决了上述所有缺点。但是,泄漏 仍然是可能的,例如当组成员身份或 ACL 刚刚更改并且尚未反射(reflect)在搜索索引中时。为了解决这个差距,通常将早期绑定(bind)和后期绑定(bind)这两种方法结合起来。
最后但同样重要的是,可能还有第三种选择,具体取决于您使用的企业搜索平台:Attivio 的主动安全性 基于查询时连接,它允许索引独立于文档本身的安全信息,但在查询时合并这两个文档以确保只有授权的内容才能进入搜索结果。
关于permissions - 企业搜索如何为用户显示结果并隐藏未经授权的结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3694532/
我从 ssh 收到以下错误: Permissions 0777 for '/Users/username/.ssh/id_rsa' are too open. It is recommended th
我正在使用 WSL1(Windows Linux 子系统)和 Ubuntu 20.04.1 LTS 开发 Win10。我有一个 Samba (1.0) 网络共享,我想通过我的 Ubuntu 终端在上面
文件权限 我有一个文件 data.tgz我想解压缩。 -rw-r--r-- 1 username group 20342951248 mai 18 11:50 data.tgz 目录权限 文件所在的目
我正在尝试设置一些其他组不应该看到的组维护文件夹。目前,我通过取消单击@@sharing 选项卡中的“从更高级别继承权限”复选框来实现这一点,但我想自动执行此操作。 我在文档或谷歌搜索中找不到任何关于
在 Android 4 下,以下简单的 native C 代码行失败并出现 Permission denied 错误 when not run as 根: online_socket = socket
(我是 tortoise SVN 的新手) 我的乌龟 SVN 中有 2 个文件夹。每个人都需要一组不同的授权(我不想有权访问第一个文件夹的人对第二个文件夹具有读/写访问权限。 我怎样才能完成它?我注意
我用 tar -zxvf tarFile.tar.gz解压tarFile,但有错误提示tar: subfile :Cannot open: Permission denied . 我是root用户,权
我是 WAMP 的新手我今天刚刚安装了它。 设置进行得很顺利,本地主机似乎可以工作,但是当我尝试访问 phpMyAdmin 时我收到此错误: Forbidden You don't have perm
我想做的是从文件夹内的文件夹中获取 .mp3 文件。多次。 一切都很完美,除了当我尝试将文件复制到新文件夹(已经存在)时,它给出:[Errno 13]权限被拒绝: import os, shutil
我是 WAMP 的新手我今天刚刚安装了它。 设置进行得很顺利,本地主机似乎可以工作,但是当我尝试访问 phpMyAdmin 时我收到此错误: Forbidden You don't have perm
我正在开发一个应用程序,我在其中使用塔位置跟踪位置。所以我使用地理定位 api 来跟踪位置并访问手机状态以获取网络详细信息。 这很好用,突然间它开始给出 LOCATION_HARDWARE 权限的安全
这两种语法有什么区别。android:uses-permission 和 uses-permission。例如: 当我创建一个从存储中读取的 Activity 时,Android Studio 自
我正在尝试使用新的 GrantPermissionRule这是最新支持库的一部分。 在我的 list 中,我声明如下: 在我的代码中,我调用: @Rule public GrantPermissio
有没有navigator.permissions.query 的替代方案 Permissions API 查询以检查 geolocation 权限。导致它仍处于工作草案中并且浏览器兼容性较差。 W3C
这个错误真的真的很奇怪,我不知道如何重现它以及如何修复它,因为我进行了大量搜索,但没有任何用处。 这是堆栈跟踪: Stack Trace _______________________________
我正在尝试在 ubuntu 16.4 上安装 MaryTTS。 但是当我上线时 sudo -u mary git clone https://github.com/marytts/marytts.gi
在我们基于 Symfony2 的应用程序中,我们希望创建一个列表,列出系统中哪些用户对给定域对象具有权限。我们正在使用 ACL,我们的直接直觉是查看从相关域对象的 ACLProvider 返回的 AC
我今天收到这封邮件,但我没有使用 Admob 广告,而是使用 applovin 和 Facebook,我必须添加此权限还是仅适用于他们使用 Admob 的开发者? 即使没有像我一样的admob,每个人
我有一个 Jenkins 用户,我想授予其对 Jenkins 实例运行远程 CLI 的权限。第一个命令是获取 config.xml: java -jar jenkins-cli.jar -s http
我今天收到这封邮件,但我没有使用 Admob 广告,而是使用 applovin 和 Facebook,我必须添加此权限还是仅适用于他们使用 Admob 的开发者? 即使没有像我一样的admob,每个人
我是一名优秀的程序员,十分优秀!