Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
dotNET Platform
runtime
提交
2ce9dd5d
R
runtime
项目概览
dotNET Platform
/
runtime
12 个月 前同步成功
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
runtime
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
2ce9dd5d
编写于
7月 15, 2022
作者:
K
Kevin Jones
提交者:
GitHub
7月 15, 2022
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use a stackalloc for short SHA1 hashes
上级
68e13b68
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
5 addition
and
3 deletion
+5
-3
src/libraries/System.Security.Cryptography/src/System/Security/Cryptography/X509Certificates/X509SubjectKeyIdentifierExtension.cs
...phy/X509Certificates/X509SubjectKeyIdentifierExtension.cs
+5
-3
未找到文件。
src/libraries/System.Security.Cryptography/src/System/Security/Cryptography/X509Certificates/X509SubjectKeyIdentifierExtension.cs
浏览文件 @
2ce9dd5d
// Licensed to the .NET Foundation under one or more agreements.
// The .NET Foundation licenses this file to you under the MIT license.
using
System.Diagnostics
;
using
Internal.Cryptography
;
namespace
System.Security.Cryptography.X509Certificates
...
...
@@ -99,14 +100,15 @@ private static byte[] GenerateSubjectKeyIdentifierFromPublicKey(PublicKey key, X
case
X509SubjectKeyIdentifierHashAlgorithm
.
ShortSha1
:
{
byte
[]
sha1
=
SHA1
.
HashData
(
key
.
EncodedKeyValue
.
RawData
);
Span
<
byte
>
sha1
=
stackalloc
byte
[
SHA1
.
HashSizeInBytes
];
int
written
=
SHA1
.
HashData
(
key
.
EncodedKeyValue
.
RawData
,
sha1
);
Debug
.
Assert
(
written
==
SHA1
.
HashSizeInBytes
);
// ShortSha1: The keyIdentifier is composed of a four bit type field with
// the value 0100 followed by the least significant 60 bits of the
// SHA-1 hash of the value of the BIT STRING subjectPublicKey
// (excluding the tag, length, and number of unused bit string bits)
byte
[]
shortSha1
=
new
byte
[
8
];
Buffer
.
BlockCopy
(
sha1
,
sha1
.
Length
-
8
,
shortSha1
,
0
,
shortSha1
.
Length
);
byte
[]
shortSha1
=
sha1
.
Slice
(
SHA1
.
HashSizeInBytes
-
8
).
ToArray
();
shortSha1
[
0
]
&=
0x0f
;
shortSha1
[
0
]
|=
0x40
;
return
shortSha1
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录