|
| БЕСПЛАТНАЯ ежедневная online лотерея! Выигрывай каждый день БЕСПЛАТНО! |
|
|
Using NDdeShareAdd to Create a DDE Share
The NDdeShareAdd function is used by a DDE server application to create a DDE share.
Before creating a DDE share, it is a good idea to verify that the proposed share name and topic name are valid by using the NDdeIsValidShareName and NDdeIsValidAppTopicList functions. These functions are also called by NDdeShareAdd. The following example demonstrates how to create a DDE share. It uses a NULL discretionary access control list (DACL) to grant write access to all users. Note that this is not the same as specifying NULL in the pSD parameter of NDdeShareAdd.
BOOL MyCreateDdeShare( LPTSTR lpszShareName, LPTSTR lpszTopicList ) { NDDESHAREINFO ndsi; PSECURITY_DESCRIPTOR pSD = NULL; // Where lpszShareName is the share name. if( NDdeIsValidShareName( lpszShareName ) == FALSE ) return FALSE;
// Where lpszTopicList is a list of null-terminated strings terminated // by another null character. if( NDdeIsValidAppTopicList( lpszTopicList ) == FALSE ) return FALSE;
// Fill in the NDDESHAREINFO structure.
ndsi.lRevision = 1; ndsi.lpszShareName = lpszShareName; ndsi.lShareType = SHARE_TYPE_STATIC; ndsi.lpszAppTopicList = lpszTopicList; ndsi.fSharedFlag = TRUE; ndsi.fService = FALSE; ndsi.fStartAppFlag = TRUE; ndsi.nCmdShow = SW_SHOWNORMAL; ndsi.cNumItems = 0; ndsi.lpszItemList = "";
// Create a security descriptor to allow write access. pSD = (PSECURITY_DESCRIPTOR) LocalAlloc( LPTR, SECURITY_DESCRIPTOR_MIN_LENGTH );
InitializeSecurityDescriptor( pSD, SECURITY_DESCRIPTOR_REVISION ); SetSecurityDescriptorDacl( pSD, TRUE, (PACL)NULL, FALSE );
// Delete possible old DDE share. NDdeShareDel( NULL, lpszShareName, 0 );
// Create the DDE share. NDdeShareAdd( NULL, 2, pSD, (LPBYTE)&ndsi, sizeof(NDDESHAREINFO) );
LocalFree( pSD ); return TRUE; }
The following example shows how you could call the MyCreateDdeShare function to create the share MyDdeShare$:
char *TopicList = "\0\0MyApp|MyTopic\0\0"; MyCreateDdeShare( "MyDdeShare$", TopicList );
This share name ends with a dollar sign ($), indicating that it is a static DDE share. Topic strings are provided only for the static-type DDE share.
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
| Пригласи друзей и счет твоего мобильника всегда будет положительным! |
Использование NDdeShareAdd, чтобы Создавать Акцию DDE
Функция NDdeShareAdd использована приложением сервера DDE, чтобы создавать акцию DDE.
Перед созданием акции DDE, это - хорошая идея проверять, что предлагаемое акционерное имя и имя темы будет в силе используя NDdeIsValidShareName и функции NDdeIsValidAppTopicList. Эти функции также названы NDdeShareAdd. Следующий пример демонстрирует как, чтобы создавать акцию DDE. Это использует НЕДЕЙСТВИТЕЛЬНЫЙ управляющий список дискреционного доступа (DACL), чтобы предоставлять записи доступ ко всем пользователям. Отметьте, что это не такое же как и определяя НЕДЕЙСТВИТЕЛЬНЫМ в параметре pSD NDdeShareAdd.
BOOL MyCreateDdeShare( LPTSTR lpszShareName, LPTSTR lpszTopicList ) { NDDESHAREINFO ndsi; PSECURITY_DESCRIPTOR pSD = НЕДЕЙСТВИТЕЛЬНЫЙ; // Где lpszShareName - акционерное имя. если( NDdeIsValidShareName( lpszShareName ) == ЛОЖЬ ) обратная ЛОЖЬ;
// Где lpszTopicList - список недействительный расторгнутых строк завершенных // другим недействительным символом. если( NDdeIsValidAppTopicList( lpszTopicList ) == ЛОЖЬ ) обратная ЛОЖЬ;
// Заполните структуру NDDESHAREINFO.
ndsi.lRevision = 1; ndsi.lpszShareName = lpszShareName; ndsi.lShareType = SHARE_TYPE_STATIC; ndsi.lpszAppTopicList = lpszTopicList; ndsi.fSharedFlag = ИСТИНА; ndsi.fService = ЛОЖЬ; ndsi.fStartAppFlag = ИСТИНА; ndsi.nCmdShow = SW_SHOWNORMAL; ndsi.cNumItems = 0; ndsi.lpszItemList = "";
// Создайте дескриптор безопасности, чтобы допускать записывать доступ. pSD = (PSECURITY_DESCRIPTOR) LocalAlloc( LPTR, SECURITY_DESCRIPTOR_MIN_LENGTH );
InitializeSecurityDescriptor( pSD, SECURITY_DESCRIPTOR_REVISION ); SetSecurityDescriptorDacl( pSD, ИСТИНА, (PACL)NULL, ЛОЖЬ );
// Удалите возможную старую акцию DDE. NDdeShareDel( НЕДЕЙСТВИТЕЛЬНЫЙ, lpszShareName, 0 );
// Создайте акцию DDE. NDdeShareAdd( НЕДЕЙСТВИТЕЛЬНЫЙ, 2, pSD, (LPBYTE)&ndsi, sizeof(NDDESHAREINFO) );
LocalFree( pSD ); возвращайтесь ВЕРНО; }
Следующий пример показывает как Вы могли бы назвать функцию MyCreateDdeShare, чтобы создавать акцию MyDdeShare$:
символ *TopicList = "\0\0MyApp|MyTopic\0\0"; MyCreateDdeShare( "MyDdeShare$", TopicList );
Это акционерное имя заканчивается со знаком доллара ($), указывая, что оно - статическая акция DDE. Строки Темы предусматриваются только для статической-акции типа DDE.
|
|
|
|
| |