检查不同组中特定用户的访问权限

Checking specific users' access rights in different groups

在 Garry 的 Mod 中,我试图做到只有某些用户组才能使用上下文菜单。但它只适用于 vip 或 superadmin 用户组。不适合两者。谁能告诉我可能出了什么问题?

hook.Add("ContextMenuOpen", "SuperAdminContext", function()

if not LocalPlayer():IsSuperAdmin() or LocalPlayer():IsUserGroup("vip") then return false end end)

你的条件是组合错误。如果用户 不是 超级管理员,代码将隐藏菜单 — 到目前为止一切正常 — or 如果用户 一个贵宾——这在两个方面都是完全错误的。相反,两种方法之一:要么确保 1) 对于所有可能的组显示,用户在其中 not(使用 and 以确保所有条件适用),或 2) none 可能显示的组适用(使用 or 和括号进行分组)。每个示例:

  1. if not LocalPlayer():IsSuperAdmin() and not LocalPlayer():IsUserGroup("vip") then
    
  2. if not (LocalPlayer():IsSuperAdmin() or LocalPlayer():IsUserGroup("vip")) then
    

布尔逻辑的否定是出了名的棘手,但它几乎总是归结为仔细考虑细节的问题。

真相table可以提供帮助。这是我们想要的复合条件的真相 table:

IsSuperAdmin()  IsUserGroup("vip")  Result (hide menu)
False           False               True
True            False               False
False           True                False
True            True                False

这看起来与 or 的标准真理 table 完全一样,只是最后一列恰好颠倒了。这是一个很好的迹象,表明方法 2 是一个很好的匹配。