当前位置: 首页 > news >正文

第三十五章 结合加密和签名

文章目录

  • 第三十五章 结合加密和签名
  • 使用非对称密钥签名并加密
  • 使用非对称密钥加密并签名

第三十五章 结合加密和签名

可以在同一条消息中加密和签名。在大多数情况下,只需组合前面主题中给出的方法即可。本主题讨论了多种场景。

使用非对称密钥签名并加密

要签名然后加密(使用非对称密钥时),请执行以下操作:

  1. 按照添加数字签名中的步骤进行操作。
  2. 按照加密安全标头元素中的步骤进行操作。

或者按照加密 SOAP 主体中的步骤进行操作。

使用非对称密钥加密并签名

要仅加密 SOAP 主体,然后添加数字签名(使用非对称密钥时),请执行以下操作:

  1. 按照加密 SOAP 主体中的步骤进行操作。
  2. 按照添加数字签名中的步骤进行操作。

要加密任何安全标头元素,然后添加数字签名(使用非对称密钥时),必须使用顶级 <ReferenceList> 元素(在文档的其他地方不需要)。在这种情况下,请执行以下操作:

  1. 按照加密安全标头元素中的步骤 1 — 4 进行操作。
  2. 对于要加密的每个安全标头元素,根据该元素创建一个 <EncryptedData> 元素。为此,请调用 %XML.Security.EncryptedDataCreate() 类方法。在此过程中,指定所有三个参数:

a. 在前面的步骤中创建的加密密钥实例。

b. 要加密的安全标头元素。

c. $$$SOAPWSReferenceEncryptedKey,指定 <EncryptedData> 如何使用加密密钥实例。

 set refopt=$$$SOAPWSReferenceEncryptedKeyset encdata=##class(%XML.Security.EncryptedData).Create(enckey,userToken,refopt)
  1. 创建 <ReferenceList> 元素。为此调用 %XML.Security.ReferenceList%New() 方法。例如:
  2. 在此 <ReferenceList> 中,创建一个指向 <EncryptedData> 元素的Reference>。为此,请对每个 <EncryptedData> 执行以下操作:

a. 调用 %XML.Security.DataReferenceCreate() 类方法,并指定加密数据实例作为参数。此方法返回 %XML.Security.DataReference的实例。

b. 调用引用列表实例的 AddReference() 方法并指定数据引用实例作为参数。

 set dataref=##class(%XML.Security.DataReference).Create(encdata)do reflist.AddReference(dataref)
  1. <ReferenceList> 元素添加到 WS-Security 标头元素。为此,请调用 Web 客户端或 Web 服务的 SecurityOut 属性的 AddSecurityElement() 方法。对于要添加的元素,请指定您的引用列表实例。例如:
 do ..SecurityOut.AddSecurityElement(reflist)

注意:在添加其他项目之前,必须先添加 <ReferenceList> 元素。

  1. <EncryptedKey> 元素添加到 WS-Security 标头元素。使用 AddSecurityElement()。例如:
 do ..SecurityOut.AddSecurityElement(enckey)
  1. 将加密的安全标头元素添加到 WS-Security 标头元素。为此,请调用 Web 客户端或 Web 服务的 SecurityOut 属性的 AddSecurityElement() 方法。在本例中,指定两个参数:

a. 要包含的安全标头元素(而不是基于该元素的 %XML.Security.EncryptedData的实例)。

b. 加密密钥实例。第二个参数指定第一个参数指定的项的放置位置。如果参数为 AB,则 IRIS 确保 AB 之后。指定此项以便收件人首先处理加密密钥,然后再处理依赖于它的加密安全标头元素。

 do ..SecurityOut.AddSecurityElement(userToken,enckey)

或者,如果加密的安全标头元素是<Signature>,,则使用 AddSecurityElement()

  1. 按照步骤添加数字签名。
  2. 发送 SOAP 消息。请参阅添加安全标头元素中的一般注释。
http://www.lryc.cn/news/449766.html

相关文章:

  • FastAPI 第八课 -- 路径操作依赖项
  • 大厂面试真题-说一下Mybatis的缓存
  • jQuery UI 工作原理
  • CS 工作笔记:SmartEdit 里创建的是 CMS Component
  • Java面试经验总结之SSM框架+springboot
  • Unity 热更新(HybridCLR+Addressable)-设置打包路径和加载路径、打开Hosting服务、打包
  • 享元(轻量级)模式
  • 基于php的幸运舞蹈课程工作室管理系统
  • NLP任务的详细原理与步骤的详细讲解
  • Kotlin 处理字符串和正则表达式(二十一)
  • 一站式大语言模型API调用:快速上手教程
  • 【TabBar嵌套Navigation案例-新特性页面-代码位置 Objective-C语言】
  • 程序员如何提升并保持核心竞争力?——深入钻研、广泛学习与软技能的培养
  • Linux之Docker虚拟化部署
  • 重构部队信息安全:部队涉密载体建设新策略
  • 使用Node.js的readline模块逐行读取并解析大文件
  • 浅谈软件安全开发的重要性及安全开发实践
  • 在 NodeJs 里面如何获取 APK 的名称和 icon
  • 基于VirtualBox和Ubuntu的虚拟环境搭建
  • 【PHP源码】匿名来信系统H5版本V1.0免费开源
  • Prompt技巧总结和示例分享
  • 大厂校招:海能达嵌入式面试题及参考答案
  • wrk(1) command
  • 【小程序 - 大智慧】Expareser 组件渲染框架
  • vue + echarts 快速入门
  • 服务器几核几G几M是什么意思?如何选择?
  • K8S服务发布
  • Allen Institute for Artificial Intelligence (Ai2) 发布开源多模态语言模型 Molmo
  • Html CSS 布局,位置处理 居中 对齐
  • Spring MVC系统学习(二)——Spring MVC的核心类和注解