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)
5906guest4/21/20233319Dispatcher 서비스 구현 질문 [1]
5905guest4/20/20233589tabControl의 tabPage가 여러 개일 때 순서를 바꾸기가 까다롭네요 [5]
5904guest4/18/20233481[신규자료첨부] DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [4]파일 다운로드1
5903guest4/18/20232937fileSystemWatcher 이벤트 관련 질문입니다 [2]
5902guest4/17/20233510c#으로 USB 관련 질문 [2]
5901guest4/17/20233173내솔루션 판매 시 1.0.0.0 폴더와 Sqlite 배포 [5]
5900guest4/17/20234309DLL 'SQLite.Interop.dll'을 찾을 수 없습니다 [2]파일 다운로드1
5899guest4/17/20233273Dictionary와 Linq [4]
5898차가워4/17/20233069CNTK 교육 문의 [1]
5897guest4/17/20233024Socket스레드와 UI thread [4]
5896HAN4/16/20232980c언어 return 에 대해 궁금한게 있어요. [1]파일 다운로드1
5895guest4/15/20232754Drag and Drop - 모든 컨트롤 [2]
5894송부장4/14/20234158[질문] Visual Studio 2022에서 '도구 상자 항목 선택'의 'COM 구성 요소' 탭에서 ActiveX 목록이 보이지 않습니다. [3]파일 다운로드2
5893감사합니...4/14/20232768오라클 OLEDB방식 접속 후 SELECT 'TEST' TEST_VALUE FROM DUAL의 값이 이상합니다. [1]
5892한무4/14/20233020C# 으로 백그라운드에서 워드를 실행하여 매크로 실행이 가능 할까요? [2]
5891리세4/14/20232850안녕하세요.C# 서버프로그램에서의 Mysql 쿼리문제(다중쿼리 실행)에 대해 문의드립니다. [2]
5890guest4/14/20233486C# 프리랜서로 돈 벌려면 성태님 책 마스터하면 되나요? [6]
5889전예찬4/14/20232709C# 파일 복사 관련 질문 드립니다. [3]
5888정경구4/12/20232982C# 첫 환경 세팅과 관련해서 [4]
5887HAN4/12/20232610안녕하세요 파이썬도 공유 가능 할까요? [1]
5886guest4/11/20232998필요한 어셈블리만 다운로드 및 재로딩하는 방법에 관하여 [2]
5885guest4/11/20232858c#으로 드림위버같은 거 만들어볼려는데요 [6]
5884궁금이4/11/20232751부모 클래스에서 예외 발생시 힙 영역에 할당 ? [2]
5883코딩초짜4/9/2023262410c언어 usleep 에 대해서 요 [2]
5882조은현4/7/20232702선생님 안녕하세요! wpf의 성능 개선에 대해서 질문드려요! [1]파일 다운로드1
5881guest4/6/20232769static method - <에러메시지 Extension method must be defined in a non-generic static class> [4]
1  [2]  3  4  5  6  7  8  9  10  11  12  13  14  15  ...