Microsoft MVP성태의 닷넷 이야기
C# DB connection string 보호 방법에 대하여 [링크 복사], [링크+제목 복사]
조회: 2099
글쓴 사람
ogosengi
홈페이지
첨부 파일
 
요즘 디컴파일러가 워낙 잘 나와서 그런지 C#응용프로그램을 디컴파일 하면
재컴파일이 가능하게 소스가 나와버리는데요.
응용프로그램에서 DB connection string을 보호할 방법이 있을까요?

DB는 원격지에 있어서 SQL 인증방식으로 접속 해야 합니다.

클라이언트 소스에 DB connection string암호화 하여 저장 하여도

프로그램을 디컴파일 한 후 소스 수준에서 디버깅 하면 connection string이 노출 될 것 같은데요.

============
음 깔끔하게 .... "DB connection string을 보호 할 방법은 없다" 라고 하시면...

C/S 버전의 프로그램을 구현 할 시 DB에 접근 하는 좋은 방안이 있으면 소개해주시면 감사하겠습니다.

"WebService 방식으로 구현 하라~" 든지.....

=====================
작성자 정보에 메일 주소를 적었었는데... 노출이 되는 것 같아서 글 수정 하고 삭제 하였습니다.


[연관 글]


donaricano-btn



[최초 등록일: ]
[최종 수정일: 5/26/2020


비밀번호

댓글 쓴 사람
 



2020-05-26 01시38분
답을 이미 아시네요. ^^ 그러니까, 근래 들어 유명해진 웹 브라우저의 SPA(Single Page Application) 유형을 생각해 보시면 됩니다.

SPA 안에 있는 자바 스크립트에서 서버 측의 DB를 직접 접근하지 않고 Web API를 사용하는 것처럼, C# 응용 프로그램도 그런 식으로 접근하시면 됩니다.
정성태
2020-05-26 01시52분
[ogosengi] 흑.. 넵 감사합니다. 혹시 방법이 없을까 하고 몇날 몇일을 여기저기 검색 해봤는데.... 속이 후련 하네요.
디컴파일이 가능한 구조에서는 ConfigurationManager를 통한 config파일의 암호화 등은 다 부질없는 행동이네요. ㅠㅠ
[손님]

1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
5482질문4/13/2021496WPF를 위한 MVVM toolkit 선택과 관련한 문의드립니다. [4]
5480한예지4/5/2021695GetHashCode 질문있습니다! [2]
5479한예지4/4/2021509Equals를 닷넷에서 어떻게 구현했는지 보고 싶을 떄는 어떻게 해야 될까요? [2]
5478갑자기C#3/23/2021957C# Winform에서 TextBox없이 입력 받을 수 있나요? [7]
5477달팽이3/18/2021498c# 도형을 그린후 편집하는 방법이 궁금합니다. [2]파일 다운로드1
5475dimohy3/2/2021678POH가 .NET 5에 추가된 것으로 알고 있습니다. POH가 유용한 경우는 어떤 경우가 있을까요? [1]
5474Syong2/26/2021583사용자 지정 컨트롤 생성시 Invalidate, Update, Refresh의 차이점 [2]
5473한예지2/25/2021613디자인 타임이 뭔지 궁금합니다!! [5]
5472dimohy2/24/2021543등록하지 않고 ocx를 사용하는 `키움`관련 포스팅을 따라가다 질문드립니다. [2]
5471남산2/21/2021706MarshalDirectiveException 에 대한 질문입니다. [1]
5470한예지2/7/2021761yield 질문있습니다!! [2]
5469유호성2/6/2021628Parallel + Task.Run 동시 실행 환경에서 간헐적으로 Task.Run()에서 null이 리턴됩니다. [3]파일 다운로드1
5467heroho2/4/2021656실행 환경에 따른 Thread.Sleep 딜레이 차이 질문 [8]
5466pr1/29/2021736c# winform load시 작업표시줄에 뜨지 않는 현상을 겪으신적이 있으신가요? [4]파일 다운로드1
5465영귤1/28/2021602두 번째 await 부터는 스레드 개수만 늘어나는 것이 아닌가요 [1]
5464민우1/26/2021530C# 빌드시 코드 치환되는걸 확인하는 방법 문의 [2]
5463한예지1/24/2021744Parameters.AddWithValue 와 Parameters.Add 의 차이점이 궁금합니다. [2]
5462C#초보1/22/2021768사용자 정의 메시지 전달이 가능한가요? [2]
5461한예지1/22/2021771AsEnumerable() 메서드 질문 있습니다! [2]
5459한예지1/21/2021783typeof와 GetType의 차이점 질문있습니다. [2]
5458진우1/20/2021936C# DataTable 에 SQL 쿼리문을 실행하는 방법 문의 (LINQ 사용하지 않고) [6]
5456성민1/17/202110329.0 출간 계획이 있으신가요? [2]
5455한예지1/16/2021887교재 194페이지 콜백메서드 질문 있습니다! [5]
5454한예지1/15/2021879교재 208쪽 질문....있습니다... [3]
5453안녕하세요1/15/20211091C# dll 파일을 C++에서 사용 시 memory leak 문제 [2]파일 다운로드1
5452예지1/15/2021950var를 사용할 수 없는 이유가 궁금합니다! [3]
1  2  [3]  4  5  6  7  8  9  10  11  12  13  14  15  ...