|
원본 : http://www.themssforum.com/Drivers/File-System-104809/
Will not work on x64 Vista/2008, also note that NtReadFile hook will not catch paging IO. - Maxim Shatskih, Windows DDK MVP Using a SSDT hook driver for this is incredibly irresponsible. First as Max pointed out, it will not work for X64, and it will not catch paging I/O. Also, getting these right is harder than one thinks, and is likely to destabilize the system. Also, the driver will immediately be flagged as MALWARE. Following such a path for file operations that are easily catchable with approved ways, is beyond stupid. - Don Burn (MVP, Windows DDK) This can be done with a mini-filter and Microsoft provides one FileSpy that meets most of the OP's needs. Get the WDK and take a look. I don't think SSDT hook driver look like malware. Too many HIPS software are using this technology. Mini-filter driver maybe is the best way to done this case. And some not all of these are special cased in the MALWARE detection. Bottom lime is you cannot hook and unhook safely and it is a damaging practice that hopefully Microsoft will block in 32 bit someday as well as 64 bit. 결국은 미니 필터 드라이버, WDK에 새로 추가된 미니필터 드라이버를 공부해 보도록 해야겠다. 자료가 별로 없는게 단점이지만 WDK에 minifilter예제들이 있으므로 그걸참고로 해야할듯 -ㅁ-;
Adobe AIR가 SQLite및 File 함수를 지원하지만 정작 파일 실행은 하지 못한다.
예제로 배우는 Flex3 책에는 AIRConnect라는 AIR와 MFC를 연동한 부분이 있지만, 그 프로그램은 같은 파일을 반복적으로 쓰고, 또 검사해야하야 하기때문에, 빠른 응답을 기대할 수 없어서 소켓을 이용하여 Win32 어플리케이션과 통신을 하는 방법을 이용했다. 서버가 Socket Accepct를 하는 부분은 다음과 같다. Win32while(true) { 여기서는 AIR에서 파일명을 던지면, Win32어플리케이션에서 무조건 실행을 시키도록 했다. 전체 파일은 첨부파일을 참고면 된다. Win32 어플리케이션 (여기서는 WTL이용) 에서 서버소켓을 생성하고 AIR에서 이제 이벤트가 발생할때마다 Win32어플리케이션으로 통지를 한다. AIRvar socket:Socket = new flash.net.Socket(); AIR 에서는 소켓으로 로컬로 접속하여 메세지를 보내고 결과값을 받는다. 여기서는 ShellExecute의 리턴값을 받는다. 에러처리를 AIR에서 하기위해서 이다. ( ShellExecute가 32보다 작은값을 리턴하면 에러이다. ) readMultiByte 일반 MultiByte String을 읽어와서 UTF-8로 변경해서 리턴한다. 이함수는 읽어올 데이터의 길이를 정해주어야 하는데, 틀릴경우 익셉션이 발생하므로 미리 프로토콜을 지정하는 것이 좋다. AirSocketProxy.zip ZwDeleteFIle(NtDeleteFile) 이라는 함수가 있어서 파일 삭제가 될때 이 ZwDeleteFile이라는 함수가 불리어 질것이라고 예상을 하여 ZwDeleteFIle함수를 후킹하였으나 DbgPrint로 뿌리니 아무런 반응이 없어서, 인터넷을 찾는 도중 원인을 알아냈다. NTSTATUS NewZwSetInformationFile( 이렇게 처리하면 된다.
|
외부 링크
카테고리
최근 등록된 덧글
c_user / 네 방문해 주셔..
by 꿍스 at 07/20 좋은 자료 감사합니다. .. by c_user at 07/13 @dylan / 아 저도 결국 .. by 꿍스 at 05/01 하 전 요즘 기말고사 기.. by dylan at 04/28 미용실이 있는 치과라.... by 미친병아리 at 03/17 라이프 로그
![]() 검색 마케팅 이야기 ![]() 그들에게 국민은 없다 ![]() 어느 인문학자의 문화로 읽는 중국 ![]() 검색2.0 : 발견의 진화 ![]() 에리히 프롬과의 대화 ![]() 산다는 것은 사랑하는 것이다 ![]() 철학, 역사를 만나다 ![]() 철학 콘서트 ![]() 소유냐 존재냐 ![]() 유쾌한 팝콘 경쟁학 ![]() 닛폰 리포트 ![]() 영국, 바꾸지 않아도 행복한 나라 ![]() 미국의 종말에 관한 짧은 에세이 ![]() 미국의 엔진, 전쟁과 시장 ![]() 김병모의 고고학 여행 2 ![]() 김병모의 고고학 여행 1 이전 블로그
이글루 링크
|