Microsoft MVP성태의 닷넷 이야기
종단간 암호화에 대해 시나리오인데 타당한 시나리오일까요? [링크 복사], [링크+제목 복사],
조회: 10527
글쓴 사람
김재영 (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]

... 31  32  33  34  35  36  37  38  [39]  40  41  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
4918ho11/16/201718142    답변글 [답변]: 예제 프로젝트 첨부합니다. [4]파일 다운로드2
4916필승11/11/201717043기본 웹 브라우저 체크는 어떻게 해야 하나요? [2]
4915필승11/10/201716541WebBrowser 컨트롤 소리 출력 문의 드립니다. [2]
4914Ques...11/10/201717185c# 버튼 이벤트에 관하여 질문드립니다. [2]
4913Arvid11/8/201720100Log4Net 라이브러리를 이용하여 특정 기간이 지났을 때 자동 로그 삭제 기능 구현 질문 드립니다! [2]
4912조범희11/8/201719557C# FTP 다운로드중 에러 발생.. [2]파일 다운로드1
4911필승11/6/201717790WebBrowser 컨트롤 사용법에 대해 궁금합니다. [2]
4910진우11/6/201717941람다 초보 질문 드립니다. [2]
4909필승11/5/201718770TextBox에 관해 질문 드립니다. [5]
4908필승11/1/201723892특정 시각에 프로그램 종료 또는 재시작시 오류 발생 [8]
4907심너울10/29/201718781선생님이 쓰신 "시작하세요! C# 7.1~"으로 공부하고 있는데요~ [2]
4906guest10/25/201716721.net core, .net standard 관련해서 궁금합니다 [2]
490510/25/201716644watermark 관련문의 [1]
4903Ho10/25/201717005간단한 서버를 구현해 보고 싶습니다. [2]
4902황재승10/22/201718087C# 7.1 프로그래밍 왕초보자도 이해할 수 있는 수준인가요? [1]
4901김레오10/17/201724246c# 프로그램 난독화 도구인 confuserex라는 도구를 사용하다 여쭙습니다. [2]
4900황준범10/12/201718165ClickOnce 배포관련 질문드립니다. [1]
4899Ques...9/28/201719918C# 프로그램이 "응답 없음" 시에도 계속 독립적으로 돌아가는 타이머 생성법 [3]
4898ssdrm9/27/201716635Clickonce 실행시 보안에 막힙니다 ㅠ [1]
4897김태진9/23/201717292윈도우7 작업관리자의 상세(details)탭 생성에 대해 여쭙습니다. [1]
4896장진국9/19/201718546안녕하세요 WPF 에서 Window객체가 가비지 콜렉션에 의해 수집되지 않는거 같아서 문의드립니다. [1]
4895Ques...9/18/201719402Generic 에 관하여 질문드립니다. [5]
4894얼마전6...9/14/201722103C# 7.1에서 보강된 부분만 PDF로 제공하는 건 아니되나요? [2]
4893BigII9/14/201720365타 언어(JAVA, PHP 등)에서 받은 RSA 개인키 문자열을 이용하여 내용 복호화 가능 여부 [4]
4892Ques...9/13/201718473서브 폼에서는 무거운 작업을해도 속도가 빠를까요 ?? [1]
4891윤현수9/11/201718828Taskbar에 관한 질문입니다. [5]
... 31  32  33  34  35  36  37  38  [39]  40  41  42  43  44  45  ...