首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用pyOpenSSL签名大型文件

用pyOpenSSL签名大型文件
EN

Stack Overflow用户
提问于 2017-07-17 10:33:31
回答 1查看 664关注 0票数 0

我需要使用SSL签名pyopenssl模块为大型*.tar.gz文件(千兆字节数据)创建Python 3

下面是我的代码的简化摘录(这很有效)。有问题的行如下:

如果文件很大,bytes_to_sign = sign_file.read() #问题

同时读取整个文件的可能不是最好的主意,但我不知道如何用其他方式。

以下是代码:

代码语言:javascript
复制
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
import OpenSSL
import argparse
import getpass
import logging

DIGEST_METHOD = 'sha256'
SSL_CERT_FORMAT_TYPE = OpenSSL.crypto.FILETYPE_PEM
LOG_FORMAT = '[%(asctime)s][ %(levelname)s ] %(message)s'


def create_args_parser():
    p = argparse.ArgumentParser(description='Simple SSL signature generator.')
    p.add_argument('file', type=argparse.FileType('rb'),
                   metavar='signed_file_path',
                   help='path to the file that will be signed')
    p.add_argument('--ssl-key', type=argparse.FileType(), 
                   metavar='CERT_PATH', required=True,
                   help='path to SSL certificate private key in PEM format')
    p.add_argument('-o', '--out', type=argparse.FileType('wb'),
                   metavar='SIGNATURE_PATH', required=True,
                   help='path where generated signature will be saved')
    return p


def get_priv_key_obj(ssl_key_file):
    """Get password protecting SSL private key and create private key object."""

    priv_key_str = ssl_key_file.read()
    ssl_key_file.close()  # https://stackoverflow.com/a/18863046/1321680
    priv_key = None

    while not priv_key:
        ssl_passwd = getpass.getpass()
        try:
            priv_key = OpenSSL.crypto.load_privatekey(SSL_CERT_FORMAT_TYPE,
                                                      priv_key_str,
                                                      ssl_passwd.encode('ascii'))
        except OpenSSL.crypto.Error:
            logging.warning('Probably wrong password - try again')

    return priv_key


def sign_file(priv_key, sign_file, out_file):
    """Sign given file with SSL private key and save signature in given file."""

    bytes_to_sign = sign_file.read()  # PROBLEM if file is LARGE
    sign = OpenSSL.crypto.sign(priv_key, bytes_to_sign, DIGEST_METHOD)
    sign_file.close()

    out_file.write(sign)
    out_file.close()


def main():
    parser = create_args_parser()
    args = parser.parse_args()
    priv_key = get_priv_key_obj(args.ssl_key)
    sign_file(priv_key, args.file, args.out)


if __name__ == '__main__':
    try:
        logging.basicConfig(format=LOG_FORMAT)
        main()
    except Exception as e:
        logging.exception('Generating SSL certificate has failed. Check if '
                          'SSL cert password is correct. Details: {}'.format(e))

脚本--help

代码语言:javascript
复制
usage: sign.py [-h] --ssl-key CERT_PATH -o SIGNATURE_PATH signed_file_path

Simple SSL signature generator.

positional arguments:
  signed_file_path      path to the file that will be signed

optional arguments:
  -h, --help            show this help message and exit
  --ssl-key CERT_PATH   path to SSL certificate private key saved in PEM
                        format
  -o SIGNATURE_PATH, --out SIGNATURE_PATH
                        path where generated signature will be saved

有没有办法不立即对整个文件进行read()

  • 若要验证创建的签名运行(或者另一个实现pyOpenSSL),请执行以下操作: openssl -sha256 -verify cert_public_key_file.pub -signature cert_file.crt signed_file_path
  • 如果需要创建SSL证书来测试它,请参见本教程
  • 我知道有相似对此提出的问题,但他们没有回答我的问题。
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-07-17 14:59:34

您必须实现自己的chunked sign函数。

但是接收者呢,它能核实吗?

阅读:DigestSignInit EVP_DigestSignUpdate()将d处的数据的cnt字节放入签名上下文ctx。 可以在同一个ctx上多次调用此函数以包含其他数据。

def标志(pkey,data,摘要):调适

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/45141917

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档