Criptografia de César
Publicado por Diogo V. Kersting 30/10/2006
[ Hits: 16.166 ]
Script que implementa a criptografia de César. Uma criptografia relativamente fraca, porém mostra como é fácil manipular strings em Python.
#!/usr/bin/python
# -*- coding: UTF-8 -*-
# Por Diogo V. Kerting diogovk@gmail.com
# Sob GNU GPL
from optparse import OptionParser
import sys
usage = "usage: %prog [options] [mensagem]"
# Objeto que manipula a linha de comando
parser = OptionParser()
parser.add_option("-o", "--saida", dest="arquivo_saida", help="Imprime em arquivo",metavar="ARQUIVO")
parser.add_option("-e", "--encripta", action="store_true", dest="encriptar",default=False,help="Encriptar mensagem",metavar="ENCRIPTA")
parser.add_option("-d", "--decripta", action="store_true", dest="decriptar",default=False,help="Decriptar mensagem",metavar="DECRIPTA")
parser.add_option("-c", "--chave", action="store", dest="chave",type='int',help="Chave utilizada para encriptar ou decriptar a mensagem",metavar="CHAVE")
(options, args) = parser.parse_args()
if options.encriptar and options.decriptar:
print 'Opções conflitantes -e e -d'
if not options.encriptar and not options.decriptar:
options.encriptar=True
if options.chave == None:
print 'É necessaria uma chave para a ação selecionada.\nTente passar uma atraves do parametro -c'
sys.exit(1)
if options.chave > 25 or options.chave < 1:
print 'A chave deve ser de 1 a 25'
print options.chave
sys.exit(1)
if args == ['']:
mensagem=raw_input()
else:
mensagem=''
for string in args:
mensagem+=string+' '
chave=options.chave
mensagem_encriptada=''
if options.encriptar:
for byte in mensagem:
if byte.isalpha():
byte_encriptado=chr(ord(byte)+chave)
if byte.isupper() and ord(byte_encriptado) > 90:
byte_encriptado=chr(ord(byte_encriptado)-26)
if byte.islower() and ord(byte_encriptado) > 122:
byte_encriptado=chr(ord(byte_encriptado)-26)
else:
byte_encriptado=byte
mensagem_encriptada+=byte_encriptado
else:
for byte in mensagem:
if byte.isalpha():
byte_encriptado=chr(ord(byte)-chave)
if byte.isupper() and ord(byte_encriptado) < 65:
byte_encriptado=chr(ord(byte_encriptado)+26)
if byte.islower() and ord(byte_encriptado) < 97:
byte_encriptado=chr(ord(byte_encriptado)+26)
else:
byte_encriptado=byte
mensagem_encriptada+=byte_encriptado
print mensagem_encriptada
Krypt - Função de criptografia por chave de qualquer tamanho
Brute force, algo à aprimorar?
Hash Checker - Calcule o Hash dos seus Arquivos para verficação de integridade.
Mkpass - Função para gerar senhas aleatórias
Cirurgia para acelerar o openSUSE em HD externo via USB
Void Server como Domain Control
Modo Simples de Baixar e Usar o bash-completion
Monitorando o Preço do Bitcoin ou sua Cripto Favorita em Tempo Real com um Widget Flutuante
Atualizar Linux Mint 22.2 para 22.3 beta
Jogar games da Battle.net no Linux com Faugus Launcher
Como fazer a Instalação de aplicativos para acesso remoto ao Linux
Assisti Avatar 3: Fogo e Cinzas (4)
Conky, alerta de temperatura alta (11)









