Méthodes de propriété IADsPathname
Les méthodes de propriété de l’interface IADsPathname obtiennent ou définissent les propriétés EscapedMode . Pour plus d’informations, consultez Méthodes de propriété d’interface.
Propriétés
-
EscapedMode
-
-
Type d’accès : Lecture/écriture
-
Type de données de script : long
-
// C++ method syntax HRESULT get_EscapedMode( [out] long* retval ); HRESULT get_EscapedMode( [in] long* lnEscapedMode );
Examinez ou spécifiez la façon dont les caractères d’échappement sont gérés dans un chemin d’accès. Pour plus d’informations et pour connaître les options définies, consultez ADS_ESCAPE_MODE_ENUM.
-
Notes
EscapedMode représente un état. Vous pouvez l’activer ou le désactiver en le définissant sur ADS_ESCAPEDMODE_ON ou ADS_ESCAPEDMODE_OFF/ADS_ESCAPEDMODE_OFF_EX. Lorsqu’elle est activée ou désactivée, toutes les récupérations suivantes produisent des chaînes de chemin d’échappement ou non échappées.
Dans ADSI, seul le nom IADsPath est capable de déscapsuler les chemins. Toutes les autres interfaces ADSI retournent toujours les chemins d’échappement. L’état par défaut d’EscapedMode est ADS_ESCAPEDMODE_DEFAULT tel que défini dans ADS_ESCAPE_MODE_ENUM.
Exemples
L’exemple de code suivant montre comment utiliser la propriété EscapedMode pour activer/désactiver l’échappement des trois caractères spéciaux suivants : « = », », » et « / ».
Dim path As New Pathname
path.Set "CN=joy\=ful\,\/*", ADS_SETTYPE_DN
path.EscapedMode = ADS_ESCAPEDMODE_ON
MsgBox path.Retrieve(ADS_FORMAT_WINDOWS) ' All escaped, producing:
' "LDAP://CN=joy\=ful\,\/*"
path.EscapedMode = ADS_ESCAPEMODE_OFF
MsgBox path.Retrieve(ADS_FORMAT_WINDOWS) ' Only "/" is unescaped:
' "LDAP://CN=joy\=ful\,/*"
path.EscapedMode = ADS_ESCAPEDMODE_OFF_EX
MsgBox path.Retrieve(ADS_FORMAT_WINDOWS) ' All are unescaped:
' "LDAP://CN=joy=ful,/*"
path.Set "LDAP://CN=joy\=ful\,\/*", ADS_SETTYPE_FULL
path.EscapedMode = ADS_ESCAPEDMODE_ON
MsgBox path.Retrieve(ADS_FORMAT_WINDOWS)
' Produces "LDAP://CN=joy\=ful\,\/*"
path.EscapedMode = ADS_ESCAPEMODE_OFF
MsgBox path.Retrieve(ADS_FORMAT_WINDOWS)
' Produces "LDAP://CN=joy\=ful\,/*"
path.EscapedMode = ADS_ESCAPEMODE_OFF_EX
MsgBox path.Retrieve(ADS_FORMAT_WINDOWS)
' Produces "LDAP://CN=joy=ful,/*"
L’exemple de code suivant montre comment utiliser la propriété EscapedMode pour activer/désactiver l’échappement des trois caractères spéciaux suivants : « = », », » et « / ».
<%
Dim path
const ADS_SETTYPE_FULL = 1
const ADS_SETTYPE_DN = 4
const ADS_FORMAT_WINDOWS = 1
const ADS_ESCAPEDMODE_ON = 2
const ADS_ESCAPEDMODE_OFF = 3
const ADS_ESCAPEDMODE_OFF_EX = 4
Set path = CreateObject("Pathname")
path.Set "CN=joy\=ful\,\/*", ADS_SETTYPE_DN
path.EscapedMode = ADS_ESCAPEDMODE_ON
Response.Write path.Retrieve(ADS_FORMAT_WINDOWS)
' All escaped, producing: "LDAP://CN=joy\=ful\,\/*"
path.EscapedMode = ADS_ESCAPEMODE_OFF
Response.Write path.Retrieve(ADS_FORMAT_WINDOWS)
' Only "/" is unescaped: "LDAP://CN=joy\=ful\,/*"
path.EscapedMode = ADS_ESCAPEDMODE_OFF_EX
Response.Write path.Retrieve(ADS_FORMAT_WINDOWS) ' All are unescaped:
' "LDAP://CN=joy=ful,/*"
path.Set "LDAP://CN=joy\=ful\,\/*", ADS_SETTYPE_FULL
path.EscapedMode = ADS_ESCAPEDMODE_ON
Response.Write path.Retrieve(ADS_FORMAT_WINDOWS)
' Produces "LDAP://CN=joy\=ful\,\/*"
path.EscapedMode = ADS_ESCAPEMODE_OFF
Response.Write path.Retrieve(ADS_FORMAT_WINDOWS)
' Produces "LDAP://CN=joy\=ful\,/*"
path.EscapedMode = ADS_ESCAPEMODE_OFF_EX
Response.Write path.Retrieve(ADS_FORMAT_WINDOWS)
' Produces "LDAP://CN=joy=ful,/*"
%>
L’exemple de code suivant montre comment utiliser la propriété EscapedMode . La vérification des erreurs est ignorée.
IADsPathname *pPathname=NULL;
HRESULT hr;
hr = CoCreateInstance(CLSID_Pathname,
NULL,
CLSCTX_INPROC_SERVER,
IID_IADsPathname,
(void**)&pPathname);
if(FAILED(hr))
{
if(pPathname) pPathname->Release();
return NULL;
}
pPathname->AddRef();
hr = pPathname->Set(CComBSTR("LDAP://CN=joy/ful\/*"),
ADS_SETTYPE_FULL);
hr = pPathname->put_EscapedMode(ADS_ESCAPEDMODE_OFF);
hr = pPathname->Retrieve(ADS_FORMAT_WINDOWS_DN,&bstr);
printf("Unescaped path: %S\n",bstr);
// Producing "LDAP://CN=joy/ful/*"
SysFreeString(bstr);
hr = pPathname->put_EscapedMode(ADS_ESCAPEDMODE_ON);
hr = pPathname->Retrieve(ADS_FORMAT_WINDOWS_DN,&bstr);
printf("Escaped path: %S\n",bstr);
// Producing "LDAP://CN=joy/ful\/*"
SysFreeString(bstr);
// Set the path using ADS_SETTYPE_DN
hr = pPathname->Set(CComBSTR("CN=joy/ful\/*"), ADS_SETTYPE_DN);
hr = pPathname->put_EscapedMode(ADS_ESCAPEDMODE_OFF);
hr = pPathname->Retrieve(ADS_FORMAT_WINDOWS_DN,&bstr);
printf("Unescaped path: %S\n",bstr);
// Producing "LDAP://CN=joy/ful/*"
SysFreeString(bstr);
hr = pPathname->put_EscapedMode(ADS_ESCAPEDMODE_ON);
hr = pPathname->Retrieve(ADS_FORMAT_WINDOWS_DN,&bstr);
printf("Escaped path: %S\n",bstr);
// Producing "LDAP://CN=joy\/ful\/*"
SysFreeString(bstr);
hr = pPathname->Release();
Spécifications
Condition requise | Valeur |
---|---|
Client minimal pris en charge |
Windows Vista |
Serveur minimal pris en charge |
Windows Server 2008 |
En-tête |
|
DLL |
|
IID |
IID_IADsPathname est défini comme D592AED4-F420-11D0-A36E-00C04FB950DC |