Microsoft MVP성태의 닷넷 이야기
글쓴 사람
롬메달 (pjh2104 at gmail.com)
홈페이지
첨부 파일
 

메인어플리케이션(1)에서 어셈블리를 LoadFrom이나 LoadFile로 객체를 얻어옵니다.(2)
그렇게 해서 사용되는 모듈에서는 또다른 외부 어셈블리(3)를 사용합니다.

하지만 2의 모듈에서는 3을 프로젝트 참조에 넣고 사용했었기 때문에 별 문제없이 빌드 됐었습니다.
문제는 1과 2,3이 다른 디렉토리에 있다는 겁니다. 1의 하위 디렉토리에 2,3의 어셈블리가 없고, 2와 3은 같은 디렉토리에 존재합니다.

또한 2의 모듈 내부의 다양한 클래스에서 3을 사용하고 멤버변수로 3의 특정 클래스를 사용하고 이렇게 커플링 되어 있어 LoadFrom이나 LoadFile로 객체를 얻어와서 사용할 수 없는 실정입니다.

프로그램 실행시에는 2의 내부에서 3의 클래스명이 나오는 메서드나 클래스를 들어가게 되면 여지없이 어셈블리참조에러로 인한 Exception이 발생합니다.

어셈블리 안의 appbase 경로는 메인어플리케이션으로 되어 있습니다.
appbase 경로를 추가로 줄수 있는지?(아니면 변경 할수 있는지? 물른 그럼 기존의 메인어플리케이션이 필요로 하는 어셈블리 객체를 얻지 못하겠지요)

아니면 어떻게 해야 2의 내부에서 사용되는 3의 모듈을 자유자재로 사용할 수 있을까요?

/////

코드상에서 문제가 되는 부분은 이렇습니다.
(2)의 모듈내의 코드에서 (3)의 클래스명이 나오는 메서드로 들어가는 순간 어셈블리 참조 Exception이 발생합니다.








[최초 등록일: ]
[최종 수정일: 2/14/2013]


비밀번호

댓글 작성자
 



2013-02-14 11시57분
[ryujh] 안녕하세요.
제가 이런 경우가 없어서 정확하게 말씀드릴 수가 없지만

마지막 질문에 대한 답변은 3모듈을 프로젝트에서 '강력한 이름' 을 만들고 빌드 후 GAC에 등록하는 것은 어떨지요?

그런데 현재 문제가 1모듈을 기준으로 참조하려하니 3모듈을 못찾아서 에러가 난다는 것인가요?
그러면 3모듈을 1모듈에도 복사해두는 것도 해보시길 바랍니다.

이상입니다.

[guest]
2013-02-15 12시48분
[롬메달] [ryujh]님 감사합니다.
3 모듈을 GAC에 등록할 정도의 의미는 아니라서, 프로그램에서 아주잠깐 쓰이는것 때문에 등록하는건 정책상 안맞다고 보고 아직 하지 않았구요.

3모듈을 1모듈에 복사해서 쓰면 상관은 없는데, 3 모듈은 2모듈과 함께 사용되는것으로 1 프로그램과는 독립적인 하나의 컴포넌트로 사용하려는게 정책이었습니다.

댓글 감사합니다. 일단 제가 질문한 답은 불가능한것으로 잠정적으로 보고 있습니다.

실행 어셈블리의 appbase에서도 벗어난 경우라서요.
[guest]
2013-02-15 03시11분
제가 테스트 해본 바에 의하면 LoadFile인 경우에는 2에서 3을 자동으로 로드하지 못하지만, LoadFrom의 경우에는 자동으로 됩니다. 제가 테스트 한 예제가 롬메달님의 상황과 뭔가 다른 부분이 있는 것 같은데요. 혹시, 위의 문제가 재현되는 간단한 솔루션/프로젝트를 보내주실 수 있나요?

