加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 20:36:11 所属栏目:百科 来源:网络整理
导读:我正在编写一个指向外部链接的网络应用程序.我正在为每个可以在URL中使用的文档创建一个非连续的,不可猜测的ID.我做了一件明显的事情:将URL作为字符串处理,并将str#crypt放在其上,但这似乎阻止了任何非字母数字字符,如斜杠,点和下划线. 有什么建议,最好的方
我正在编写一个指向外部链接的网络应用程序.我正在为每个可以在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"

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读