DER编码基础

完成下面任务(9分)

1. 对 BitString "101101101101"进行 DER编码,提交详细过程和结果。使用 echo 命令生成 bs.der文件,并使用 OpenSSL asn1parse命令解析,提交命令和结果(4 分)

补位:由于BitString的长度不是8的倍数,我们需要在末尾添加比特0,直到长度是8的倍数。"101101101101"长度为12位,所以我们需要添加4个0,使其成为16位:"1011 0110 1101 0000"。

确定未使用的比特数:在最后一个字节中,未使用的比特数为4(因为我们添加了4个0以达到16位)。

构建DER编码:

首先,BitString的标识符为0x03(BIT STRING类型)。

接着,我们需要确定编码的总长度。由于我们有16位,需要2个字节来表示,再加上1个字节来表示未使用的比特数,总共需要3个字节。

因此,长度字段为0x03(3的DER编码)。 然后,我们需要添加一个字节来表示未使用的比特数,这里是0x04(因为使用了4个0)。

最后,我们将BitString的二进制数据转换为字节表示。"10110110 11010000"转换为字节是0xB6和0xd0(因为最后4位是0)。

将这些组合起来,DER编码为:0x03 0x02 0x04 0xB6 0xd0。

即03 02 04 b6 d0

命令生成bs.der文件

bash 复制代码
echo -n -e "\x03\x02\x04\xb6\xd0" > bs.der

使用openssl asn1parse解析

bash 复制代码
openssl asn1parse -in bs.der
bash 复制代码
[wzy@LAPTOP-PRC71A0C test2]$ echo -n -e "\x03\x02\x04\xb6\x00" > bs.der
[wzy@LAPTOP-PRC71A0C test2]$ ls
base  base.c  bs.der  readsnbase64.c  sn.txt
[wzy@LAPTOP-PRC71A0C test2]$ openssl asn1parse -in bs.der
 0:d=0  hl=1 l=   2 prim: BIT STRING

2. 对 基于SM2算法和SHA256算法的签名的OID 1.2.156.197.1.503进行 DER 编码,提交详细过程和结果,并使用 OpenSSL asn1parse命令解析,提交命令和结果。(5分)

OID(Object Identifier)是一种用于标识对象的标准化方法。OID 1.2.156.197.1.503可以分解为以下几个部分:

1.2: ISO 和 identified-organization 156: CN (China) 197: organization (SM2) 1: sub-organization 503: specific algorithm (SM2 with SHA256)

06 表示OID类型 05 表示OID的长度为5字节

OID 1.2.156.197.1.503的DER编码过程如下:

1.第一个字节:0x06(表示OID类型)

2.长度字节:0x05(表示OID值的长度为5字节)

3.OID值:

1.2 编码为 0x2A

156 编码为 0x9F 0x3C

197 编码为 0xC5

1 编码为 0x01

503 编码为 0xF7

最终的DER编码为:06 05 2A 9F 3C C5 01 F7

2A 9F 3C C5 01 F7 是OID 1.2.156.197.1.503的DER编码值

bash 复制代码
[wzy@LAPTOP-PRC71A0C test2]$ echo -n "06052A9F3CC501F7" | xxd -r -p | openssl asn1parse -inform DER 
    0:d=0  hl=2 l=   5 cons: SEQUENCE           
    2:d=1  hl=2 l=   3 prim: OBJECT            :1.2.156.197.1.503 

提交要求 (1')

  1. 记录实践过程和 AI 问答过程,尽量不要截图,给出文本内容
  2. (选做)推荐所有作业托管到 gitee或 github 上
  3. (必做)提交作业 markdown文档,命名为"学号-姓名-作业题目.md"
  4. (必做)提交作业 markdown文档转成的 PDF 文件,命名为"学号-姓名-作业题目.pdf"
相关推荐
xiezhr31 分钟前
折腾半小时,终于让AI 能直接帮我写飞书文档了
ai·飞书·ai agent·飞书cli·飞书文档
岳小哥AI1 小时前
Claude Fable和Claude Mythos 5同时发布:注意力机制下愈加强大的AI大模型
ai·ai基础
Artech1 小时前
[MAF预定义的AIContextProvider-04]Mem0Provider——长期记忆基于的云端解决方案
ai·agent·maf·aicontextprovider·chathistorymemoryprovider·mem0provider
哥不是小萝莉11 小时前
一文读懂 OpenAI Codex 源码的原理、架构与未来
ai
AlfredZhao18 小时前
AI 编程工作总结:从体验问题到模块能力建设
ai·codex
cup112 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南
python·ai·环境变量·ci·nuitka·skill
IT王师傅2 天前
从 豆包 到 Codex CLI:一名普通开发者的 AI 工具进化路线
ai·codex cli·openclaw
岳小哥AI2 天前
Siri要接入AI了,苹果手机上一句话让GPT写文案、DeepSeek写代码的时刻来了
ai·ai基础
Artech2 天前
[MAF预定义的AIContextProvider-03]ChatHistoryMemoryProvider——赋予Agent从经验中学习的能力
ai·c#·agent·memory·maf
哥布林学者3 天前
深度学习进阶(三十一)FlashAttention:IO 感知的精确注意力
机器学习·ai