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

湖南平台网站建设哪里好网站开发图

湖南平台网站建设哪里好,网站开发图,wordpress侧边文本轮播图片,2021年最新企业所得税政策文章目录 openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.c概述笔记END openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.c 概述 ED25519 签名/验签算法, 现在是最好的. 产生ED25519私钥/公钥 用私钥对明文签名, 得到签名数据 用公钥对明文… 文章目录 openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.c概述笔记END openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.c 概述 ED25519 签名/验签算法, 现在是最好的. 产生ED25519私钥/公钥 用私钥对明文签名, 得到签名数据 用公钥对明文和签名数据进行验签 笔记 /*! \file EVP_ED_Signature_demo.c \note openssl3.2 - 官方demo学习 - signature - EVP_ED_Signature_demo.cED25519 签名/验签算法, 现在是最好的. 产生ED25519私钥/公钥 用私钥对明文签名, 得到签名数据 用公钥对明文和签名数据进行验签 *//*-* Copyright 2023 The OpenSSL Project Authors. All Rights Reserved.** Licensed under the Apache License 2.0 (the License). You may not use* this file except in compliance with the License. You can obtain a copy* in the file LICENSE in the source distribution or at* https://www.openssl.org/source/license.html*//** This demonstration will calculate and verify an ED25519 signature of* a message using EVP_DigestSign() and EVP_DigestVerify().*/#include string.h #include stdio.h #include openssl/err.h #include openssl/evp.h #include openssl/core_names.h#include my_openSSL_lib.h/* A test message to be signed (TBS) */ static const unsigned char hamlet[] To be, or not to be, that is the question,\nWhether tis nobler in the minde to suffer\nThe slings and arrowes of outragious fortune,\nOr to take Armes again in a sea of troubles,\n;static int demo_sign(EVP_PKEY *priv,const unsigned char *tbs, size_t tbs_len,OSSL_LIB_CTX *libctx,unsigned char **sig_out_value,size_t *sig_out_len) {int ret 0;size_t sig_len;unsigned char *sig_value NULL;EVP_MD_CTX *sign_context NULL;/* Create a signature context */sign_context EVP_MD_CTX_new();if (sign_context NULL) {fprintf(stderr, EVP_MD_CTX_new failed.\n);goto cleanup;}/** Initialize the sign context using an ED25519 private key* Notice that the digest name must NOT be used.* In this demo we dont specify any additional parameters via* OSSL_PARAM, which means it will use default values.* For more information, refer to doc/man7/EVP_SIGNATURE-ED25519.pod* ED25519 and ED448 Signature Parameters*/if (!EVP_DigestSignInit_ex(sign_context, NULL, NULL, libctx, NULL, priv, NULL)) {fprintf(stderr, EVP_DigestSignInit_ex failed.\n);goto cleanup;}/* Calculate the required size for the signature by passing a NULL buffer. */if (!EVP_DigestSign(sign_context, NULL, sig_len, tbs, tbs_len)) {fprintf(stderr, EVP_DigestSign using NULL buffer failed.\n);goto cleanup;}sig_value OPENSSL_malloc(sig_len);if (sig_value NULL) {fprintf(stderr, OPENSSL_malloc failed.\n);goto cleanup;}fprintf(stdout, Generating signature:\n);if (!EVP_DigestSign(sign_context, sig_value, sig_len, tbs, tbs_len)) {fprintf(stderr, EVP_DigestSign failed.\n);goto cleanup;}*sig_out_len sig_len;*sig_out_value sig_value;BIO_dump_indent_fp(stdout, sig_value, (int)sig_len, 2);fprintf(stdout, \n);ret 1;cleanup:if (!ret)OPENSSL_free(sig_value);EVP_MD_CTX_free(sign_context);return ret; }static int demo_verify(EVP_PKEY *pub,const unsigned char *tbs, size_t tbs_len,const unsigned char *sig_value, size_t sig_len,OSSL_LIB_CTX *libctx) {int ret 0;EVP_MD_CTX *verify_context NULL;/** Make a verify signature context to hold temporary state* during signature verification*/verify_context EVP_MD_CTX_new();if (verify_context NULL) {fprintf(stderr, EVP_MD_CTX_new failed.\n);goto cleanup;}/* Initialize the verify context with a ED25519 public key */if (!EVP_DigestVerifyInit_ex(verify_context, NULL, NULL,libctx, NULL, pub, NULL)) {fprintf(stderr, EVP_DigestVerifyInit_ex failed.\n);goto cleanup;}/** ED25519 only supports the one shot interface using EVP_DigestVerify()* The streaming EVP_DigestVerifyUpdate() API is not supported.*/if (!EVP_DigestVerify(verify_context, sig_value, sig_len,tbs, tbs_len)) {fprintf(stderr, EVP_DigestVerify() failed.\n);goto cleanup;}fprintf(stdout, Signature verified.\n);ret 1;cleanup:EVP_MD_CTX_free(verify_context);return ret; }static int create_key(OSSL_LIB_CTX *libctx,EVP_PKEY **privout, EVP_PKEY **pubout) {int ret 0;EVP_PKEY *priv NULL, *pub NULL;unsigned char pubdata[32];size_t pubdata_len 0;/** In this demo we just create a keypair, and extract the* public key. We could also use EVP_PKEY_new_raw_private_key_ex()* to create a key from raw data.*/priv EVP_PKEY_Q_keygen(libctx, NULL, ED25519);if (priv NULL) {fprintf(stderr, EVP_PKEY_Q_keygen() failed\n);goto end;}if (!EVP_PKEY_get_octet_string_param(priv,OSSL_PKEY_PARAM_PUB_KEY,pubdata,sizeof(pubdata),pubdata_len)) {fprintf(stderr, EVP_PKEY_get_octet_string_param() failed\n);goto end;}pub EVP_PKEY_new_raw_public_key_ex(libctx, ED25519, NULL, pubdata, pubdata_len);if (pub NULL) {fprintf(stderr, EVP_PKEY_new_raw_public_key_ex() failed\n);goto end;}ret 1; end:if (ret) {*pubout pub;*privout priv;} else {EVP_PKEY_free(priv);}return ret; }int main(void) {OSSL_LIB_CTX *libctx NULL;size_t sig_len 0;unsigned char *sig_value NULL;int ret EXIT_FAILURE;EVP_PKEY *priv NULL, *pub NULL;libctx OSSL_LIB_CTX_new();if (libctx NULL) {fprintf(stderr, OSSL_LIB_CTX_new() returned NULL\n);goto cleanup;}if (!create_key(libctx, priv, pub)) {fprintf(stderr, Failed to create key.\n);goto cleanup;}if (!demo_sign(priv, hamlet, sizeof(hamlet), libctx,sig_value, sig_len)) {fprintf(stderr, demo_sign failed.\n);goto cleanup;}if (!demo_verify(pub, hamlet, sizeof(hamlet),sig_value, sig_len, libctx)) {fprintf(stderr, demo_verify failed.\n);goto cleanup;}ret EXIT_SUCCESS;cleanup:if (ret ! EXIT_SUCCESS)ERR_print_errors_fp(stderr);EVP_PKEY_free(pub);EVP_PKEY_free(priv);OSSL_LIB_CTX_free(libctx);OPENSSL_free(sig_value);return ret; } END
http://www.hkea.cn/news/14306024/

