Microsoft MVP성태의 닷넷 이야기
글쓴 사람
박평옥 (buruss at yahoo.co.kr)
홈페이지
첨부 파일
 

안녕하세요? 네티모의 박평옥이라고 합니다.

기억나실지 모르겠지만, 전에 바로가 툴바라고 제작해 주셨었죠^^. 제가 이번에 이 툴바를 비스타까지 지원되도록 VB6으로 다시 개발하고 있는데요, 정성태님의 코드를 많이 참고하고 있답니다.^^

하여튼, 문제는 제목에 있는 증상인데요, 좋은 아이디어 있으신지 싶어서 이렇게 조언 부탁드리고자 합니다.

테스트 환경은 비스타 32bit SP1, IE7, IE 보호 모드 활성화, UAC활성화 상태입니다. 바탕화면의 기본 Internet Explorer 아이콘을 실행하면 위 증상이 없는데요, URL 단축아이콘을 실행하는 경우에는 iexplore.exe 프로세스가 잠깐 두 개가 뜹니다. 그리고 첫번째 프로세스는 두번째 프로세스가 실행된 직후 바로 종료가 되어서 사용자는 하나만 실행되는 것으로 착각하게 됩니다.

하지만, 내부적으로는 모든 BHO나 툴바들이 각 iexplore.exe 프로세스마다 다 로드가 되더라구요. 이게 다른 툴바들에게는 문제가 되지 않겠지만, 저희 툴바에는 웹브라우저가 내장되어 있어서 로딩하자마자 바로 Navigate2 메서드를 호출하는데, 이것 때문에 첫번째 프로세스가 종료되지 못하고 화면에는 보이지 않는 상태로 좀비 상태가 되어 버리는 증상이 발생합니다. (Navigate2 메서드 호출하지 않으면 정상 동작합니다.)

그래서 iexplore.exe 가 작업관리자 프로세스 탭에 두 개 떠있게 되구요, 또한 화면에 보이는 두번째 프로세스의 브라우저에도 이상하게 탭이 두 개 표시되고, 이 브라우저를 종료시켜도 처음 실행되었던 프로세스는 여전히 메모리에 남게 됩니다.

IE 보호모드를 끄거나, UAC를 끄면 이 증상이 없는 것으로 보아서 Microsoft에서 비스타 IE7의 보안을 강화하면서 의도적으로 이렇게 동작시키는 것 같은데요, 비스타의 동작 방식을 프로그램적으로 변경하는 것은 가능성이 희박해 보이고, 제 생각에는 툴바 내부에서 자신이 첫번째 프로세스에서 로드되는 것인지, 아니면 두번째 프로세스에서 로드되는 것인지를 판단할 수만 있다면 첫번째 프로세스에서 로드되는 툴바에서는 Navigate2 메서드를 호출하지 않으면 되지 않을까 생각했거든요.

그런데, 아무리 두 프로세스를 비교해봐도 차이점이 보이지 않아서 고민하고 있습니다. 설명이 잘 된 건지 모르겠습니다만, 하여튼 뭔가 두 프로세스간의 차이가 있을 거라고 생각이 드네요. 여기에 대해서 어떤 의견이든지, 간단한 힌트라도 알려주시면 무척 고맙겠습니다.

아무튼 항상 건강하시고 하시는 일 번창하시기 바랍니다. 수고하세요.~~








[최초 등록일: ]
[최종 수정일: 3/18/2009]


비밀번호

댓글 작성자
 



2009-03-19 10시12분
안녕하세요. 기억나지요. ^^ 당연히.

이 부분은 저도 한번 살펴봐야겠는데요.
저도 몇가지 테스트를 해보고 나서 답변을 다시 드리겠습니다.

그 전에, 제가 다음과 같이 테스트 해보면 되는 건가요?

1. 바탕화면에 "http://msdn.microsoft.com" 에 대한 URL 바로가기 아이콘을 생성한다.
2. BHO를 만들고 SetSite메서드에서 메시지 박스를 띄워본다.
3. 1번에 생성한 바로가기를 더블 클릭해서 메시지 박스가 2번 뜨는지 확인한다.
4. 만약 2번이 뜨는 것이 확인되면, 한번만 뜨는 방법이 뭔지 찾아낸다.
kevin25
2009-03-21 05시55분
[박평옥] ㅎㅎ 기억하고 계시네요.^^
네, 말씀하신 순서가 맞습니다. UAC와 보호모드도 켜져 있는지 꼭 확인하세요.
결과에 상관없이 답변 주시면 감사하겠습니다.^^
[guest]

... 91  92  93  94  95  [96]  97 
NoWriterDateCnt.TitleFile(s)
57정성태9/23/200413258    답변글 [답변]: ATL을 이용해서 함수를 하나 만들었습니다.
61엄길웅10/1/200411893        답변글 [답변]: [답변]: ATL을 이용해서 함수를 하나 만들었습니다.
54차광석8/26/200412121잘 지내시죠?
55정성태8/27/200411240    답변글 [답변]: 잘 지내시죠?
52김명원8/3/200412073질문이요..
53정성태8/19/200411942    답변글 [답변]: 질문이요..
50김상표7/5/200411757질문요...
51정성태7/6/200411622    답변글 [답변]: 질문요...
45송야5/29/200411761웹페이지 자동로그인..
46정성태5/31/200412631    답변글 [답변]: 웹페이지 자동로그인..
44반데라이차5/26/200411781안녕하세요~저 오크에요~~^^* [1]
43이윤복4/22/200410614윤보기 입니다.
48정성태5/31/200411905    답변글 [답변]: 윤보기 입니다.
40김대웅2/26/200412925메일 드렸는데.. 읽어보셨는지 모르겠네요.. 많이 바쁘신것 같아요..
41정성태2/29/200411887    답변글 [답변]: 메일 드렸는데.. 읽어보셨는지 모르겠네요.. 많이 바쁘신것 같아요..
42정성태3/6/200413113    답변글 [답변]: 메일로 답변을 드렸는데. 메일이 자꾸 반송되네요. 여기서 답변드립니다.
38문우영1/19/200411469ㅋㅋ 한글 아이디도 되는군요.!!
39정성태1/26/200412068    답변글 [답변]: 다행이네요. ^^;
33신종화1/9/200412892성태님 오랬만이군요 ^^ 새해복 많이 받으세요
35정성태1/17/200411015    답변글 [답변]: 성태님 오랬만이군요 ^^ 새해복 많이 받으세요
32김기영1/5/200411779질문인데요... 웹브라우저로 text를 전송할 수 있을까요??
34정성태1/17/200411305    답변글 [답변]: 질문인데요... 웹브라우저로 text를 전송할 수 있을까요??
28박소연10/30/200315271c언어를 이용한 가계부 프로그램
31정성태12/17/200316692    답변글 [답변]: c언어를 이용한 가계부 프로그램
27임영택9/17/200311858atl com에서 Window Handle 구하고 싶은데(바쁘시더라도 꼭 답변 해주세요!!)
30정성태12/17/200312303    답변글 [답변]: atl com에서 Window Handle 구하고 싶은데(바쁘시더라도 꼭 답변 해주세요!!)
... 91  92  93  94  95  [96]  97