在ruby中哈希网址的最佳方法是什么?

前端之家收集整理的这篇文章主要介绍了在ruby中哈希网址的最佳方法是什么?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在编写一个指向外部链接的网络应用程序.我正在为每个可以在URL中使用的文档创建一个非连续的,不可猜测的ID.我做了一件明显的事情:将URL作为字符串处理,并将str#crypt放在其上,但这似乎阻止了任何非字母数字字符,如斜杠,点和下划线.

有什么建议,最好的方法解决这个问题?

谢谢!

解决方法

根据你想要的字符串的长度可以使用几种方法
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"

现在,对于不知道原始内容并且无法访问您的源的人来说,生成这个哈希变得更加困难.

猜你在找的Ruby相关文章