English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Prefácio
No início, pensei em tentar instalar o Python no Windows3.6Embora o Python tenha sido instalado com sucesso, ao instalar o módulo Cryto usando pip3 O install pycrypto sempre gera erros. Após tentativas por um tempo, decidi fazer isso no Linux.
Este processo está limitado ao sistema Linux:
Crypto不是自带的模块,需要下载。http://www.voidspace.org.uk/python/modules.shtml#pycrypto
我下载了之后,发现下载的是crypto而不是Crypto(就是差个首字母大小写)
而crypto.Cipher而又不能运行,报错,最后在:https://stackoverflow.com/questions/31485110/no-module-named-crypto-cipher/31485157 找到解答,需要在python目录里面把Python27\Lib\site-packages下的crypto文件改名,没错,就是直接改成Crypto。结果就能用了...
(因为我上面下载的是免安装版,所以没安装VS2008。我用过pip,下载不了Crypto)windows下安装这些模块真是招罪,要是我的电脑再好一点就弄双系统了..扯远了..
0x00 安装python
apt-get install python3.6
0x01 安装pip3
1.首先安装setuptool
wget --no-check-certificate https://pypi.python.org/packages/source/s/setuptools/setuptools-19.6.tar.gz#md5=c607dd118eae682c44ed146367a17e26 tar -zxvf setuptools-19.6.tar.gz cd setuptools-19.6.tar.gz python3 setup.py build python3 setup.py install
2.然后直接安装pip就搞定了
wget --no-check-certificate https://pypi.python.org/packages/source/p/pip/pip-8.0.2.tar.gz#md5=3a73c4188f8dbad6a1e6f6d44d117eeb tar -zxvf pip-8.0.2.tar.gz cd pip-8.0.2 python3 setup.py build python3 setup.py install
0x02 install crypto
apt-get install python3-dev pip3 install Crypto pip3 install --upgrade pycrypt
下面主要介绍一下Crypto.Cipher的AES算法。
代码如下:
from Crypto.Cipher import AES import base64 secret = "12345678912345678912345678912345" #由用户输入的16位或24位或32位长的初始密码字符串 cipher = AES.new(secret) #通过AES处理初始密码字符串,并返回cipher对象 s = cipher.encrypt("1234567891234567") # Input da string a ser criptografada, note que o comprimento da string deve ser16multiplos.16,32,48.. print s # Output da string criptografada print base64.b64encode(s) # Output da string criptografada do base64Codificação. print cipher.decrypt(s) # Descriptografar
Isso é para que os iniciantes (eu) possam entender. Geralmente, métodos de tratamento mais comuns podem ser consultados em https://pt.oldtoolbag.com/article/114364.htm
A respeito de por que a string criptografada já usada base64Codificação, acredito que o tratamento da string é baseado em binário, enquanto base64O princípio é que em cada6Adicione dois zeros no início do número binário, então, a codificação ascii do string processado pode ser vista completamente (pelo menos não são aqueles caracteres de interrogação...), teste com o módulo charset, descobri que é exatamente como eu disse.
O algoritmo DES é usado da mesma forma que o AES, mas deve-se prestar atenção para que a string de senha inicial seja8Posso usar AES, mas em outros lugares, você pode substituir AES por DES (se não lembrar de configurar o ambiente, o Python ainda é muito conveniente...)
Este módulo Crypto ainda possui algoritmos de hash e outras técnicas de criptografia. Se algum gênio ou colega descobrir esse módulo, é bem-vindo a deixar um comentário aqui. E também, por favor, ensinem-me a usá-lo, obrigado a todos!
Isso é tudo sobre o conteúdo deste artigo. Espero que ajude na sua aprendizagem e que vocês apoiem mais o tutorial Yell.
Declaração: O conteúdo deste artigo é extraído da internet, pertence ao respectivo proprietário. O conteúdo é contribuído e carregado voluntariamente pelos usuários da internet. Este site não possui direitos de propriedade, não foi editado manualmente e não assume responsabilidades legais relacionadas. Se você encontrar conteúdo suspeito de infringir direitos autorais, envie um e-mail para: notice#oldtoolbag.com (ao enviar e-mail, substitua # por @ para denunciar e forneça provas. Se confirmado, o site deletará imediatamente o conteúdo suspeito de infringir direitos autorais.)