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)
5564초보10/21/20211374오버라이드 관련 질문드립니다 [2]
5562서지훈10/20/20211338win32 api 문의 드립니다. (EnableMenuItem) [5]
5561Edun10/15/20211526도와주세요!! 팝업 띄우는 더블클릭 이벤트!! 부탁드립니다 ㅠㅠ [4]파일 다운로드1
5560Edun10/13/20211806C#초보자 개념이해 도와주세요!! [4]
5559최가운10/5/20211592C# debugging 중에 Thread Pool Worker들이 사라지는데요 [3]
5558옥코드9/29/20211544안녕하세요! EntityFramework Linq 질문 드리겠습니다. [4]
5557임기성9/16/20212022웹 사이트(IIS)가 오류로 인하여 빈번하게 죽는 이슈 문의 [1]
5556hjlee9/13/20211343visual studio 설치 없이 csi.exe (C# interactive) tool을 설치할 수 있을까요? [2]
5555이성열9/2/20211373C# 런타임(Reflection)에서 소스코드에 입력한 함수설명(Summary)을 가져올 수 있을까요? [3]
5554농상9/2/20211683enum 원소값이 중복인 경우 출력 [4]
5553shdtkd378/31/20211656제너릭을 new로 할당했는데 null인 경우가 존재하나요? [1]
5552hjshimdm8/30/20211449C# 폼 - 마우스가 다른 버튼 위를 움직일 때도 폼의 페인트핸들러가 호출되는 것이 맞나요? [2]
5551하나다라마8/27/20211542뽀모도로 타이머 개선사항 [1]
5550하영8/27/20212188SqlDataReader 관련 질문입니다. [8]
5549책 감사합니다8/23/20212490C# 9.0 책 오타 [1]
5548Dev8/23/20212128String의 IndexOfAny 함수 질문 [3]
5547민성8/20/20211953WPF Radio 버튼을 GroupName으로 읽어와서 비교하기 [1]
5546DeveloperST8/19/20212119C++ C# API 연동 관련 [1]
5545영귤8/18/20211543C# 14.3장 예제에서 반환 값의 값 복사 부하가 어디서 발생하는 것인가요? [4]
5544이상호8/18/20211524C# Graphics 객체 저장 가능 여부 [2]
5543정형지8/18/20211613c# outofmemoryexception [3]
5542영귤8/11/20212267C#9.0 886쪽 오류 발생 안 해요 [2]
5541서지훈8/11/20212893C# 응용프로그램(Winform)의 비정상 종료(Exit Code) [2]
5540산들마을호랑이8/11/20211802C# 많은 Control(Label 300개) Update 관련 문의 [2]파일 다운로드1
5539초초초촙8/9/20211216c# textbox 입력값이 다름 [1]파일 다운로드1
5538VS8/7/20211318vsmacros 확장자 파일을 사용하는 방법을 알 수 있을까요? [2]
1  2  3  4  5  6  [7]  8  9  10  11  12  13  14  15  ...