相关文章:

  • 未备案网站 赚钱免费一级域名注册教程
  • 枞阳县建设局网站提高自己网站
  • 百度网站收录提交入口郑州电商运营公司排行
  • 四川省城乡建设网站宁波模板做网站
  • 道农网站建设建材网站建设案例
  • 网站开发的分工网站域名备案要多少钱
  • 东莞建网站公司案例怎么做互联网营销推广
  • 7网站建设1做网站应该会什么
  • 如皋网站建设公司商城网站系统
  • 青岛市城阳区建设局网站网站流量钱是谁给的
  • 腾讯网站建设推广wordpress设置不显示摘要
  • 外贸 网站推广电信公司网络维护
  • 周口学做网站织梦网站安装
  • 定制网络监控方案天津seo诊断技术
  • 网站右侧二维码代码大气企业响应式网站
  • 太原网站制作哪儿好薇营销型网站结构
  • 泰安企业做网站表白网站制作生成器
  • 灰色行业做网站推广wordpress模块插件
  • 家用电脑做网站教程关键词优化seo费用
  • 简单个人网站制作流程access 网站源码
  • 策划类网站怎么网站推广
  • 个人域名免费网站百度域名收录提交入口
  • 青岛开办公司要做网站吗太原网站设计费用
  • 企业宣传网站源码厦门网站建设外包
  • 企业网站建设价格物流公司招聘信息
  • 网站开发行业信息网做个小程序的费用大概多少
  • 深圳市网站哪家做的好做网站图片的大小
  • seo网站优化系统西丽做网站
  • 怎样拿电脑做网站官网建设目的
  • 手机网站图片做多大常州网站建设系统