Sem resumo de edição |
|||
| Linha 32: | Linha 32: | ||
= Código = | = Código = | ||
<syntaxhighlight lang="python3"> | |||
Arquivo = "lista_contatos.txt" # Nome do arquivo | |||
def ler_arquivo(): # Função que le o arquivo de texto | |||
try: # Tratamento de erro | |||
arq = open(Arquivo,"r+") # Abre o arquivo para leitura | |||
print( '\n'+arq.read() ) # Quebra linha e mostra o conteudo | |||
arq.close() # Fecha o arquivo | |||
except IOError: # Tratamento de erro | |||
print('\nArquivo não encontrado!') | |||
def escrever_linhas(texto): # Função que le e escreve no arquivo | |||
try: # Tratamento de erro | |||
arq = open(Arquivo,"a+") # Abre o arquivo para gravação no final do arquivo | |||
arq.writelines('\n'+texto) # Escreve no arquivo o parametro 'texto' | |||
arq.close() # Fecha o arquivo | |||
print('\nLinha gravada com sucesso') | |||
except IOError: # Tratamento de erro | |||
print('\nErro ao abrir o arquivo!') # Mostra na tela uma mensagem de erro | |||
def pesquisar_contato(nome): | |||
try: | |||
arq = open(Arquivo, "r+") | |||
dicionario = {'nome':'', 'telefone':'', 'email':''} | |||
achei = False | |||
# lógica ler arquivo e comparar nome | |||
for cont, s in enumerate(arq.readlines()): | |||
dicionario['nome'], dicionario['telefone'],dicionario['email'] = s.split(' - ') | |||
if dicionario['nome'] == nome: | |||
print(cont) | |||
print('Nome: %s'% dicionario['nome']) | |||
print('Telefone: %s'% dicionario['telefone']) | |||
print('Email: %s'% dicionario['email']) | |||
achei = True | |||
if not achei: | |||
print('Não existe %s' % (nome)) | |||
# se achou imprime, se não mostra uma mensagem de nao encontrado | |||
arq.close | |||
except IOError: | |||
print('\nContato não encontrado') | |||
def excluir_contatos(): | |||
try: | |||
arq =open('lista_contatos.txt','r+') | |||
valores = arq.readlines() | |||
l = [] | |||
splited =[] | |||
nome = input('Entre com um nome:') | |||
for x in valores: | |||
splited=x.split(' - ') | |||
if splited[0]==nome: | |||
pass | |||
else: | |||
l.append(splited) | |||
arq.close() | |||
novo_cadastro(l) | |||
except: | |||
print('erro') | |||
def novo_cadastro(l): | |||
arq = open(Arquivo,'w') | |||
for x in l: | |||
#print("Nome:%s | Telefone:%s | Email:%s"%(x[0],x[1],x[2])) | |||
arq.write("%s - %s - %s" %(x[0],x[1],x[2])) | |||
arq.close() | |||
while(True): | |||
print('\n Opcões:') | |||
print(' ') | |||
print('1 - Cadastrar contato') | |||
print('2 - Listar dados') | |||
print('3 - Pesquisar contato') | |||
print('4 - Excluir contato') | |||
print('9 - Sair') | |||
print(' ') | |||
Op = int(input('Digite a opção desejada:')) # Entrada da opcao pelo teclado | |||
if Op == 1: # Se a opcao for 1 | |||
nome = input('\nDigite o nome do contato:') # Entrada do nome pelo teclado | |||
fone = input('Digite o número do telefone:')# Entrada do telefone pelo teclado | |||
email = input('Digite o email:') # Entrada do telefone pelo teclado | |||
contato = (nome+' - '+fone+' - '+email) # Recebe o nome + o telefone | |||
escrever_linhas(str(contato)) # Chama a função que grava em arquivo | |||
elif Op == 2: # Se a opcao for 2 | |||
ler_arquivo() # Chama a função que le o arquivo | |||
elif Op == 9: # Se a opcao for 0 | |||
break # Quebra o laço infinito | |||
elif Op == 3: | |||
nome = input("Digite o nome: ") | |||
pesquisar_contato(nome) | |||
elif Op == 4: | |||
#nome = input ("Digite o nome: ") | |||
excluir_contatos() | |||
</syntaxhighlight> | |||
Dar um exemplo de um código-fonte que mostre alguma parte da aplicação final. O código deverá ser curto mas que o leitor consiga enxergar para que serve. Pode-se usar comentários no programa. | |||
<br> | |||
= Diagrama de Casos de Uso = | |||
Desenhar ou plotar os requisitos funcionais de uma aplicação. | |||
<br> | |||
= Interações com as tecnologias = | |||
Incluir links (internos ou externos) temas que tem relação com este, explicando detalhes sobre. Limite de 3 internos e 2 externos. | |||
<br> | |||
= Informações adicionais = | |||
Descrever detalhes a mais sobre esse tema. | |||
<br> | |||
= Referências bibliográficas = | |||
Relacionar aqui as referências bibliográficas no padrão ABNT. | |||
Bases de procura: Artigos, publicações acadêmicas, revistas e sites de fornecedores | |||
<br> | <br> | ||
Edição das 20h22min de 5 de outubro de 2017
Conceito
A programação em segurança de rede começa quando o usuário tem que efetuar uma autenticação, habitualmente com um nome de usuário e uma senha. Uma vez que isso seja efetuado, é necessário apenas um detalhe autenticando o nome do usuário ,ou seja, a senha. Isso é usualmente chamado de autenticação de um fator. Com a autenticação de dois fatores, algo que o usuário possui também é usado (por exemplo, um token de segurança ou dongle, um cartão de caixa eletrônico ou um telefone celular); e com autenticação de três fatores, algo que o usuário é também é usado (por exemplo, uma impressão digital ou uma varredura retiniana).
Uma vez autenticado, um firewall impõe políticas de acesso, como os serviços a que os usuários da rede podem acessar. Embora eficaz para impedir o acesso não autorizado, esse componente pode não verificar o conteúdo potencialmente nocivo, como worms de computador ou troianos que estão sendo transmitidos pela rede. O software anti-vírus ou um sistema de prevenção de intrusão (IPS) ajudam a detectar e inibir a ação de tal malware.
Softwares
Alguns softwares que são usados para esta finalidade são: SNORT e WIRESHARK. Alguns dos softwares que usam a programação em segurança de redes são: Nessus Vulnerability Scanner , Nmap, Burp Suite entre outros. Todas as linguagens praticamente podem ser usadas na área da Programação em Segurança de redes, com relativo destaque para Assembly, C/C++, Python e Perl.
- WIRESHARK
Wireshark (anteriormente conhecido como Ethereal) é uma ferramenta open source e multiplataforma. Ele é um analisador de rede (sniffer) completo. Ele permite que você examine os dados de uma rede em tempo real ou a partir de um arquivo de captura. Além disso, tem várias características poderosas; tais como: suporte a centenas de protocolos e tipos de mídia. Em comparação, o Wireshark assemelhasse ao tcpdump – outra ferramenta sniffer, contudo via linha de comando.
Banco de dados: Sniffing no localhost: Sniffing é a prática que, utilizando uma ferramenta genericamente chamada sniffer, intercepta e registra tráfego de dados e é capaz de decodificar o conteúdo trocado entre computadores de uma rede. O localhost muitas vezes é usado também por serviços que não precisam ser expostos a uma rede maior. Um ótimo exemplo é um servidor de banco de dados executando na mesma máquina que a aplicação web que se conecta com esse banco de dados. Como o banco de dados é possivelmente acessível de fora da máquina da aplicação web, ele representa um risco à segurança. Em situações como essa, basta vincular o banco de dados ao localhost de modo que o servidor web local possa continuar se comunicando com ele, mas o banco de dados seja inacessível aos processos que estejam fora da máquina local.
- SNORT
É um sistema de detecção e prevenção de intrusão (IDS) de rede é um dos mais completos para análise de tráfego e registro de pacotes em redes IP. O Snort utiliza uma linguagem baseada em regras (rules) flexíveis para descrever o tráfego que deve analisar ou passar, e um motor de detecção modular. Além do mais, existe uma ferramenta livre com interface web para análise dos alertas de Snort – Basic Analysis and Security Engine (BASE). Por fim, o Snort é gratuito e open-source. Contudo, boa parte das rules para Snort são pagas; limitando os recursos da versão free, já que as rules são o combustível principal do Snort.
Código
<syntaxhighlight lang="python3"> Arquivo = "lista_contatos.txt" # Nome do arquivo
def ler_arquivo(): # Função que le o arquivo de texto
try: # Tratamento de erro
arq = open(Arquivo,"r+") # Abre o arquivo para leitura
print( '\n'+arq.read() ) # Quebra linha e mostra o conteudo
arq.close() # Fecha o arquivo
except IOError: # Tratamento de erro
print('\nArquivo não encontrado!')
def escrever_linhas(texto): # Função que le e escreve no arquivo
try: # Tratamento de erro
arq = open(Arquivo,"a+") # Abre o arquivo para gravação no final do arquivo
arq.writelines('\n'+texto) # Escreve no arquivo o parametro 'texto'
arq.close() # Fecha o arquivo
print('\nLinha gravada com sucesso')
except IOError: # Tratamento de erro
print('\nErro ao abrir o arquivo!') # Mostra na tela uma mensagem de erro
def pesquisar_contato(nome):
try:
arq = open(Arquivo, "r+")
dicionario = {'nome':, 'telefone':, 'email':}
achei = False
# lógica ler arquivo e comparar nome
for cont, s in enumerate(arq.readlines()):
dicionario['nome'], dicionario['telefone'],dicionario['email'] = s.split(' - ')
if dicionario['nome'] == nome:
print(cont)
print('Nome: %s'% dicionario['nome'])
print('Telefone: %s'% dicionario['telefone'])
print('Email: %s'% dicionario['email'])
achei = True
if not achei:
print('Não existe %s' % (nome))
# se achou imprime, se não mostra uma mensagem de nao encontrado
arq.close
except IOError:
print('\nContato não encontrado')
def excluir_contatos():
try:
arq =open('lista_contatos.txt','r+')
valores = arq.readlines()
l = []
splited =[]
nome = input('Entre com um nome:')
for x in valores:
splited=x.split(' - ')
if splited[0]==nome:
pass
else:
l.append(splited)
arq.close()
novo_cadastro(l)
except:
print('erro')
def novo_cadastro(l):
arq = open(Arquivo,'w')
for x in l:
#print("Nome:%s | Telefone:%s | Email:%s"%(x[0],x[1],x[2]))
arq.write("%s - %s - %s" %(x[0],x[1],x[2]))
arq.close()
while(True):
print('\n Opcões:')
print(' ')
print('1 - Cadastrar contato')
print('2 - Listar dados')
print('3 - Pesquisar contato')
print('4 - Excluir contato')
print('9 - Sair')
print(' ')
Op = int(input('Digite a opção desejada:')) # Entrada da opcao pelo teclado
if Op == 1: # Se a opcao for 1
nome = input('\nDigite o nome do contato:') # Entrada do nome pelo teclado
fone = input('Digite o número do telefone:')# Entrada do telefone pelo teclado
email = input('Digite o email:') # Entrada do telefone pelo teclado
contato = (nome+' - '+fone+' - '+email) # Recebe o nome + o telefone
escrever_linhas(str(contato)) # Chama a função que grava em arquivo
elif Op == 2: # Se a opcao for 2
ler_arquivo() # Chama a função que le o arquivo
elif Op == 9: # Se a opcao for 0
break # Quebra o laço infinito
elif Op == 3:
nome = input("Digite o nome: ")
pesquisar_contato(nome)
elif Op == 4:
#nome = input ("Digite o nome: ")
excluir_contatos()
</syntaxhighlight>
Dar um exemplo de um código-fonte que mostre alguma parte da aplicação final. O código deverá ser curto mas que o leitor consiga enxergar para que serve. Pode-se usar comentários no programa.
Diagrama de Casos de Uso
Desenhar ou plotar os requisitos funcionais de uma aplicação.
Interações com as tecnologias
Incluir links (internos ou externos) temas que tem relação com este, explicando detalhes sobre. Limite de 3 internos e 2 externos.
Informações adicionais
Descrever detalhes a mais sobre esse tema.
Referências bibliográficas
Relacionar aqui as referências bibliográficas no padrão ABNT. Bases de procura: Artigos, publicações acadêmicas, revistas e sites de fornecedores

