Microsoft MVP성태의 닷넷 이야기
종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [링크 복사], [링크+제목 복사],
조회: 2933
글쓴 사람
김재영 (kjyoffice at gmail.com)
홈페이지
첨부 파일
 

안녕하세요
이전 RSA 암호화 문의에 이어 추가적인 질문이 있습니다.
(쓰고보니 위 질문시 주의 사항의 스무고개 같은 느낌인데 혹시 해당된다면 죄송합니다.)
(지난 RSA 글에 이 내용까지 쓰자니 너무 길어지기도 하고 RSA도 안되는데 이 시나리오 까진 시기상조다 싶었거든요)

종단간 암호화에 대해서 시나리오를 만들었는데 타당한지 의견을 여쭤봅니다.
(이후 내용은 제가 시나리오 만들면서 쓴 내용이라 반말성입니다. 양해 부탁드리겠습니다.)




-----------------------------------------
어떤 채팅 앱을 만들었고 종단간 암호화를 한다

--- Type 1

<<< 1:1 대화방 >>>
- User1이 방을 만듦

- User1가 방 입장시 키 생성
# 개인키 : user1pri
# 공개키 : user1pub

- User2이 방에 입장
- User2가 방 입장시 키 생성
# 개인키 : user2pri
# 공개키 : user2pub

- 서로 공개키 교환을 함
- User1이 User2에게 공개키 "user1pub" 전달
- User2가 User1에게 공개키 "user2pub" 전달

#1
- User1이 글 작성 "안녕"
- User2의 공개키(user2pub)로 암호화 : abcabc
- 서버로 전송 : abcabc
- 서버에선 User2에게 전송 : abcabc
- User2는 개인키(user2pri)로 복호화 : 안녕

- User2가 글작성 : 웅 안녕 밥 먹었어?
** 위 #1과 동일 프로세스


<<< 1:n 대화방 >>>
** 위 1:1 대화방 프로세스와 Base는 동일
- 유저가 방에 입장할때마다 개인키 공개키 생성 (10명이라고 가정)
- 모두와 공개키 공유
- User7이 글 작성 : 늦어서 미안
- 각 유저별 개인키로 함호화 (User 1,2,3,4,5,6,8,9,10)
- userlist = [u1,u2,u3,u4,u5,u6,u8,u9,u10];
  foreach userx in userlist
    암호화 및 전송 userx.Send(userx.GetKeyAndEncrypt())


--- Type 2
(유저가 몇명이 될지 모르고 보안적으로도) 미리 개인키 받아서 공유과정은 좋지 않을 수 있다

암호화 하는 시점에 보내고자 하는 유저의 공개키를 요청, 받아와서 쓰고 버림

글 작성 시점
- User1이 글 작성 "안녕"
- User2에게 공개키 요청
- User2는 공개키 생성 후 전달 :user2pub111
- User1은 User2의 공개키(user2pub111)를 받아서 암호화 : xyzxyz
- User1은 User2의 공개키 user2pub111 는 이미 썼으니 버림
- 서버로 전송 : xyzxyz
- 서버에선 User2에게 전송 : xyzxyz
- User2는 개인키(user2pri)로 복호화 : 안녕
-----------------------------------------

위 시나리오가 맞다면 만들기 나름이긴 하지만
종단간 암호화를 위해 크게는 아래 3가지 서버 타입이 있다고 보여지는데 타당할까요?


- Type 1 : 공개키를 주고받고, 암호화된 데이터를 주고받는 서버, 즉 전달만 담당
- Type 2 - A : 공개키를 중앙에서 관리, User1이 User2의 공개키를 요청하면 서버는 User2의 공개키를 내어주고 공개키 만료시간이 다가오면 서버가 User2에게 새로운 공개키를 요청하여 갱신한다
- Type 2 - B : 키 자체를 중앙에서 관리, User가 입장하면 서버에서 개인키를 생성 입장한 User에게 제공, 이후 UserX키를 요청하면 서버에서 공개키를 제공
- Type 3 : User간 p2p로 연결하고 외부서버는 유저간 연결을 위해 홀펀칭을 담당


감사합니다.








[최초 등록일: ]
[최종 수정일: 2/6/2023]


비밀번호

댓글 작성자
 



2023-02-06 01시45분
어느 것을 하셔도 상관없을 듯합니다. 단지 Type 2-B의 경우 종단 간 암호화라는 취지가 "사용자 간 암호화"를 의미한다면 서버에서 개인키를 생성하는 것은 맞지 않다고 봅니다.
정성태
2023-02-06 06시12분
[김재영] 의견 감사합니다. +_+
[guest]

... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
5290베도빈2/15/20207290직접 제작한 사용자 정의 콘트롤 DLL, 실행파일에 포함시켜 배포할 수 있을까요? [1]
5288김성배2/14/20207711c# 참조추가 기능에서 DirectX 참조가 보이지 않아요.. DircetX 11 은 설치 되어 있습니다. [1]
5287C# 초...2/14/20206708프로그램 실행 질문 드립니다. [4]파일 다운로드1
5286gongs2/3/202014125윈도우 배율 및 레이아웃에 대한 질문입니다. [3]
5285강성욱1/27/20207846작업관리자에 표시되는 스레드 개수와 프로그램 내 스레드 개수 일치 [1]
5284이상준1/15/202013562출력창에 '스레드가 종료되었습니다' 문구 문의 [2]파일 다운로드1
5282봉봉이 1/13/202010319소켓 비동기 ReceiveTimeOut 구현 [9]파일 다운로드1
5281봉봉이 1/13/20208345소켓 비동기 ReceiveTimeOut 구현 [2]
5280sdd1/8/20206918데이터 저장, 배치파일 관련하여 질문드립니다. [4]
5279김창한12/27/20197902dsoframer ocx [3]
5278guest12/27/20196684CLR 스레드 풀 관련 질문 [1]
5277방문자12/26/20196509WindowsForm 질문드립니다. [3]
5276진우12/17/20198238c++/c# 에도 파이썬 가상환경 같은 기능 혹시 있는지 궁금합니다. [3]
5275송재필12/17/20197943아래 'c#8.0 프로그래밍 교제 예제 관련 문의 드립니다' 의 원인이 압축 파일의 문제인듯 합니다. [2]파일 다운로드1
5272정영훈12/13/20198124byte => string => byte 변환 문의드립니다. [5]파일 다운로드1
5270김세미12/3/20197862c#8.0 프로그래밍 교제 예제 관련 문의 드립니다. [4]
5269달려라라...12/2/20198004C# winform(framework) tabcontrol 에서 button 함수 관련 질문 [3]파일 다운로드1
5266엔벌잉11/26/20196935라즈베리파이 autostart관련 질문 [2]
5265해나11/25/20197019C# 6.0 책 내용 문의 [1]
5264김혜원11/18/20199481C# CodeSign에 대해 여쭤볼 것이 있습니다 [4]
5263정환맨11/17/20197595Task관련 질문입니다 [3]
5262닷린이11/14/20199002Dispatcher 와 synchronizationcontext의 관계가 궁금합니다. [6]
5260방문자11/13/20197958안녕하세요 도움받고 싶습니다 [1]
5259ming11/13/20197060string타입 파라메터로 넘길때 메모리 내부가 궁금합니다. [3]
5258C#초보11/13/20198853DCOM COM+ 등록 관련 문의드립니다. [7]
5257C#초보11/9/20197482파일 저장 방법에 대해 조언 부탁드립니다. [3]
... 16  17  18  19  20  21  22  23  24  [25]  26  27  28  29  30  ...