當前位置: 首頁>>代碼示例>>Python>>正文


Python number.long_to_bytes方法代碼示例

本文整理匯總了Python中Crypto.Util.number.long_to_bytes方法的典型用法代碼示例。如果您正苦於以下問題:Python number.long_to_bytes方法的具體用法?Python number.long_to_bytes怎麽用?Python number.long_to_bytes使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Crypto.Util.number的用法示例。


在下文中一共展示了number.long_to_bytes方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: derive_key

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def derive_key(password):
    start = bytes_to_long(password)

    #Making sure I am safe from offline bruteforce attack

    for i in range(NB_ITERATIONS):
        start = start ** e
        start %= N

    #We are never too cautious let's make it harder

    key = 1
    for i in range(NB_ITERATIONS):
        key = key ** e
        key %= N
        key *= start
        key %= N

    return sha256(long_to_bytes(key)).digest() 
開發者ID:The-Art-of-Hacking,項目名稱:h4cker,代碼行數:21,代碼來源:encrypt.py

示例2: generateQ

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def generateQ(randfunc):
    S=randfunc(20)
    hash1=SHA.new(S).digest()
    hash2=SHA.new(long_to_bytes(bytes_to_long(S)+1)).digest()
    q = bignum(0)
    for i in range(0,20):
        c=bord(hash1[i])^bord(hash2[i])
        if i==0:
            c=c | 128
        if i==19:
            c= c | 1
        q=q*256+c
    while (not isPrime(q)):
        q=q+2
    if pow(2,159L) < q < pow(2,160L):
        return S, q
    raise RuntimeError('Bad q value generated') 
開發者ID:mortcanty,項目名稱:earthengine,代碼行數:19,代碼來源:_DSA.py

示例3: change_key

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def change_key(self, master_key):
                if master_key >= (1 << 128):
                    raise InvalidInputException('Master key should be 128-bit')

                self.__master_key = long_to_bytes(master_key, 16)
                self.__aes_ecb = AES.new(self.__master_key, AES.MODE_ECB)
                self.__auth_key = bytes_to_long(self.__aes_ecb.encrypt(b'\x00' * 16))

                # precompute the table for multiplication in finite field
                table = []  # for 8-bit
                for i in range(16):
                    row = []
                    for j in range(256):
                        row.append(self.gf_2_128_mul(self.__auth_key, j << (8 * i)))
                    table.append(tuple(row))
                self.__pre_table = tuple(table)

                self.prev_init_value = None  # reset 
開發者ID:bkerler,項目名稱:edl,代碼行數:20,代碼來源:cryptutils.py

示例4: decrypt

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def decrypt(self, ciphertext: bytes) -> bytes:
        c = bytes_to_long(ciphertext)

        # compute c**d (mod n)
        if (hasattr(self.key, 'p') and hasattr(self.key, 'q') and hasattr(self.key, 'u')):
            m1 = pow(c, self.key.d % (self.key.p - 1), self.key.p)
            m2 = pow(c, self.key.d % (self.key.q - 1), self.key.q)
            h = m2 - m1

            if (h < 0):
                h = h + self.key.q
            h = h * self.key.u % self.key.q

            plaintext = h * self.key.p + m1
        else:
            plaintext = pow(c, self.key.d, self.key.n)

        return long_to_bytes(plaintext) 
開發者ID:GoSecure,項目名稱:pyrdp,代碼行數:20,代碼來源:crypto.py

示例5: writePublicKey

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def writePublicKey(self, publicKey: RSA.RsaKey) -> bytes:
        modulus = publicKey.n
        publicExponent = publicKey.e

        # Modulus must be reversed because bytes_to_long expects it to be in big endian format
        modulusBytes = long_to_bytes(modulus)[:: -1]

        stream = BytesIO()
        stream.write(b"RSA1")
        Uint32LE.pack(len(modulusBytes) + 8, stream)
        Uint32LE.pack(2048, stream)
        Uint32LE.pack(255, stream)
        Uint32LE.pack(publicExponent, stream)
        stream.write(modulusBytes)
        stream.write(b"\x00" * 8)
        return stream.getvalue() 
開發者ID:GoSecure,項目名稱:pyrdp,代碼行數:18,代碼來源:connection.py

