Este projeto visa proporcionar maior segurança na comunicação entre usuários da rede ContextNet, aplicando métodos de criptografia para proteger as mensagens transmitidas.
Desenvolver uma solução de comunicação segura dentro da rede ContextNet, garantindo confidencialidade, integridade e autenticidade das mensagens trocadas entre os usuários.
- ContextNet: Rede utilizada para a comunicação entre dispositivos.
- Java: Linguagem de programação usada para implementar a lógica do sistema.
- Criptografia: Métodos de criptografia simétrica e/ou assimétrica para proteger as mensagens trocadas.
- Envio e Recebimento de Mensagens: Comunicação entre dois nós da rede ContextNet (remetente e receptor).
- Criptografia de Mensagens: As mensagens são criptografadas antes de serem enviadas e descriptografadas após o recebimento.
- Clone o repositório:
git clone https://github.com/seu-usuario/contextnet-encrypt.git
- Acesse a pasta do projeto:
cd contextnet-encrypt
- Para iniciar o comunicador, é necessário ter o seu uuid e o uuid para quem quer se comunicar, além de já ter definido a chave simétrica de 16 bytes. Depois de ter esses dados em mãoes, rode o seguinte comando:
java -cp "target/dependency/*;app.jar" br.cefet.segaudit.Comunicador runSimetric [servidor] [porta] [my-uuid] [receiver-uuid] [simetricKey]
- Para gerar as chave públicas e privadas dos comunicadores, rode o comando abaixo no diretório do projeto. Esse comando gera dois arquivos, um para cada chave, que serão utilizadas posteriormente para realizar a comunicação entre os comunicadores;
java -jar appKeys.jar generateKeys [nome-do-arquivo]
- Para rodar esse comando é necessário já ter os arquivos de chave privada e pública já gerados para os dois comunicados do sistema, além do seu uuid e o uuid para quem se comunicará. Tendo essas chaves em mãos, rode o seguinte comando para poder inicializa-los no sistema ContextNet.
java -cp "target/dependency/*;app.jar" br.cefet.segaudit.Comunicador run [servidor] [porta] [uuid-sender] [privateKey-sender] [uuid-receiver] [receiver-publicKey]
No caso desses comandos, o "sender" é o para o comunicador quie irá se registrar, e o "receiver" são os dados para qual vamos estabelecer a conexão.