首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对于具有固定哈希长度的字符串,Java中是否存在现成的双向哈希函数?

对于具有固定哈希长度的字符串,Java中是否存在现成的双向哈希函数?
EN

Stack Overflow用户
提问于 2018-06-01 09:05:36
回答 2查看 368关注 0票数 4

我需要对字符串使用散列和对散列(双向)函数。散列应该是固定长度(5-6个符号)。

示例:

代码语言:javascript
复制
String hashed = MagicHashLib.hash("long string"); //hash is hd45dk as an example
String enhashedLongString = MagicHashLib.enhash(hash);

是否已经在Java中实现了算法?还是我应该自己写?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-06-01 09:13:44

我不认为这种散列存在,不管编程语言是什么。

以下是哈希函数维基百科页面的引文

代码语言:javascript
复制
A hash function is any function that can be used to map data of arbitrary size to data of fixed size.

这意味着您有一组固定的值,例如,6个字符长散列可以存储16^6不同的值。但是,您可以创建任何字符串的哈希值。因此,哈希函数将潜在无限不同的值映射到一组固定的值。因此会有碰撞。因此,您不能仅仅通过哈希值来判断,而哈希值是正确的原始值。

一个来自假想散列函数的简单示例:John映射到abcJane映射到ghiDoe还映射到abc。那么,当您将abc视为散列值时,这是从何而来的呢?是John吗?是Doe吗?

票数 1
EN

Stack Overflow用户

发布于 2018-06-01 09:10:08

您要寻找的是所谓的加密和解密

散列是,总是单向的.您无法从其散列值中恢复原始字符串。

浅谈散列和加密见这个答案的区别

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50639826

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档