示例6: pubKeyXML

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def pubKeyXML(pemPublicKeyFile):
   with open (pemPublicKeyFile, 'rb') as pkFile:
      pemPublicKey = pkFile.read()
   publicKey = RSA.importKey(pemPublicKey)
   xml  = '<RSAKeyValue>'
   xml += '<Modulus>'
   xml += standard_b64encode(number.long_to_bytes(publicKey.n))
   xml += '</Modulus>'
   xml += '<Exponent>'
   xml += standard_b64encode(number.long_to_bytes(publicKey.e))
   xml += '</Exponent>'
   xml += '</RSAKeyValue>'
   fileName = basename(pemPublicKeyFile)
   with open (fileName+'.xml', 'w') as pkFile:
      pkFile.write(xml)
   return
#
# CreateXMLPrivKey
# 
開發者ID:MisterDaneel,項目名稱:PemToXml,代碼行數:21,代碼來源:PemToXml.py

示例7: _noise

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def _noise(self):
        # Adds a bit of noise to the random pool, by adding in the
        # current time and CPU usage of this process.
        # The difference from the previous call to _noise() is taken
        # in an effort to estimate the entropy.
        t=time.time()
        delta = (t - self._lastcounter)/self._ticksize*1e6
        self._lastcounter = t
        self._addBytes(long_to_bytes(int(1000*time.time())))
        self._addBytes(long_to_bytes(int(1000*time.clock())))
        self._addBytes(long_to_bytes(int(1000*time.time())))
        self._addBytes(long_to_bytes(int(delta)))

        # Reduce delta to a maximum of 8 bits so we don't add too much
        # entropy as a result of this call.
        delta=delta % 0xff
        return int(delta) 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:19,代碼來源:randpool.py

示例8: generateQ

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def generateQ(randfunc):
    S=randfunc(20)
    hash1=SHA.new(S).digest()
    hash2=SHA.new(long_to_bytes(bytes_to_long(S)+1)).digest()
    q = bignum(0)
    for i in range(0,20):
        c=ord(hash1[i])^ord(hash2[i])
        if i==0:
            c=c | 128
        if i==19:
            c= c | 1
        q=q*256+c
    while (not isPrime(q)):
        q=q+2
    if pow(2,159) < q < pow(2,160):
        return S, q
    raise error('Bad q value generated') 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:19,代碼來源:DSA.py

示例9: _noise

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def _noise(self):
        # Adds a bit of noise to the random pool, by adding in the
        # current time and CPU usage of this process.
        # The difference from the previous call to _noise() is taken
        # in an effort to estimate the entropy.
        t=time.time()
        delta = (t - self._lastcounter)/self._ticksize*1e6
        self._lastcounter = t
        self._addBytes(long_to_bytes(long(1000*time.time())))
        self._addBytes(long_to_bytes(long(1000*time.clock())))
        self._addBytes(long_to_bytes(long(1000*time.time())))
        self._addBytes(long_to_bytes(long(delta)))

        # Reduce delta to a maximum of 8 bits so we don't add too much
        # entropy as a result of this call.
        delta=delta % 0xff
        return int(delta) 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:19,代碼來源:randpool.py

示例10: generateQ

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def generateQ(randfunc):
    S=randfunc(20)
    hash1=SHA.new(S).digest()
    hash2=SHA.new(long_to_bytes(bytes_to_long(S)+1)).digest()
    q = bignum(0)
    for i in range(0,20):
        c=ord(hash1[i])^ord(hash2[i])
        if i==0:
            c=c | 128
        if i==19:
            c= c | 1
        q=q*256+c
    while (not isPrime(q)):
        q=q+2
    if pow(2,159L) < q < pow(2,160L):
        return S, q
    raise error, 'Bad q value generated' 
開發者ID:kuri65536,項目名稱:python-for-android,代碼行數:19,代碼來源:DSA.py

示例11: pack

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def pack(data):
    ret = ''
    for part in data:
        if type(part) in (type(()), type([])):
            partData = pack(part)
            partType = SEQUENCE|0x20
        elif type(part) in (type(1), type(1L)):
            partData = number.long_to_bytes(part)
            if ord(partData[0])&(0x80):
                partData = '\x00' + partData
            partType = INTEGER
        else:
            raise 'unknown type %s' % type(part)

        ret += chr(partType)
        if len(partData) > 127:
            l = number.long_to_bytes(len(partData))
            ret += chr(len(l)|0x80) + l
        else:
            ret += chr(len(partData))
        ret += partData
    return ret 
