我正在写一个指向外部链接的网络应用程序.我正在寻找为URL中可以使用的每个文档创建一个非顺序的,不可猜测的id.我做了显而易见的事情:处理的URL作为一个字符串和STR#墓穴,但似乎呛任何非alphanumberic字符,如斜线,点和下划线.
有关解决此问题的最佳方法的任何建议?
谢谢!
根据您希望的字符串长度,您可以使用以下几种方法:
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"
现在,为不了解原始内容且无法访问您的源的人生成此哈希变得更加困难.