Microsoft MVP성태의 닷넷 이야기
글쓴 사람
조윤상
홈페이지
첨부 파일
 

안녕하세요.

http wcf 어플리케이션을 iis없이 if로 self hosting 하고 있습니다.

https 적용을 위해 검색해보니

.net core 처럼 인증서를 직접 참조 하는건 불가능 합니다.

그래서 윈도우에 인증서를 설치하고 바인딩 해서 사용 하라고 하네요.

openssl로 인증서 생성 -> 윈도우 로컬 컴퓨터에 설치 -> 바인딩 --실패

키를 포함한 인증서로 교체 -> 윈도우 로컬 컴퓨터에 설치 -> 바인딩 --성공

wcf 어플리케이션 app.config 수정(일단 빌드 성공 실행)

브라우저에서 https 요청 "해당 서버는 localhost임을 증명하지 못했습니다; 해당 보안 인증서는 주체 대체 이름을 지정하지 않습니다. 이것은 잘못된 구성이나 공격자가 연결을 가로채서 발생한 것일 수 있습니다."

주체 대체 이름 추가한 V3 인증서 새로 발급

V3 인증서로 교체 -> 윈도우 로컬 컴퓨터에 설치 -> 바인딩 --성공

브라우저에서 https 요청 "이 사이트에는 인증서가 없습니다. 이 연결은 안전하지 않으므로 이 사이트와 안전하게 전송되지 않으며 이 사이트에 해로운 상태일 수 있습니다." 이렇게 나옵니다.


PS C:\Users\jys92\dec> netsh http add sslcert ipport=0.0.0.0:8081 appid='{ab642e3b-ebad-4c4d-8f58-08a4ac8dbd1d}' certhash=5026dd45cfd5cc99ab9169e9d59da74e3a51c3fb clientcertnegotiation=enable

SSL 인증서를 추가했습니다.








[최초 등록일: ]
[최종 수정일: 7/15/2021]


비밀번호

댓글 작성자
 



2021-07-15 12시13분
"iis 없이"는 이해하겠는데요, "if"로 호스팅했다는 것에 "if" 의미가 뭔가요?

그리고 clientcertnegotiation을 enable로 한 특별한 의미가 있나요? 그건 클라이언트 측도 인증서를 서버에 전달하겠다는 것으로 아마도 의도하지 않은 설정일 것입니다.

아래의 글을 일단 참고하시고,

WCF에 SSL 적용 (2) - 서비스 제작
; https://www.sysnet.pe.kr/2/0/390

인증서는 다음의 글에 따라 구성해 주시면 됩니다. (아래에서는 CA와 인증서를 구분하지만, self-root 인증서를 만들어 실습해도 됩니다.)

openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법
; https://www.sysnet.pe.kr/2/0/12570

그래도 안 되면 다시 질문해 주세요. 그때는 구체적인 인증서 만들기 절차와 재현 가능한 간단한 예제 프로젝트를 추가하시면 됩니다.
정성태
2021-07-15 12시23분
답변감사합니다.

"iis 없이"는 이해하겠는데요, "if"로 호스팅했다는 것에 "if" 의미가 뭔가요?
 > 오타입니다 IP입니다.

그리고 clientcertnegotiation을 enable로 한 특별한 의미가 있나요? 그건 클라이언트 측도 인증서를 서버에 전달하겠다는 것으로 아무 의도하지 않은 설정일 것입니다.
 > 의미 없습니다.
조윤상

1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5857guest3/17/20232967귀도 반 로썸을 보고 [4]
5856guest3/17/20233181Form1_FormClosing에 closing time을 Sqlite 저장하는 법? [6]파일 다운로드1
5855욜로3/17/20232761C# 메타데이터에서 불러오는 참조 정의가 안됨 [1]
5854민성3/16/20232951안녕하세요 asp.net mvc using문 관련하여 [1]
5853pa3/16/20233200오피스 2016 업데이트 후 파일 출력 불가 [1]
5852guest3/16/20232893입력 foreach 검색/출력 foreach [3]
5851guest3/15/20233227foreach내 list변경 [10]
5850독서가3/14/20232890C#에서 동적dll 사용시 문의입니다. [4]파일 다운로드1
5849guest3/9/20232877C# wpf로 Web에서 구동되는 hts가능한가요? (노트북없고 스마트폰 없음) [4]
5848민성3/9/20232786도움 요청드립니다. [2]파일 다운로드1
5847guest3/7/20232937SQlike Like 구문 - 1시간째 인데 안되네요 [13]
5846Huuu...3/7/20232625웹 다운로드에 대한 고찰 [5]파일 다운로드1
5845guest3/7/20232647C# Split함수의 불친절함 [1]
5844까망이3/7/20232766c# 무료 디컴파일러는 어떤게 좋습니까? [1]
5843guest3/7/20232726판매 후 dll 등 에러 [5]
5842kr13/6/20232770publish 할 때 분석기 관련 dll 제외 [5]
5841guest3/3/20232959프로그램 판매 시 - Upgrade 버전 판매 [2]
5840joe3/2/20233056C# 클래스 라이브러리 수정 -> C++에서 참조시 함수 목록 갱신되지 않음. [4]파일 다운로드1
5839guest3/2/20233684윈도우 서비스 프로그램 - FORM 애플리케이션 감시서비스 [8]
5838랄랄라3/1/20232892event 사용 시 두 표현의 차이점이 있을까요? [1]
5837감사합니...2/28/20233049오라클 DB서버 접속관련 문의 드립니다.(Load Balancing, HA Events) [2]
5836박지범2/27/20232842static instance의 initialize 순서가 보장되나요? [6]
5835주민호2/25/20235654Windows Software Development Kit - 최신버전 1개 남기고 다 삭제하면 안되는지요? [10]파일 다운로드1
5834guest2/24/20232889Python IDE - 비주얼스튜디오 [3]
5833무지남2/23/20232601Async 메서드 그리고 나서 Bool 메서드 [5]
5832김지우2/21/20232887event와 delegate의 차이 , event를 써야하는 이유 [1]
1  2  3  [4]  5  6  7  8  9  10  11  12  13  14  15  ...