開發者ID:kenorb-contrib,項目名稱:BitTorrent,代碼行數:24,代碼來源:asn1.py

示例12: monty_pow

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def monty_pow(base, exp, modulus):
    max_len = len(long_to_bytes(max(base, exp, modulus)))

    base_b, exp_b, modulus_b = [ long_to_bytes(x, max_len) for x in
                                 (base, exp, modulus) ]

    out = create_string_buffer(max_len)
    error = _raw_montgomery.monty_pow(
                out,
                base_b,
                exp_b,
                modulus_b,
                c_size_t(max_len),
                c_ulonglong(32)
                )

    if error == 17:
        raise ExceptionModulus()
    if error:
        raise ValueError("monty_pow failed with error: %d" % error)

    result = bytes_to_long(get_raw_buffer(out))
    return result 
開發者ID:vcheckzen,項目名稱:FODI,代碼行數:25,代碼來源:test_modexp.py

示例13: _compute_mac

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def _compute_mac(self):
        """Compute MAC without any FSM checks."""

        if self._tag:
            return self._tag

        # Step 5 in NIST SP 800-38D, Algorithm 4 - Compute S
        self._pad_cache_and_update()
        self._update(long_to_bytes(8 * self._auth_len, 8))
        self._update(long_to_bytes(8 * self._msg_len, 8))
        s_tag = self._signer.digest()

        # Step 6 - Compute T
        self._tag = self._tag_cipher.encrypt(s_tag)[:self._mac_len]

        return self._tag 
開發者ID:vcheckzen,項目名稱:FODI,代碼行數:18,代碼來源:_mode_gcm.py

示例14: _compute_mac

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def _compute_mac(self):
        """Finalize the cipher (if not done already) and return the MAC."""

        if self._mac_tag:
            assert(self._status == _CipherStatus.PROCESSING_DONE)
            return self._mac_tag

        assert(self._status != _CipherStatus.PROCESSING_DONE)

        if self._status == _CipherStatus.PROCESSING_AUTH_DATA:
            self._pad_aad()

        if self._len_ct & 0x0F:
            self._authenticator.update(b'\x00' * (16 - (self._len_ct & 0x0F)))

        self._status = _CipherStatus.PROCESSING_DONE

        self._authenticator.update(long_to_bytes(self._len_aad, 8)[::-1])
        self._authenticator.update(long_to_bytes(self._len_ct, 8)[::-1])
        self._mac_tag = self._authenticator.digest()
        return self._mac_tag 
開發者ID:vcheckzen,項目名稱:FODI,代碼行數:23,代碼來源:ChaCha20_Poly1305.py

示例15: generate_RSA

# 需要導入模塊: from Crypto.Util import number [as 別名]
# 或者: from Crypto.Util.number import long_to_bytes [as 別名]
def generate_RSA(pridir, pubdir):
    key = RSA.generate(2048)
    with open(pridir, 'wb') as content_file:
        content_file.write(key.exportKey('PEM'))
    print("Private key written to home directory " + pridir)
    with open(pubdir, 'wb') as content_file:
        # Ugly hack to introduce pycrypto v2.7a1
        # Original: .exportKey('OpenSSH')
        eb = long_to_bytes(key.e)
        nb = long_to_bytes(key.n)
        if bord(eb[0]) & 0x80:
            eb = bchr(0x00) + eb
        if bord(nb[0]) & 0x80:
            nb = bchr(0x00) + nb
        keyparts = [b('ssh-rsa'), eb, nb]
        keystring = b('').join(
            [struct.pack(">I", len(kp)) + kp for kp in keyparts])
        content_file.write(b('ssh-rsa ') + binascii.b2a_base64(keystring)[:-1])
    print("Public key written to home directory " + pubdir)
    return sha1(key.exportKey('PEM')).hexdigest() 
開發者ID:projectarkc,項目名稱:arkc-client,代碼行數:22,代碼來源:common.py


注:本文中的Crypto.Util.number.long_to_bytes方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。