gpt4 book ai didi

cmd - OpenSSL HMCA SHA1 未给出预期结果

转载 作者:行者123 更新时间:2023-12-05 04:55:07 24 4
gpt4 key购买 nike

我正在尝试使用 OpenSSL 在 CMD 中生成校验和,根据最佳答案 here .

但是,使用提供的示例我得到了意想不到的结果:

C:\>echo -n "value" | openssl dgst -sha1 -hmac "key"
(stdin)= 8c5b4c3a9cee7bc9020a43f1c396f9e13c2bae4a

原始问题中显示的预期结果是:

57443a4c052350a44638835d64fd66822f813319

奇怪的是,我在 PowerShell 中得到了第三个结果:

PS C:\> echo -n "value" | openssl sha1 -hmac "key"
(stdin)= 56d96e5393d98eb5e189ab189e02b1832af727b5

可能不言而喻,我在这里有点超出了我的舒适区,所以请原谅我在解释中的任何明显错误或不足。

最佳答案

将 SO 上的几个问题的答案拼凑在一起,可以学到一些技巧,可以在所有三种情况下获得相同的结果:

在 *nix-like 环境中(包括 macOS),printf 是一种更便携的无换行打印方式:

$ printf value | openssl dgst -sha1 -hmac key
57443a4c052350a44638835d64fd66822f813319

避免CMD换行的技巧(注意第二个|前没有空格,这个必不可少):

>echo | set /p=value| openssl dgst -sha1 -hmac key
(stdin)= 57443a4c052350a44638835d64fd66822f813319

根据 PowerShell GitHub 项目中的这个问题:Piping Text To An External Program Appends A Trailing Newline,目前使用 PowerShell 这似乎“本地”是不可能的.如果您真的必须在 PowerShell 提示符下执行此操作,黑客可能会调用 CMD,如下所示:

> cmd /c "echo | set /p=value| openssl dgst -sha1 -hmac key"
(stdin)= 57443a4c052350a44638835d64fd66822f813319

关于cmd - OpenSSL HMCA SHA1 未给出预期结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65575738/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com