참고로, 자동 로드가 안된다면 AppDomain.AssemblyLoad 이벤트를 구독한 후, Load 실패한 어셈블리를 수작업으로 로드해주는 것도 방법입니다.
정성태
2013-02-15 03시15분
[롬메달] 네......LoadFrom으로 다시 되더군요.....
일단 그렇게 처리하는걸로 잠정적으로 결론내렸습니다.
일단 LoadFile과 LoadFrom에 대한 차이와 이해를 해야할것 같아서 확인중이었습니다.
감사합니다...ㅠ
[guest]
2013-02-16 04시17분
[엄준일] assemblyBinding/probing probingParh 설정은 어떨까요?
[guest]
2013-02-16 05시17분
privatePath 는 반드시 EXE 파일이 위치한 (정확히는 AppDomain.CurrentDomain.BaseDirectory) 폴더의 하위만 지정할 수 있다는 단점이 있습니다. ^^
정성태
2013-02-16 05시25분
[롬메달] 네 그게 어셈블리의 appbase에 대한 내용인데 2,3 모듈은 어플리케이션의 같은 레벨의 다른 폴더에 위치해 있었기 때문에 appbase범위를 벗어났었거든요.
appbase 범위를 벗어나면 위치를 지정해 줘도 불가능하다고 나옵니다.
[guest]
2013-02-20 06시47분
[윤용한] 제가 사용한 방법은
runtime/assemblyBinding/probing/@privatePath에 하위경로 몇개 지정하고,
이 하위 경로들을 symbolic link로 만들어서 로드하면 됩니다.
symbolic link를 만드는 툴은
Junction (http://technet.microsoft.com/en-us/sysinternals/bb896768.aspx)
[guest]

... 46  47  48  49  50  51  52  53  54  55  56  57  58  59  [60]  ...
NoWriterDateCnt.TitleFile(s)
1113박진영12/28/201220642윈도우 2008 64비트 닷넷 오류 문의드립니다. [13]
1112이대근12/18/201214886[질문] odp.net 배포 관련 궁금한게 있어서 질문좀 드릴게요 [3]
1111나그넹!12/13/201211345안녕하세요. 파일전송에 관련해서 궁금한것좀 여쭈고싶네요. [1]
1110김동현12/11/201213360안녕하세요 닷넷 신입개발자입니다 Clickonce 질문좀 하겠습니다. [6]파일 다운로드1
1109김성우12/5/201210285WCF IIS 호스팅 관련하여 질문 드립니다. [1]
1123윤용한3/13/201310459    답변글 [답변]: WCF IIS 호스팅 관련하여 질문 드립니다.
1107우라미윰11/22/201217255안녕하세요. RSA공개키 알고리즘에 나와있는 글을 보고 응용을 해야 하는데 막히는 부분이 있어서 질문드립니다. [3]파일 다운로드1
1106초급11/21/201210909WCF Server 인증서 및 Client 인증서 문의 [1]
1104hon11/17/201210503VS2008에서 디버그/릴리즈 환경중에 디버그 환경의 빌드시 배열의 자동 초기화 라는 것에 대해서 궁금합니다. [3]
1102최년호11/15/201213143[탭 브라우저의 윈도우 핸들 구하기] 예제에서 활성화 방법 [1]
1100박진영11/7/201218785[긴급] 코드 액세스 보안 정책(CASPOL.exe) 설정해도 SmartClient 보안에러가 발생합니다. [6]
1099Hyey...10/22/201212943php에서 c file compile [4]
1095이지은10/8/201230109중단점이 현재 적중되지 않았습니다 [3]
1094고민남10/6/201210533NScreen 에 대해 어떻게 생각하십니까? [1]
1093이지수10/6/20129852vbs [1]
1092김성수9/20/201211109안녕하세요? MS Windows server 2008 R2 에서 IIS7 의 SSL 설정시에 에러 해결좀 도와주세요 [1]
1089한상욱9/13/201211037azure에 관한 질문입니다. [1]
1088김영대9/12/201213200DirectX.AudioVideoPlayBack 참조하여 wav 재생기를 제작하여 SmartClient 를 이용하여 aspx 페이지에 Embed 하는 과정의 질문 사항입니다. [2]
1087한우주9/10/201213904SSL 모든 웹페이지에 적용해야하나요? [2]
1086한우주9/4/201212101SSL 인증서 범용으로 사용하기 [3]
1085한우주9/4/201210490개발환경구성 18.3.1 에 대한 문의 [2]파일 다운로드1
1084김종하9/3/201211496team foundation express 2012에서 새 프로젝트 생성... [3]
1082김대경8/23/201210446windows2008 에서 ActiveX 사용 시 문제점. [3]
1091김대경9/20/201210474    답변글 [답변]: windows2008 에서 ActiveX 사용 시 문제점. [2]파일 다운로드1
1081Seon...8/20/201212803WCF 파일 업,다운로드 문제 [2]
1080배동선8/13/201211600정품 라이센스 인증 개발에 대해 조언을 구하고 싶습니다 [4]
... 46  47  48  49  50  51  52  53  54  55  56  57  58  59  [60]  ...