1. 개요 프로젝트의 필요로 인해 VC, DLL 및 ActiveX 컨트롤을 배우고 연구하기 시작했습니다. 온라인에서 많은 정보를 찾았지만 사용할 수 있는 정보가 없거나 예제가 없었습니다. 그것은 이해되고 실행될 수 있습니다. 아니요, 그냥 스스로 조사해 보세요. 열심히 노력하면 결국 성공할 것입니다. 하하, 이제 제가 배운 내용을 요약하여 필요한 사람들에게 바쳤습니다. DLL(동적 링크 라이브러리): WIN32 DLL과 MFC DLL로 구분 ActiveX: ATL 컨트롤과 MFC 컨트롤로 구분(DLL이기도 함) WEB: JAVASCRIPT 호출-> 추가 작업을 완료하고 페이지에 표시되는 값을 반환합니다. 2. 개발(VS2008) 1. DLL 라이브러리 작성: 파일 -> 새로 만들기 -> WIN32 콘솔 -> 프로젝트 이름 입력 -> DLL 선택 -> 프로젝트 비우기 -"마치다. (1) 솔루션 패널에 헤더 파일 testdll.h를 추가합니다. 내용:
return( a b ) } DECLDIR void Function( void ) { std::cout < ;< "DLL 호출됨!" << } }
(3) 선택사항. 새 WIN32 콘솔 클래스를 만들고 이 DLL을 테스트합니다. 파일 -> 새로 만들기 -> WIN32 콘솔 -> 프로젝트 이름 입력 -> 콘솔 프로그램 선택 -> 프로젝트 비우기 -> 완료. 솔루션 패널에서 구현 파일 loaddll.cpp 콘텐츠를 추가합니다.
// L은 프로젝트의 문자 집합과 일치해야 하는 유니코드 문자 집합을 사용한다는 의미입니다. HINSTANCE hInstLibrary = LoadLibrary(L"E:\Project\VS\LoadDll\Release\TestDll.dll"); if (hInstLibrary == NULL) { cout <<" Dll 로딩 [실패]."<< endl; FreeLibrary(hInstLibrary); }else{ cout <<"Dll 로딩 [성공]."<< endl; } _AddFunc = (AddFunc)GetProcAddress(hInstLibrary, "추가"); _FunctionFunc = (FunctionFunc)GetProcAddress(hInstLibrary, "Function") if ((_AddFunc == NULL) || (_FunctionFunc == NULL)) { FreeLibrary(hInstLibrary);//Release }else{ cout <<"---DLL 함수 가져오기 [OK]---. "<< endl; } cout << _AddFunc(1, 1) << endl; // 호출 시작 _FunctionFunc(); // cin.get (); // 프로그램이 깜박이지 않도록 포커스를 얻습니다. FreeLibrary(hInstLibrary);//호출 후 메모리를 해제합니다. 반환(1) }
2. ActiveX 컨트롤 구현: 여기에서는 MFC ActiveX 대신 ATL 컨트롤 구현을 선택합니다. 파일 -> 새로 만들기 -> ATL 프로젝트 -> 프로젝트 이름("FROMYANTAI") 입력 -> 동적 링크 라이브러리(DLL) 선택 -> 완료. 완료되면 오른쪽의 "솔루션 탐색기"에 헤더 H 파일과 CPP 구현 파일이 많이 생성됩니다. 이는 기본값이므로 수정할 필요가 없습니다. (1) ALT 단순 개체 추가: 프로젝트 이름(방금 지정한 이름)을 마우스로 클릭하고 - "클래스 추가 -" ATL 단순 개체를 선택합니다. 다음 단계에서는 이름을 지정합니다: "ytiicrj" -> 다음 단계: 다른 모든 항목은 변경하지 않고 그대로 두고 지원에서 "연결 지점" 및 "IE 개체 지원"을 선택합니다 -> 완료. 다음 단계는 웹 페이지에서 호출할 수 있도록 "ytiicrj"에 메서드를 추가하는 것입니다. "Class View"(회색 키 아이콘 있음)에서 "iytiicrj"를 선택하고 마우스 오른쪽 버튼을 클릭한 후 추가 -> 메서드 추가를 선택합니다. 메서드 이름을 "GetContent"로 지정하고, 매개변수 속성에 대해 IN을 선택하고, 매개변수 유형에 대해 LONG을 선택하고, 매개변수 이름을 A로 선택하고, 계속해서 매개변수 속성에 대해 IN을 선택하고, 매개변수 유형에 대해 LONG을 선택하고, 매개변수 이름 B를 선택합니다. OUT 및 매개변수 속성 RETVAL을 선택하고 매개변수 유형 및 매개변수 이름 출력에 대해 LONG*을 선택합니다. –》추가---》완료하려면 클릭하세요. 이것은 ytiicrj.H 헤더 파일에 하나(마지막 줄)를 추가합니다: STDMETHOD(GetContent)(LONG a, LONG b, LONG* out) 그리고 ytiicrj.CPP 파일에 추가되었습니다. 구현 클래스:
#pragma Once #include " resources.h " // 기본 기호 #include // 추가 #include "AtlActiveX_i.h" #include "_ICaluNumCtrlEvents_CP.h" #if 정의됨(_WIN32_WCE ) &&! ATL이 단일 스레드 개체 구현을 지원하도록 하고 단일 스레드 COM 개체 구현의 사용을 허용합니다. 이 모델이 유일한 스레딩 모델이기 때문에 rgs 파일의 스레딩 모델이 "무료"로 설정되었습니다. DCOM이 아닌 Windows CE 플랫폼에서 지원됩니다. " #endif // ytiicrj class ATL_NO_VTABLE Cytiicrj: //줄 추가: 보안 프롬프트가 제거됩니다. -- 브라우저 호출을 실행할 때, 보안 질문은 표시되지 않습니다. 공용 IObjectSafetyImpl, 공용 IConnectionPointContainerImpl, 공용 CProxy_ICaluNumCtrlEvents 공용 IObjectWith SiteImpl, 공개 IDispatchImpl{ public: //다음 세 줄의 구현 정의입니다. typedef int (*AddFunc)(int,int); //DLL ADD 메소드에 해당하는 유형 정의. Func는 사용자 정의되어 원하는 대로 작성할 수 있습니다. HINSTANCE hInstLibrary; AddFunc _AddFunc; //클래스 매핑 Cytiicrj() { //계산을 위해 DLL 호출을 시작합니다. hInstLibrary = LoadLibrary(L"TestDll.dll");//작성된 DLL 파일을 이 프로젝트에서 생성된 디렉터리에 넣습니다 if (hInstLibrary == NULL) { FreeLibrary( hInstLibrary) ;//리소스 릴리스 }else{ } //메서드를 호출하고 메서드 핸들을 반환합니다. _AddFunc = (AddFunc)GetProcAddress(hInstLibrary, "추가"); } DECLARE_REGISTRY_RESOURCEID(IDR_CALUNUMCTRL) BEGIN_COM_MAP(Cytiicrj) COM_INTERFACE_ENTRY(ICaluNumCtrl) COM _INTERFACE_ENTRY(IDispatch) COM_INTERFACE_ENTRY(IConnectionPointContainer) COM_INTERFACE_ENTRY(IObjectWithSite) //줄 추가: 보안 프롬프트를 비활성화합니다. -- 브라우저 호출을 실행할 때 보안 질문이 표시되지 않습니다. COM_INTERFACE_ENTRY(IObjectSafety) END_COM_MAP() BEGIN_CONNECTION_POINT_MAP(Cytiicrj) CONNECTION_POINT_ENTRY(__uuidof(_ICaluNumCtrlEvents)) END_CONNECTION_POINT_MAP() DE CLARE_PROTECT_FINAL_CONSTRUCT() HRESULT FinalConstruct() { return S_OK; } void FinalRelease() { FreeLibrary(hInstLibrary) } public: STDMETHOD(GetContent)(LONG a, LONG b, LONG* 출력) } OBJECT_ENTRY_AUTO(__uuidof(CaluNumCtrl), Cytiicrj)
STDMETHODIMP CCaluNumCtrl::GetContent(LONG a, LONG b, LONG* out) { // TODO: 여기에 구현 코드 추가 int sum = this-> ;_AddFunc(static_cast(a),static_cast(b)) *out = static_cast(sum) this->_AtlFinalRelease(); 🎜>return S_OK ; }
(4) DLL 생성: 이 단계는 매우 간단합니다. 릴리스 모드를 선택하고 생성할 프로젝트를 클릭합니다. REG32 등록을 선택한 다음 선택하세요). 이는 Release 디렉터리에 많은 파일을 생성하며 우리가 원하는 것은 DLL 파일입니다. 3. DLL 및 ATL ActiveX 컨트롤 DLL은 CAB 파일로 패키지됩니다. 예: test.CAB를 생성한 후 웹 페이지에 다운로드 및 설치 메시지가 표시됩니다. (1) 먼저 setup.inf 파일을 정의합니다. 이는 다운로드한 콘텐츠와 대상 디렉터리, 버전 번호 및 해당 DLL 파일을 설명합니다. 내 콘텐츠는 다음과 같습니다(이름을 적절하게 수정하세요):
[버전] ; 버전 서명(NT 및 Win95 모두 동일) 제거하지 않음 signature="$CHICAGO$" AdvancedINF=2.0 [추가.코드] AtlActiveX.dll=AtlActiveX.dll TestDll.dll=TestDll.dll setup.inf=setup.inf [install.files] AtlActiveX.dll =AtlActiveX.dll TestDll.dll=TestDll.dll setup.inf=setup.inf [AtlActiveX.dll] clsid={4AE870B5-C7FB-4171-A47E-7F57AFD86F67} file-win32-x86 =thiscab FileVersion=1,0,0,1 DestDir=11 RegisterServer=yes [TestDll.dll] file-win32-x86=thiscab DestDir=11 FileVersion=1,0,0,1 RegisterServer=yes [setup.inf] file=thiscab [RegisterFiles] %AtlActiveX. dll ; INF 파일 끝
(2) 리소스 통합: setup.inf 파일을 포함하여 사용된 모든 DLL을 하나의 디렉터리에 넣은 후 다음을 실행합니다. IExpress 명령을 생성합니다. CAB 패키지. 실행 후 첫 번째, 다음, 세 번째 선택, 다음, 파일 추가(DLL 및 INF 파일 선택), 출력 디렉터리 선택 및 CAB 파일 이름 생성, 두 번째 옵션 선택, 다음 단계, 두 번째 옵션을 선택한 다음 확인을 선택하세요. 그러면 CAB 파일이 생성됩니다. (3) WEB 페이지는 ActiveX 컨트롤을 호출하여 추가 작업을 수행합니다. test.htm 웹 페이지를 작성하고 CAB 파일을 디렉터리에 넣습니다.
입력 유형="버튼" 값="renjie" id ="btnOK" onclick="doTest();">
설명: codeBase="test .CAB#version=9,0,0,1" codeBase는 파일의 상대 또는 절대 경로를 나타냅니다. 이 숫자가 버전 번호와 동일한 경우. INF 파일의 버전 번호를 변경하면 페이지가 두 번째로 다운로드되지 않습니다. 그렇지 않으면 매번 다운로드됩니다. CLSID는 ActiveX 프로젝트에서 생성된 일련 번호로, 프로젝트의 *.rgs 파일에서 찾을 수 있습니다. 알겠습니다. 모든 단계가 완료되었습니다. 이제 test.htm을 실행하면 ActiveX 컨트롤이 표시되고 이를 허용하도록 선택한 다음 추가 작업을 호출할 수 있습니다. 이것은 단지 간단한 예일 뿐이며 DLL에서 자신만의 애플리케이션을 구현할 수 있습니다.