- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
为了简单和(假定的)速度,我一直倾向于使用长整数作为数据库中的主键。但是当使用 REST或对象实例的类似 Rails 的 URL 方案,然后我会得到这样的 URL:
http://example.com/user/783
然后假设还有 ID 为 782、781、...、2 和 1 的用户。假设有问题的 Web 应用程序足够安全,可以防止人们输入其他号码以查看其他用户而无需授权,一个简单的顺序分配的代理键也会“泄漏”实例的总数(比这个旧的),在这种情况下是用户,这可能是特权信息。 (例如,我是 stackoverflow 中的用户 #726。)
会 UUID/GUID 是更好的解决方案吗?然后我可以像这样设置 URL:
http://example.com/user/035a46e0-6550-11dd-ad8b-0800200c9a66
不完全简洁,但显示的用户隐含信息较少。当然,它有点“通过模糊实现安全”的味道,这不能替代适当的安全性,但它似乎至少更安全一些。
为 Web 可寻址对象实例实现 UUID 的成本和复杂性是否值得这种好处?我认为我仍然希望使用整数列作为数据库 PK 只是为了加快连接速度。
还有 UUID 在数据库中表示的问题。我知道 MySQL 将它们存储为 36 个字符的字符串。 Postgres 似乎有一个更有效的内部表示(128 位?),但我自己还没有尝试过。任何人都有这方面的经验吗?
更新:对于那些询问只在 URL 中使用用户名(例如 http://example.com/user/yukondude )的人来说,这对于具有唯一名称的对象实例来说效果很好,但是对于真正可以真正只能通过数字识别?订单、交易、发票、重复的图像名称、stackoverflow 问题……
最佳答案
关于您的问题的网络方面,我不能说。但是 uuid 非常适合 n 层应用程序。 PK 生成可以是分散的:每个客户端生成它自己的 pk 而没有冲突的风险。而且速度差异一般很小。
确保您的数据库支持有效的存储数据类型(16 字节,128 位)。至少你可以在 base64 中编码 uuid 字符串并使用 char(22)。
我已经在 Firebird 中广泛使用它们并推荐。
关于database - 您对使用 UUID 作为数据库行标识符有何看法,尤其是在 Web 应用程序中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5949/
C++ Primer 说: The identifier we define in our programs may not contain 2 consecutive underscores, no
标识符术语在文档 alongside constants 中定义。 , 使用几乎相同的用例,尽管术语在运行时计算它们的值,而常量在编译时得到它。潜在地,这可能会使术语使用全局变量,但这是一个遥远而丑陋
我想知道,.Net 标识符中接受哪些字符? 不是 C# 或 VB.Net,而是 CLR。 我问这个的原因是我正在查看 yield return 语句是如何实现的 (C# In Depth),并看到
在PowerShell中,当我专门使用Active Directory时,通常会编译一个包含一组人群列表的对象,通常使用$x = get-adgroup -filter {name -like "*"
使用 hibernate 时: 我必须为每个实体指定一个 ID 或复合 ID,如果我想使用没有任何主键且没有复合键的表怎么办... 提前致谢 最佳答案 没有键的表不是一个好的关系模型。我不会推荐它。
所以我有一些代码正在尝试编译,但我不断收到此错误: 3SATSolver.java:3: expected 这是代码。我只是没有看到什么吗? import java.util.ArrayList;
我正在寻找有关 C 标准(C99 和/或 C11)部分内容的一些说明,主要是关于标识符的使用。 上下文是一个完整的C99标准库的实现,我希望它完全符合标准。 基本问题是:C 标准允许我在多大程度上声明
我有这个 Shader.h 文件,我正在用这段代码制作它: #include #include #include #include in vec2 TexCoords; out vec4 co
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
这是我的代码: #include "stdafx.h" #include #include #include #include using namespace std; int _tmain(
pthread_create() 的第一个参数是一个thread 对象,用于标识新创建的线程。但是,我不确定我是否完全理解其中的含义。 例如,我正在编写一个简单的聊天服务器并且我计划使用线程。线程会随
我想从我的标识符中获得匹配项。 我在 {/describe:foo} 中有一个这样的字符串,我正在尝试匹配 {/describe:} 以返回 foo,但我没有得到正确的正则表达式,会有人介意指出我做错
我遇到了一个奇怪的问题,我似乎找不到答案,但我想我不妨问问。 我有一个执行碰撞检查的抽象类,它有一个“更新”函数,以及“updateX”和“updateY”函数。 class MapCollidabl
我正在尝试创建一个程序来将所有文件从一个目录复制到另一个目录。但我遇到了一个基本问题。它说当我尝试在第 52 行编译时需要标识符。 public bool RecursiveCopy() {
1>cb.c(51): error C2061: syntax error : identifier 'SaveConfiguration' 1>cb.c(51): error C2059: synt
我刚刚发现命名变量 arguments 是个坏主意。 var arguments = 5; (function () { console.log(arguments); })(); Outpu
我们对我们的网站进行了安全测试,并发现了一个漏洞。 问题 If the session identifier were known by an attacker who had access to t
为了估计程序在一次内核启动中可以处理多少数据,我尝试使用 cudaMemGetInfo() 获取一些内存信息。但是,编译器告诉我: 错误:标识符“cudaMemGetInfo”未定义 cudaGetD
我发现我需要使用 xpath 查询来定位几乎是 regexp 类型的字符串,但无法看到如何管理它。我正在使用的当前查询是: $result = $xpath->query('//ul/li[sta
我正在创建我的学生计划表的虚拟版本,它基本上可以让你记下你有哪些科目的作业。 这是界面: 用户从组合框中选择主题,并在相邻的备忘录中输入一些注释。完成后,他们将单击“保存”按钮,将其保存到 .ini
我是一名优秀的程序员,十分优秀!