如何散列std :: string?

问题描述 投票:13回答:3

我正在做一个小工具来帮助我通过重复记住密码。我想输入密码,每天只记住一次,而不是每次会话之前。当然,我本身不会存储密码,但很乐意存储它的哈希值。

那么,使用C ++标准库从std::string获取哈希的最简单方法是什么?

c++ string hash cryptography std
3个回答
23
投票

对于不涉及外部库的快速解决方案,您可以使用hash<std::string>来散列strings。它的定义是包含头文件hash_mapunordered_map(或其他一些)。

#include <string>
#include <unordered_map>

hash<string> hasher;

string s = "heyho";

size_t hash = hasher(s);

如果您决定要增加SHA的安全性,那么如果您不需要所有其他功能,则无需下载大型Crypto ++库;互联网上有很多独立的实现,只需搜索“sha implementation c ++”。


12
投票

使用c ++ 11,您可以:

#include <string>
#include <unordered_map>

std::size_t h1 = std::hash<std::string>{}("MyString");
std::size_t h2 = std::hash<double>{}(3.14159);

看到更多here


1
投票

你可以使用STL functor hash。看看你的STL lib是否包含它。

请注意,这个返回一个size_t,所以范围是numeric_limits<size_t>::min() numeric_limits<size_t>::max()。如果这是不可接受的,你将不得不使用SHA或其他东西。

© www.soinside.com 2019 - 2024. All rights reserved.