亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? iis.cpp

?? vc環境下的pgp源碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
//____________________________________________________________________________
//	Copyright (C) 1998 Network Associates Inc. and affiliated companies.
//	All rights reserved.
//	
//	iis.c -- iis administration functions.
//  Author: Philip Nathan
//
//Id: iis.c,v 1.1 1999/02/10 00:06:08 philipn Exp $_______________________
//IIS

#define INITGUID 
#define STATUS_STRING_SIZE 2048

#include <stdio.h>
#include <windows.h>
#include "CrtVDir.h"
#include <iostream.h>
#include <winnt.h>
#include <ks.h>
#include "iadmw.h"							// COM Interface header 
#include "iiscnfg.h"						// MD_ & IIS_MD_ #defines 
#include "iwamreg.h"
#include "atlBase.h"						// ATL support for smart pointers

#include "install.h"
#include "prototype.h"


#if PGPCERTD
	//IIS admin 
	CComPtr <IMSAdminBase> g_spAdminBase;  
	CComPtr <IWamAdmin> g_spWamAdmin;  

	char*	Title = "IIS Configuration";
	int		g_nOperation;						// CD == 1, RD == 2, CA == 3, RA == 4
	DWORD	g_dwPermissions = 1, g_dwSite = 1;	// default to "read" permission and site 1
	DWORD	g_dwAuthorization = 5;				//default to MD_AUTH_ANONYMOUS | MD_AUTH_NT
	BOOL	g_bInProc = true;
	BOOL	g_CD = true;
	LPSTR	lpstrPath;
	char*	pName;


	int CreateIISVDir(int arg)
	{
		//getting path
		#define PATHTOCERTDKEY "SOFTWARE\\Network Associates\\PGP Certificate Server"
		LPSTR lpstrCertPath;
		LPSTR lpstrCgiPath;
		LPSTR lpstrDocPath;
		DWORD dwType;
		DWORD dwSize;
		LPBYTE pValue		= NULL;
		HKEY hMainKey		= HKEY_LOCAL_MACHINE;
		HKEY hOpenKey		= NULL;
		char* Name = "AppPath";	
		BOOL bNewDefaultFile = 0;
		char* NewDefaultFile = "";
		BOOL bSetCustomErr = 0;

		//Get usage
		if	((1 != arg)	&&
			(0 != arg))		
		{
			MessageBox (GetFocus(), "Usage error: use either CD or RD\n"
									"for CommandLine.\n\n"
									"1 = Create Directory\n"
									"0 = Remove Directory\n", Title, 0 | MB_ICONERROR);
			return 0;
		}

		if(1 == arg)
		{
			g_CD = true;
		}
		if(0 == arg)
		{
			g_CD = false;
		}


		CHAR szStatus[STATUS_STRING_SIZE];
		HRESULT hres = S_OK;

		// initialize COM
		hres = CoInitialize(NULL);

		if (FAILED(hres))
		{
			wsprintf(szStatus, "CoInitializeEx failed: %d (0x%08x)", hres, hres);
			//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			return 0;
		}

		// get a pointer to the IIS Admin Base Object
		hres = CoCreateInstance(CLSID_MSAdminBase, NULL, CLSCTX_ALL, 
				IID_IMSAdminBase, (void **) &g_spAdminBase);  

		if (FAILED(hres))  
		{
			wsprintf(szStatus, "CoCreateInstance failed for CLSID_MSAdminBase: %d (0x%08x)", hres, hres);
			//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			CoUninitialize();
			return 0;  
		}

		// get a pointer to the IWamAdmin Object
		hres = CoCreateInstance(CLSID_WamAdmin, NULL, CLSCTX_ALL, 
				IID_IWamAdmin, (void **) &g_spWamAdmin);  

		if (FAILED(hres))  
		{
			wsprintf(szStatus, "CoCreateInstance failed for CLSID_WamAdmin: %d (0x%08x)", hres, hres);
			//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			g_spAdminBase.Release();
			CoUninitialize();
			return 0;  
		}

		if(g_CD)
		{
			if (RegOpenKeyEx(hMainKey, PATHTOCERTDKEY, 0, KEY_ALL_ACCESS, &hOpenKey)
							== ERROR_SUCCESS)
			{
				lpstrCertPath = (char*)malloc (_MAX_PATH);
				lpstrCgiPath = (char*)malloc (_MAX_PATH);
				lpstrDocPath = (char*)malloc (_MAX_PATH);

				dwSize = _MAX_PATH;
				pValue = (LPBYTE) calloc(sizeof(BYTE), (DWORD)dwSize);
				
				RegQueryValueEx(hOpenKey, Name, NULL, &dwType, pValue, &dwSize);
				RegCloseKey (hOpenKey);	
			}
			else
			{
				MessageBox (GetFocus(), "Unable to open certd key.", Title, 0 | MB_ICONERROR);
				return 0;
			}

			memcpy (lpstrCertPath, pValue, dwSize);
			memcpy (lpstrCgiPath, pValue, dwSize);
			memcpy (lpstrDocPath, pValue, dwSize);

			strcat (lpstrCertPath, "\\Web\\HTDOCS");
			strcat (lpstrCgiPath, "\\Web\\cgi-bin");
			strcat (lpstrDocPath, "\\Documentation");

			// create the virtual root
			//g_dwPermissions set to default 1
			g_dwAuthorization = 4;
			bSetCustomErr = 1;
			if(!CreateVirtualRoot("certserver", lpstrCertPath, g_dwPermissions, g_dwSite, szStatus
								,bNewDefaultFile, NewDefaultFile, bSetCustomErr))
				MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);

			// create the virtual root
			bSetCustomErr = 0;
			if(!CreateVirtualRoot("certserver/docs", lpstrDocPath, g_dwPermissions, g_dwSite, szStatus
								,bNewDefaultFile, NewDefaultFile, bSetCustomErr))
				MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);

			// create the virtual root
			//g_dwPermissions reset to 4 for execute permission
			g_dwPermissions = 4;
			g_dwAuthorization =4;
			if(!CreateVirtualRoot("certserver/cgi-bin", lpstrCgiPath, g_dwPermissions, g_dwSite, szStatus
								,bNewDefaultFile, NewDefaultFile, bSetCustomErr))
				MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);

			// create the virtual root
			g_dwAuthorization = 0;
			g_dwPermissions = 0;
			if(!CreateVirtualRoot("pks", lpstrCgiPath, g_dwPermissions, g_dwSite, szStatus
								,bNewDefaultFile, NewDefaultFile, bSetCustomErr))
				MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);

			// create the virtual root
			//g_dwPermissions reset to 4 for execute permission
			bNewDefaultFile = 1;
			NewDefaultFile = "Add.exe";
			g_dwPermissions = 4;
			g_dwAuthorization = 1;
			if(!CreateVirtualRoot("pks/Add", lpstrCgiPath, g_dwPermissions, g_dwSite, szStatus
								,bNewDefaultFile, NewDefaultFile, bSetCustomErr))
				MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);

			// create the virtual root
			bNewDefaultFile = 1;
			NewDefaultFile = "Lookup.exe";
			g_dwPermissions = 4;
			g_dwAuthorization = 1;
			if(!CreateVirtualRoot("pks/Lookup", lpstrCgiPath, g_dwPermissions, g_dwSite, szStatus
								,bNewDefaultFile, NewDefaultFile, bSetCustomErr))
				MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);

			//cleanup
			if (pValue)
				free(pValue);
			if (lpstrCertPath)
				free(lpstrCertPath);
			if (lpstrCgiPath)
				free(lpstrCgiPath);
			if (lpstrDocPath)
				free(lpstrDocPath);
		}
		else
		{
			// delete the virtual root
			//dont show err msg
			if(!DeleteVirtualRoot("certserver/cgi-bin", g_dwSite, szStatus))
				Sleep(1);
				//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			// delete the virtual root
			if(!DeleteVirtualRoot("certserver/docs", g_dwSite, szStatus))
				Sleep(1);
				//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			// delete the virtual root
			if(!DeleteVirtualRoot("certserver", g_dwSite, szStatus))
				Sleep(1);
				//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			// delete the virtual root
			if(!DeleteVirtualRoot("pks/Lookup", g_dwSite, szStatus))
				Sleep(1);
				//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			// delete the virtual root
			if(!DeleteVirtualRoot("pks/Add", g_dwSite, szStatus))
				Sleep(1);
				//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
			// delete the virtual root
			if(!DeleteVirtualRoot("pks", g_dwSite, szStatus))
				Sleep(1);
				//MessageBox (GetFocus(), szStatus, Title, 0 | MB_ICONERROR);
		}

		// this needs to be released before we uninitialize COM
		g_spAdminBase.Release();
		g_spWamAdmin.Release();

		CoUninitialize();
		return 0;
	}

	/*
	Function :  CreateVirtualRoot

	Description:

		Creates the specified virtual root

	Arguments:

		szName - Name of the virtual root to add
		szPhysicalPath - Physical path of the virtual root
		dwPermissions - Access permissions for the virtual root
		dwSite - The site to which the virtual root is to be added
		szStatus - The function can report error descriptions in this string

	Return Value:

		Returns TRUE if successfull; otherwise FALSE.
	*/
	BOOL CreateVirtualRoot(
		LPSTR szName,
		LPSTR szPhysicalPath,
		DWORD dwPermissions,
		DWORD dwSite,
		CHAR szStatus[STATUS_STRING_SIZE],
		BOOL bNewDefaultFile,
		char* NewDefaultFile,
		BOOL bSetCustomErr
		)
	{
		CHAR szMetaPath[MAX_PATH];
		BOOL bResult;

		// Create the metabase path

		wsprintf(szMetaPath, "/LM/W3SVC/%d/ROOT/%s", dwSite, szName);

		// Create a new key for the virtual directory

		bResult = WrAddKey(szMetaPath);

		if (!bResult)
		{
			wsprintf(
				szStatus,
				"CreateVirtualRoot: Error %d (0x%08x) creating key for virtual root",
				GetLastError(),
				GetLastError()
				);

			goto Failed;
		}

		// Set the key type for the virtual directory

		bResult = WrSetData(
			szMetaPath,         // metabase path
			MD_KEY_TYPE,        // identifier
			METADATA_INHERIT,   // attributes
			IIS_MD_UT_FILE,     // user type
			STRING_METADATA,    // data type
			0,                  // data size (not used for STRING_METADATA)
			"IIsWebVirtualDir"  // data
			);

		if (!bResult)
		{
			wsprintf(szStatus, "CreateVirtualRoot: Error %d (0x%08x)setting key type for virtual root",
				GetLastError(), GetLastError());

			goto Failed;
		}
            
		// Set the VRPath for the virtual directory

		bResult = WrSetData(
			szMetaPath,         // metabase path
			MD_VR_PATH,         // identifier
			METADATA_INHERIT,   // attributes
			IIS_MD_UT_FILE,     // user type
			STRING_METADATA,    // data type
			0,                  // data size (not used for STRING_METADATA)
			szPhysicalPath      // data
			);

		if (!bResult)
		{
			wsprintf(szStatus, "CreateVirtualRoot: Error %d (0x%08x) setting vrpath for virtual root",
					GetLastError(), GetLastError());

			goto Failed;
		}

		// Set the permissions for the virtual directory

		bResult = WrSetData(
			szMetaPath,         // metabase path
			MD_ACCESS_PERM,     // identifier
			METADATA_INHERIT,   // attributes
			IIS_MD_UT_FILE,     // user type
			DWORD_METADATA,     // data type
			0,                  // data size (not used for DWORD_METADATA)
			&dwPermissions      // data
			);



		if (!bResult)
		{
			wsprintf(szStatus, "CreateVirtualRoot: Error %d (0x%08x) setting permissions for virtual root",
					GetLastError(), GetLastError());

			goto Failed;
		}
		
		
		// Set the Authorization for the virtual directory
		bResult = WrSetData(
			szMetaPath,         // metabase path
			MD_AUTHORIZATION,   // identifier
			METADATA_INHERIT,   // attributes
			IIS_MD_UT_FILE,     // user type
			DWORD_METADATA,     // data type
			0,                  // data size (not used for DWORD_METADATA)
			&g_dwAuthorization	// data
			);

		if (!bResult)
		{
			wsprintf(szStatus, "CreateVirtualRoot: Error %d (0x%08x) setting Authorization for virtual root",
					GetLastError(), GetLastError());
		}

		if(bNewDefaultFile)
		{
			// Set a new default load file
			bResult = WrSetData(
				szMetaPath,					// metabase path
				MD_DEFAULT_LOAD_FILE,		// identifier
				METADATA_INHERIT,			// attributes
				IIS_MD_UT_FILE,				// user type
				STRING_METADATA,			// data type
				0,							// data size (not used for STRING_METADATA)
				NewDefaultFile				// data
				);

			if (!bResult)
			{
				wsprintf(szStatus, "CreateVirtualRoot: Error %d (0x%08x) setting new default file for virtual root",
						GetLastError(), GetLastError());
			}
		}
		
//DONT SET CUSTOM ERROR UNTIL PROPER WAY IS FOUND
//		if(bSetCustomErr)
//		{
//			LPSTR lpstrCustomError;
//			LPSTR StringsA [5] = {"404,", "*,", "FILE,", szPhysicalPath, "\\error_doc.html"};
//			int i = 0;
//			int iTotalLength = 0;
//		
//			lpstrCustomError = (char*)malloc(strlen(szPhysicalPath)+27/*total chars*/+5/*nulls*/);
//			strcpy(lpstrCustomError, StringsA[0]);
//			strcat(lpstrCustomError, StringsA[1]);
//			strcat(lpstrCustomError, StringsA[2]);
//			strcat(lpstrCustomError, StringsA[3]);
//			strcat(lpstrCustomError, StringsA[4]);
//			//add extra null to end
//			lpstrCustomError [strlen (lpstrCustomError) + 1] = '\0';
//
//			// Set new custom error
//			bResult = WrSetData(
//				szMetaPath,         // metabase path
//				MD_CUSTOM_ERROR,    // identifier
//				METADATA_INHERIT,   // attributes
//				IIS_MD_UT_SERVER,   // user type
//				STRING_METADATA,	// data type
//				0,
//				lpstrCustomError	// data
//				);
//
//			if (!bResult)
//			{
//				wsprintf(szStatus, "CreateVirtualRoot: Error %d (0x%08x) setting custom error for virtual root",
//						GetLastError(), GetLastError());
//			}
//		}

		// Commit the changes and return

		g_spAdminBase->SaveData();

		wsprintf(szStatus, "CreateVirtualRoot completed successfully.");
    
		return TRUE;

	Failed:

		return FALSE;
	}

	/*
	Function :  DeleteVirtualRoot

	Description:

		Deletes the specified virtual root

	Arguments:

		szName - Name of the virtual root to be deleted
		dwSite - The site from which the virtual root will be deleted
		szStatus - The function can report error descriptions in this string

	Return Value:

		Returns TRUE if successfull; otherwise FALSE.

	*/

	BOOL DeleteVirtualRoot(
		LPSTR szName,
		DWORD dwSite,
		CHAR szStatus[STATUS_STRING_SIZE]
		)
	{
		CHAR szMetaPath[MAX_PATH];
		CHAR szParent[MAX_PATH];
		CHAR szVDir[MAX_PATH];
		LPSTR szPtr;
		LPWSTR szwParent = NULL;
		LPWSTR szwVDir = NULL;
		METADATA_HANDLE hMetaData;
		BOOL fMetaData = FALSE;
		BOOL bRes;
		HRESULT hres;
		DWORD dwLastError;

		wsprintf(szMetaPath, "/LM/W3SVC/%d/ROOT/%s", dwSite, szName);

		strcpy(szParent, szMetaPath);

		szPtr = strrchr(szParent, '/');

		strcpy(szVDir, szPtr + 1);

		*szPtr = 0;

		szwParent = MakeUnicode(szParent, 1);
		szwVDir = MakeUnicode(szVDir, 1);

		if (!szwParent || !szwVDir)
		{
			SetLastError(ERROR_NOT_ENOUGH_MEMORY);

			wsprintf(
				szStatus,
				"DeleteVirtualDirectory failed: %d",
				GetLastError()
				);

			goto Failed;
		}

		// Delete any applications on this directory

		bRes = DeleteApplication(
			szMetaPath,     // metabase path
			FALSE,          // not recoverable
			TRUE,           // recursive
			szStatus        // status string
			);

		if (!bRes)
			goto Failed;

		// Get a handle to the metabase

		hres = g_spAdminBase->OpenKey(
			METADATA_MASTER_ROOT_HANDLE,
			szwParent,
			METADATA_PERMISSION_READ|METADATA_PERMISSION_WRITE,
			60000,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品欧美久久久久一区二区| 在线电影一区二区三区| 国产亚洲欧美色| 国产揄拍国内精品对白| 久久综合久久久久88| 国产高清亚洲一区| 亚洲欧美综合在线精品| 色综合久久99| 婷婷综合久久一区二区三区| 欧美一区二区二区| 国产成人综合网站| ...av二区三区久久精品| 一本到一区二区三区| 香蕉久久夜色精品国产使用方法| 91精品国产色综合久久不卡电影| 经典三级视频一区| 国产精品护士白丝一区av| 色哟哟国产精品免费观看| 天天做天天摸天天爽国产一区| 日韩精品专区在线影院观看| 国产精品99久久久久久似苏梦涵| 中文字幕在线观看一区| 欧美三级电影精品| 国产曰批免费观看久久久| 亚洲少妇屁股交4| 国产偷国产偷亚洲高清人白洁| 国产精品综合一区二区三区| 亚洲日本va午夜在线电影| 在线播放一区二区三区| 国产成人免费视频 | 国产亚洲欧美日韩日本| 成人国产精品视频| 午夜久久久影院| 国产视频一区二区在线| 91黄色小视频| 国产激情一区二区三区四区 | 日韩欧美美女一区二区三区| 九色综合狠狠综合久久| 日韩一区在线播放| 日韩美一区二区三区| 91网址在线看| 国产一区二区免费视频| 亚洲一区二区成人在线观看| 久久精品欧美日韩精品| 91精品国产高清一区二区三区蜜臀| 成人免费精品视频| 紧缚捆绑精品一区二区| 亚洲国产日韩a在线播放性色| 婷婷亚洲久悠悠色悠在线播放 | 狠狠网亚洲精品| 中文字幕日韩一区| 日韩一区二区三免费高清| 在线免费不卡视频| 成人免费毛片嘿嘿连载视频| 蜜桃av一区二区| 午夜精品久久久久久| 亚洲视频你懂的| 中文一区一区三区高中清不卡| 欧美一区二区三区白人| 欧美亚一区二区| 91视频一区二区三区| 国产999精品久久久久久| 另类欧美日韩国产在线| 亚洲成人精品影院| 亚洲一区二区精品视频| 亚洲欧美另类久久久精品| 欧美国产成人在线| 久久久91精品国产一区二区精品 | 尤物在线观看一区| 欧美经典三级视频一区二区三区| 欧美大片日本大片免费观看| 欧美精品九九99久久| 欧美日韩另类一区| 欧美三级电影精品| 欧美另类久久久品| 4438成人网| 日韩女同互慰一区二区| 欧美成人艳星乳罩| 精品久久久久久最新网址| 精品国产青草久久久久福利| 欧美不卡一区二区| 精品va天堂亚洲国产| 久久伊人蜜桃av一区二区| 精品sm捆绑视频| 国产亚洲女人久久久久毛片| 国产三区在线成人av| 国产午夜精品久久| 日韩一区有码在线| 亚洲一区二区偷拍精品| 午夜影院久久久| 久久aⅴ国产欧美74aaa| 国产激情精品久久久第一区二区| 国产精品99久久不卡二区| 国产a区久久久| 99久久亚洲一区二区三区青草| 不卡电影免费在线播放一区| 色先锋资源久久综合| 欧美私人免费视频| 91精品国产黑色紧身裤美女| 26uuu成人网一区二区三区| 国产三级精品在线| 最好看的中文字幕久久| 亚洲尤物视频在线| 免费观看日韩电影| 国产成人无遮挡在线视频| 91论坛在线播放| 69久久99精品久久久久婷婷| 欧美v日韩v国产v| 国产精品白丝在线| 丝袜脚交一区二区| 国产一区二区导航在线播放| 成人动漫av在线| 在线成人午夜影院| 欧美激情一区二区三区全黄| 一区二区三区产品免费精品久久75| 亚洲成av人片在线观看无码| 激情亚洲综合在线| 日本乱人伦aⅴ精品| 日韩精品资源二区在线| 一区在线中文字幕| 日韩**一区毛片| 成人手机电影网| 666欧美在线视频| 欧美经典一区二区| 婷婷六月综合亚洲| av电影在线观看不卡| 91精品国产综合久久久久久久 | 亚洲国产综合色| 国产精品一区二区免费不卡| 在线观看国产精品网站| 精品日本一线二线三线不卡| 亚洲乱码中文字幕| 国产毛片精品视频| 欧美精品一二三| 日韩一区在线播放| 精品一区中文字幕| 欧美男人的天堂一二区| 成人欧美一区二区三区视频网页| 看片的网站亚洲| 欧美影院一区二区三区| 污片在线观看一区二区| 日本欧美久久久久免费播放网| 岛国av在线一区| 日韩一区二区免费在线电影| 亚洲乱码精品一二三四区日韩在线| 久久国产乱子精品免费女| 日本精品一级二级| 国产精品―色哟哟| 久久99精品久久久久久| 6080午夜不卡| 午夜伦欧美伦电影理论片| 99国产精品久久久久久久久久| 久久九九久精品国产免费直播| 视频在线观看91| 91激情五月电影| 《视频一区视频二区| 从欧美一区二区三区| 亚洲精品在线网站| 蜜臀久久久99精品久久久久久| 欧美丝袜自拍制服另类| 亚洲免费在线播放| 成人av片在线观看| 欧美国产精品专区| 国产成人鲁色资源国产91色综| 2019国产精品| 激情五月婷婷综合| 亚洲精品一区二区三区影院 | 亚洲成年人影院| 99r精品视频| 成人免费一区二区三区在线观看| 国产凹凸在线观看一区二区| 2017欧美狠狠色| 国产精品影音先锋| 国产亲近乱来精品视频 | 麻豆国产精品777777在线| 欧美久久久久中文字幕| 午夜av区久久| 日韩一二在线观看| 久久国产综合精品| 久久综合九色综合97_久久久| 激情偷乱视频一区二区三区| 久久久久久电影| www.成人在线| 亚洲精品日韩综合观看成人91| 日本乱人伦aⅴ精品| 五月天国产精品| 日韩免费高清av| 国产精品一区2区| 亚洲特黄一级片| 欧美三片在线视频观看| 日本va欧美va欧美va精品| 精品久久国产字幕高潮| 国产福利一区二区| 亚洲欧美一区二区三区久本道91 | 另类小说图片综合网| 久久久91精品国产一区二区精品 | 91精品福利视频| 日韩精品国产欧美| 国产亚洲视频系列| 在线欧美日韩精品|