SAS MD5散列

ofz*_*fzy 3 hash md5 sas

我想使用MD5对SAS数据集中的敏感信息(1个字段)进行哈希处理。但是在散列后,数据看起来很尴尬,即所有特殊字符。这是使用哈希函数的正确方法吗?

我的代码:

data md5; 
set sashelp.class (obs=2); 
md5 = md5(strip(name)); 
keep name md5; 
put _all_;
run; 
Run Code Online (Sandbox Code Playgroud)

我的输出:

Name=Alfred Sex=M Age=14 Height=69 Weight=112.5 md5=?p????\?rT]( _ERROR_=0 _N_=1
 Name=Alice Sex=F Age=13 Height=56.5 Weight=84 md5=dH???/?x{??!K8 _ERROR_=0 _N_=2
Run Code Online (Sandbox Code Playgroud)

mom*_*644 5

没错,您只需要应用十六进制格式即可$hex32.读取。MD5是128位哈希,但是有一个更好的哈希称为SHA256(),它是256位哈希。

码:

data md5; 
set sashelp.class (obs=2); 
format md5 $hex32.; 
md5 = md5(strip(name)); 
keep name md5; 
put _all_;
run;
Run Code Online (Sandbox Code Playgroud)

输出:

 Name=Alfred md5=86703FDE9E87DD5C0F8E1072545D0128 
 Name=Alice  md5=64489C85DC2FE0787B85CD87214B3810
Run Code Online (Sandbox Code Playgroud)

注意:

您还可以在字符串中添加SALT或PEPPER值,以提高安全性;这些字符串连接到字符串的开头或结尾。