我正在编写一个指向外部链接的web应用程序。我希望为我可以在URL中使用的每个文档创建一个非连续的、不可猜测的id。我做了一件显而易见的事情:把url当作一个字符串和str#crypt,但它似乎会被任何非字母数字字符卡住,比如斜杠、点和下划线。
对解决这个问题的最佳方法有什么建议吗?
谢谢!
发布于 2008-09-15 23:49:00
根据您希望字符串的长度,您可以使用以下几种替代方法:
require 'digest'
Digest.hexencode('http://foo-bar.com/yay/?foo=bar&a=22')
# "687474703a2f2f666f6f2d6261722e636f6d2f7961792f3f666f6f3d62617226613d3232"
require 'digest/md5'
Digest::MD5.hexdigest('http://foo-bar.com/yay/?foo=bar&a=22')
# "43facc5eb5ce09fd41a6b55dba3fe2fe"
require 'digest/sha1'
Digest::SHA1.hexdigest('http://foo-bar.com/yay/?foo=bar&a=22')
# "2aba83b05dc9c2d9db7e5d34e69787d0a5e28fc5"
require 'digest/sha2'
Digest::SHA2.hexdigest('http://foo-bar.com/yay/?foo=bar&a=22')
# "e78f3d17c1c0f8d8c4f6bd91f175287516ecf78a4027d627ebcacfca822574b2"
请注意,这并不是不可猜测的,您可能必须将其与其他一些(秘密的但静态的)数据组合在一起,以对字符串进行加盐:
salt = 'foobar'
Digest::SHA1.hexdigest(salt + 'http://foo-bar.com/yay/?foo=bar&a=22')
# "dbf43aff5e808ae471aa1893c6ec992088219bbb"
现在,对于不知道原始内容并且无法访问您的源的人来说,生成此哈希变得更加困难。
发布于 2008-09-16 02:38:13
我还建议查看摘要名称空间中的不同算法。为了使猜测更加困难,而不是(或除了)使用秘密密码短语进行盐渍,您还可以使用精确的时间转储:
require 'digest/md5'
def hash_url(url)
Digest::MD5.hexdigest("#{Time.now.to_f}--#{url}")
end
因为任何散列算法的结果都不能保证是唯一的,所以在假设你的散列是可用的之前,不要忘记对照以前生成的散列检查结果的唯一性。Time.now的使用使得重试的实现变得很简单,因为您只需调用直到生成唯一的散列。
发布于 2008-09-15 23:21:35
使用Ruby标准库中的Digest::MD5:
Digest::MD5.hexdigest(my_url)
https://stackoverflow.com/questions/67890
复制相似问题