Python Pyme: простая расшифровка без взаимодействия с пользователем

Я использую Pyme для взаимодействия с GPGME и у меня не было проблем с подписью / шифрованием. Однако, когда я пытаюсь расшифровать, он всегда вызывает приглашение для ключевой фразы, несмотря на то, что установил его через c.set_passphrase_cb Перезвоните. Я делаю что-то неправильно?

2 ответа

Решение

Добавьте "c.set_armor(1)" перед установкой обратного вызова парольной фразы.

У меня похожая проблема. Мой код выглядит так:

def passphrase_callback (hint = '', desc = '', prev_bad = ''): вернуть 'пароль'

класс CryptoEngine: класс NoSignKeys(исключение): def init(self, str): исключение.init(self, str)

def __init__(self, user_id, passphrase):
    "Initialize with ID (e-mail)"
    self.user_id = user_id
    self.passphrase = passphrase
def verify(self, data):
    c = core.Context()
    sig = core.Data(string = data)
    file = None
    plain = core.Data()
    c.op_verify(sig, file, plain)
    result = c.op_verify_result()
    plain.seek(0, 0)
    plaintext = plain.read()
    sig = result.signatures
    status = False
    for s in sig:
        status = (s.status == 0)
    return status, plaintext

def sign(self, data):
    c = core.Context()
    for sigkey in c.op_keylist_all(self.user_id, 1):
        if sigkey.can_sign:
            c.signers_add(sigkey)
    if not c.signers_enum(0):
        raise CryptoEngine.NoSignKeys("No secret %s's keys suitable for signing" % self.user_id)

    plain = core.Data(data)
    sig = core.Data()
    c.set_passphrase_cb(passphrase_callback)
    c.op_sign(plain, sig, mode.CLEAR)
    sig.seek(0, 0)
    return sig.read()

Несмотря на установку обратного вызова парольной фразы, я все равно получаю окно с запросом парольной фразы или просто исключение, сообщающее о неверном пароле. Кто-то решил эту проблему и может поделиться своими знаниями? Спасибо ян

Другие вопросы по тегам