Microsoft MVP성태의 닷넷 이야기
닷넷: 2203. C# - Python과의 AES 암호화 연동 [링크 복사], [링크+제목 복사],
조회: 2284
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일

(시리즈 글이 2개 있습니다.)
.NET Framework: 847. JAVA와 .NET 간의 AES 암호화 연동
; https://www.sysnet.pe.kr/2/0/11972

닷넷: 2203. C# - Python과의 AES 암호화 연동
; https://www.sysnet.pe.kr/2/0/13530




C# - Python과의 AES 암호화 연동

간단하게, Python으로는 이렇게 암호화/복호화를 할 수 있고,

# 패키지 2개 설치
# pip install pycryptodome
# pip install pycryptodomex

from Crypto.Cipher import AES
from Crypto.Util.Padding import unpad, pad

iv = "0123456789abcdef"
key = "abcdefghijklmnopabcdefghijklmnop"

cipher = AES.new(key.encode('utf-8'), AES.MODE_CBC, iv.encode('utf-8'))

data = "test is good, not bad, so so.".encode('utf-8')
padded_data = pad(data, AES.block_size)  # AES.block_size == 16
encrypted_data = cipher.encrypt(padded_data)

with open('encrypted.bin', 'wb') as f:
    f.write(encrypted_data)

# 복호화
# cipher = AES.new(key.encode('utf-8'), AES.MODE_CBC, iv.encode('utf-8'))

# decrypted_data = cipher.decrypt(encrypted_data)
# unpadded_data = unpad(decrypted_data, AES.block_size)
# print(bytes.decode(unpadded_data))

위의 코드로 저장한 encrypted.bin 파일을 C#에서 복호화 하려면 다음과 같이 코딩할 수 있습니다.

using System.Security.Cryptography;
using System.Text;

namespace ConsoleApp1;

internal class Program
{
    static void Main(string[] args)
    {
        byte[] iv = Encoding.UTF8.GetBytes("0123456789abcdef"); // 파이썬에서 사용한 iv와 동일
        byte[] key = Encoding.UTF8.GetBytes("abcdefghijklmnopabcdefghijklmnop"); // 파이썬에서 사용한 key와 동일
        byte[] encrypted_data = File.ReadAllBytes("encrypted.bin");

        using (Aes aesAlg = Aes.Create())
        {
            aesAlg.Key = key;
            aesAlg.IV = iv;

            Console.WriteLine($"BlockSize: {aesAlg.BlockSize}(bits) {aesAlg.BlockSize / 8}(bytes)"); // 기본값이 파이썬의 BlockSize와 동일
            Console.WriteLine($"Mode: {aesAlg.Mode}"); // 기본값이 CBC

            var decryptor = aesAlg.CreateDecryptor();
            using (var ms = new MemoryStream(encrypted_data))
            using (var decrypt = new CryptoStream(ms, decryptor, CryptoStreamMode.Read))
            using (var plain = new MemoryStream())
            {
                decrypt.CopyTo(plain);
                string text = Encoding.UTF8.GetString(plain.GetBuffer(), 0, (int)plain.Length);
                Console.WriteLine(text); // 출력 결과: test is good, not bad, so so
            }
        }
    }
}

마찬가지로, C#으로 Encrypt, 파이썬에서 Decrypt하는 것도 위의 옵션 그대로 사용해 과정만 역으로 하면 됩니다.

(첨부 파일은 이 글의 예제 코드를 포함합니다.)




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 1/15/2024]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13392정성태7/16/20233616오류 유형: 872. Oracle - ORA-01031: insufficient privileges
13391정성태7/14/20233632닷넷: 2132. C# - sealed 클래스의 메서드를 callback 호출했을 때 인라인 처리가 될까요?
13390정성태7/12/20233545스크립트: 53. 파이썬 - localhost 호출 시의 hang 현상
13389정성태7/5/20233615개발 환경 구성: 684. IIS Express로 호스팅하는 웹을 WSL 환경에서 접근하는 방법
13388정성태7/3/20233804오류 유형: 871. 윈도우 탐색기에서 열리지 않는 zip 파일 - The Compressed (zipped) Folder '[...].zip' is invalid. [1]파일 다운로드1
13387정성태6/28/20233869오류 유형: 870. _mysql - Commands out of sync; you can't run this command now
13386정성태6/27/20233988Linux: 61. docker - 원격 제어를 위한 TCP 바인딩 추가
13385정성태6/27/20234189Linux: 60. Linux - 외부에서의 접속을 허용하기 위한 TCP 포트 여는 방법
13384정성태6/26/20233899.NET Framework: 2131. C# - Source Generator로 해결하는 enum 박싱 문제파일 다운로드1
13383정성태6/26/20233633개발 환경 구성: 683. GPU 런타임을 사용하는 Colab 노트북 설정
13382정성태6/25/20233682.NET Framework: 2130. C# - Win32 API를 이용한 윈도우 계정 정보 (예: 마지막 로그온 시간)파일 다운로드1
13381정성태6/25/20234098오류 유형: 869. Fatal Python error: init_fs_encoding: failed to get the Python codec of the filesystem encoding
13380정성태6/24/20233501스크립트: 52. 파이썬 3.x에서의 동적 함수 추가
13379정성태6/23/20233537스크립트: 51. 파이썬 2.x에서의 동적 함수 추가
13378정성태6/22/20233422오류 유형: 868. docker - build 시 "CANCELED ..." 뜨는 문제
13377정성태6/22/20237299오류 유형: 867. 파이썬 mysqlclient 2.2.x 설치 시 "Specify MYSQLCLIENT_CFLAGS and MYSQLCLIENT_LDFLAGS env vars manually" 오류
13376정성태6/21/20233685.NET Framework: 2129. C# - Polly를 이용한 클라이언트 측의 요청 재시도파일 다운로드1
13375정성태6/20/20233361스크립트: 50. Transformers (신경망 언어모델 라이브러리) 강좌 - 2장 코드 실행 결과
13374정성태6/20/20233455오류 유형: 866. 파이썬 - <class 'AttributeError'> module 'flask.json' has no attribute 'JSONEncoder'
13373정성태6/19/20234744오류 유형: 865. 파이썬 - pymssql 설치 관련 오류 정리
13372정성태6/15/20233317개발 환경 구성: 682. SQL Server TLS 통신을 위해 사용되는 키 길이 확인 방법
13371정성태6/15/20233411개발 환경 구성: 681. openssl - 인증서 버전(V1 / V3)
13370정성태6/14/20233563개발 환경 구성: 680. C# - Ubuntu + Microsoft.Data.SqlClient + SQL Server 2008 R2 연결 방법 - TLS 1.2 지원
13369정성태6/13/20233369개발 환경 구성: 679. PyCharm(을 비롯해 JetBrains에 속한 여타) IDE에서 내부 Window들의 탭이 없어진 경우
13368정성태6/13/20233532개발 환경 구성: 678. openssl로 생성한 인증서를 SQL Server의 암호화 인증서로 설정하는 방법
13367정성태6/10/20233690오류 유형: 864. openssl로 만든 pfx 인증서를 Windows Server 2016 이하에서 등록 시 "The password you entered is incorrect" 오류 발생
1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...