Obtener la configuración de usuario de Exchange mediante el uso de detección automática
Obtenga información sobre cómo obtener la configuración de usuario de un servidor exchange mediante detección automática.
La detección automática simplifica la configuración de la aplicación al proporcionar un acceso fácil a la información de configuración del usuario mediante solo la dirección de correo electrónico y la contraseña del usuario. Hay una serie de opciones de configuración de usuario disponibles a través de detección automática, como el nombre para mostrar del usuario o la dirección URL del servicio web externo.
Puede usar una de las siguientes tecnologías de desarrollo para recuperar la configuración de usuario del servicio Detección automática:
La API administrada de EWS proporciona una interfaz basada en objetos para recuperar la configuración de usuario. Si su aplicación cliente usa un código administrado, le recomendamos que use la API administrada de EWS. Si usa la API administrada de EWS, determine si la configuración que necesita está disponible en la enumeración Microsoft.Exchange.WebServices.Autodiscover.UserSettingName . Si no es así, es posible que quiera usar los servicios de detección automática SOAP o POX.
Si usa un servicio web, se recomienda usar el servicio de detección automática de SOAP, ya que admite un conjunto de características más completo que el servicio de detección automática pox. Si el servicio de detección automática soap no está disponible, el servicio de detección automática pox es una buena alternativa.
Configuración para obtener la configuración del usuario
Antes de obtener la configuración de usuario mediante el servicio Detección automática, asegúrese de que tiene acceso a lo siguiente:
Si usa la API administrada de EWS o el servicio de detección automática basado en POX, Exchange Online, Exchange Online como parte de Office 365 o un servidor que ejecuta una versión de Exchange a partir de Exchange 2007 SP1.
Si usa el servicio de detección automática basado en SOAP, Exchange Online o una versión de Exchange a partir de Exchange 2010.
Nota:
Si usa la API administrada de EWS, deberá proporcionar un método de devolución de llamada de validación de certificados en algunas circunstancias. También es posible que necesite un método de devolución de llamada de validación de certificados con algunas bibliotecas de proxy generadas, como las creadas por Visual Studio.
Obtener la configuración de usuario mediante la API administrada de EWS
Puede usar el método GetUserSettings para recuperar información de configuración de un usuario, como se muestra en el ejemplo siguiente. En este ejemplo, puede especificar una matriz de configuración de usuario que se va a devolver (de las disponibles en la enumeración UserSettingName ) y el método seguirá las respuestas de redireccionamiento del servidor de Exchange.
using System;
using System.Net;
using Microsoft.Exchange.WebServices.Autodiscover;
public static GetUserSettingsResponse GetUserSettings(
AutodiscoverService service,
string emailAddress,
int maxHops,
params UserSettingName[] settings)
{
Uri url = null;
GetUserSettingsResponse response = null;
for (int attempt = 0; attempt < maxHops; attempt++)
{
service.Url = url;
service.EnableScpLookup = (attempt < 2);
response = service.GetUserSettings(emailAddress, settings);
if (response.ErrorCode == AutodiscoverErrorCode.RedirectAddress)
{
url = new Uri(response.RedirectTarget);
}
else if (response.ErrorCode == AutodiscoverErrorCode.RedirectUrl)
{
url = new Uri(response.RedirectTarget);
}
else
{
return response;
}
}
throw new Exception("No suitable Autodiscover endpoint was found.");
}
Puede analizar la colección devuelta para tener acceso a cada par clave-valor de la matriz de configuración de usuario. En el siguiente ejemplo se muestra cómo analizar mediante cada elemento devuelto y mostrar el nombre y el valor de cada par clave-valor.
// Display each retrieved value. The settings are part of a key/value pair.
// userresponse is a GetUserSettingsResonse object.
foreach (KeyValuePair<UserSettingName, Object> usersetting in userresponse.Settings)
{
Console.WriteLine(usersetting.Key.ToString() + ": " + usersetting.Value);
}
De manera alternativa, puede obtener el valor de una configuración específica. En el ejemplo siguiente, se mostrará la configuración UserDisplayName .
// Display a specific setting, such as UserDisplayName.
Console.WriteLine(userresponse.Settings[UserSettingName.UserDisplayName]);
Obtener la configuración de usuario mediante la detección automática de SOAP
Si no usa la API administrada de EWS, se recomienda usar el servicio web de detección automática de SOAP. Use solo el servicio web de detección automática pox si el servicio web de detección automática SOAP produce un error o no está disponible.
Para obtener la configuración del usuario, use la operación GetUserSettings (SOAP). La configuración solicitada se devuelve como elementos UserSetting.
En el ejemplo siguiente se muestra una solicitud de detección automática SOAP para obtener la configuración de usuario del servidor.
<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:a="https://schemas.microsoft.com/exchange/2010/Autodiscover"
xmlns:wsa="http://www.w3.org/2005/08/addressing"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:soap="https://schemas.xmlsoap.org/soap/envelope/">
<soap:Header>
<a:RequestedServerVersion>Exchange2013</a:RequestedServerVersion>
<wsa:Action>https://schemas.microsoft.com/exchange/2010/Autodiscover/Autodiscover/GetUserSettings</wsa:Action>
<wsa:To>https://autodiscover.exchange.microsoft.com/autodiscover/autodiscover.svc</wsa:To>
</soap:Header>
<soap:Body>
<a:GetUserSettingsRequestMessage xmlns:a="https://schemas.microsoft.com/exchange/2010/Autodiscover">
<a:Request>
<a:Users>
<a:User>
<a:Mailbox>mara@contoso.com</a:Mailbox>
</a:User>
</a:Users>
<a:RequestedSettings>
<a:Setting>UserDisplayName</a:Setting>
<a:Setting>UserDN</a:Setting>
<a:Setting>UserDeploymentId</a:Setting>
<a:Setting>InternalMailboxServer</a:Setting>
<a:Setting>MailboxDN</a:Setting>
<a:Setting>PublicFolderServer</a:Setting>
<a:Setting>ActiveDirectoryServer</a:Setting>
<a:Setting>ExternalMailboxServer</a:Setting>
<a:Setting>EcpDeliveryReportUrlFragment</a:Setting>
<a:Setting>EcpPublishingUrlFragment</a:Setting>
<a:Setting>EcpTextMessagingUrlFragment</a:Setting>
<a:Setting>ExternalEwsUrl</a:Setting>
<a:Setting>CasVersion</a:Setting>
<a:Setting>EwsSupportedSchemas</a:Setting>
<a:Setting>GroupingInformation</a:Setting>
</a:RequestedSettings>
</a:Request>
</a:GetUserSettingsRequestMessage>
</soap:Body>
</soap:Envelope>
En el ejemplo siguiente se muestra la respuesta SOAP devuelta por el servidor después de analizar la solicitud del cliente. La respuesta contiene solo la configuración que se solicita, si existe.
<s:Envelope xmlns:s="https://schemas.xmlsoap.org/soap/envelope/" xmlns:a="http://www.w3.org/2005/08/addressing">
<s:Header>
<a:Action s:mustUnderstand="1">https://schemas.microsoft.com/exchange/2010/
Autodiscover/Autodiscover/GetUserSettingsResponse</a:Action>
<h:ServerVersionInfo xmlns:h="https://schemas.microsoft.com/exchange/2010/Autodiscover"
xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<h:MajorVersion>15</h:MajorVersion>
<h:MinorVersion>0</h:MinorVersion>
<h:MajorBuildNumber>160</h:MajorBuildNumber>
<h:MinorBuildNumber>4</h:MinorBuildNumber>
<h:Version>Exchange2013</h:Version>
</h:ServerVersionInfo>
</s:Header>
<s:Body>
<GetUserSettingsResponseMessage xmlns="https://schemas.microsoft.com/exchange/2010/Autodiscover">
<Response xmlns:i="http://www.w3.org/2001/XMLSchema-instance">
<ErrorCode>NoError</ErrorCode>
<ErrorMessage />
<UserResponses>
<UserResponse>
<ErrorCode>NoError</ErrorCode>
<ErrorMessage>No error.</ErrorMessage>
<RedirectTarget i:nil="true" />
<UserSettingErrors />
<UserSettings>
<UserSetting i:type="StringSetting">
<Name>UserDisplayName</Name>
<Value>Mara Whitley</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>UserDN</Name>
<Value>/o=microsoft/ou=Exchange Administrative Group (FYDIBOHF23SPDLT)/cn=Recipients/cn=mara</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>UserDeploymentId</Name>
<Value>649d50b8-a1ce-4bac-8ace-2321 e463f701</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>CasVersion</Name>
<Value>15.01.0160.004</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>EwsSupportedSchemas</Name>
<Value>Exchange2007, Exchange2007_SP1, Exchange2010, Exchange2010_SP1, Exchange2010_SP2, Exchange2013</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>InternalMailboxServer</Name>
<Value>mail.contoso.com</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>ActiveDirectoryServer</Name>
<Value>dc.contoso.com</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>MailboxDN</Name>
<Value>/o=microsoft/ou=Exchange Administrative Group
(FYDIBOHF23SPDLT)/cn=Configuration/cn=Servers/cn=mail.contoso.com/cn=Contoso Private MDB</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>PublicFolderServer</Name>
<Value>public.contoso.com</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>EcpDeliveryReportUrlFragment</Name>
<Value>PersonalSettings/DeliveryReport.aspx?exsvurl=1&amp;IsOWA=&lt;IsOWA&gt;&amp;MsgID=&lt;MsgID&gt;&amp;Mbx=&lt;Mbx&gt;</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>EcpTextMessagingUrlFragment</Name>
<Value>?p=sms/textmessaging.slab&amp;exsvurl=1</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>EcpPublishingUrlFragment</Name>
<Value>customize/calendarpublishing.slab?exsvurl=1&amp;FldID=&lt;FldID&gt;</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>ExternalEwsUrl</Name>
<Value>https://mail.contoso.com/EWS/Exchange.asmx</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>ExternalMailboxServer</Name>
<Value>mail.contoso.com</Value>
</UserSetting>
<UserSetting i:type="StringSetting">
<Name>GroupingInformation</Name>
<Value>CONTOSO-1</Value>
</UserSetting>
</UserSettings>
</UserResponse>
</UserResponses>
</Response>
</GetUserSettingsResponseMessage>
</s:Body>
</s:Envelope
Obtener la configuración de usuario mediante la detección automática de POX
Aunque se recomienda usar el servicio web de detección automática de SOAP, el servicio web de detección automática pox es una buena opción de copia de seguridad para aquellos momentos en los que SOAP no está disponible. Por ejemplo, Exchange 2007 no admite el servicio web de detección automática de SOAP, por lo que si tiene como destino Exchange 2007, debe usar el servicio web de detección automática pox. A diferencia del servicio web de detección automática de SOAP, el servicio de detección automática pox no permite solicitar una configuración específica. En su lugar, el servidor devuelve una lista completa de la configuración disponible como elementos secundarios del elemento Protocol.
En el ejemplo siguiente se muestra una solicitud de detección automática de POX para obtener la configuración de usuario del servidor. El siguiente XML se envía al servidor a través de un HTTP POST.
<?xml version="1.0" encoding="utf-8"?>
<Autodiscover xmlns="https://schemas.microsoft.com/exchange/autodiscover/outlook/requestschema/2006">
<Request>
<EMailAddress>mara@contoso.com</EMailAddress>
<AcceptableResponseSchema>https://schemas.microsoft.com/exchange/autodiscover/outlook/responseschema/2006a</AcceptableResponseSchema>
</Request>
</Autodiscover>
En el ejemplo siguiente se muestra la respuesta POX devuelta por el servidor.
<?xml version="1.0" encoding="utf-8"?>
<Autodiscover xmlns="https://schemas.microsoft.com/exchange/autodiscover/responseschema/2006">
<Response xmlns="https://schemas.microsoft.com/exchange/autodiscover/outlook/responseschema/2006a">
<User>
<DisplayName>Mara Whitley</DisplayName>
<LegacyDN>/o=First Organization/ou=Exchange Administrative Group (FYDIBOHF23SPDLT)/cn=Recipients/cn=f5eeabead90d4b6fb51d6379474692cd-Mara</LegacyDN>
<AutoDiscoverSMTPAddress>mara@contoso.com</AutoDiscoverSMTPAddress>
<DeploymentId>50817eff-b925-4578-a0db-13bfc635e7a5</DeploymentId>
</User>
<Account>
<AccountType>email</AccountType>
<Action>settings</Action>
<MicrosoftOnline>False</MicrosoftOnline>
<Protocol>
<Type>EXCH</Type>
<Server>5f76be3c-9138-4f66-85e0-21bc23ca35f0@contoso.com</Server>
<ServerDN>/o=First Organization/ou=Exchange Administrative Group (FYDIBOHF23SPDLT)/cn=Configuration/cn=Servers/cn=5f76be3c-9138-4f66-85e0-21bc23ca35f0@contoso.com</ServerDN>
<ServerVersion>73C08204</ServerVersion>
<MdbDN>/o=First Organization/ou=Exchange Administrative Group (FYDIBOHF23SPDLT)/cn=Configuration/cn=Servers/cn=5f76be3c-9138-4f66-85e0-21bc23ca35f0@contoso.com/cn=Microsoft Private MDB</MdbDN>
<PublicFolderServer>public.contoso.com</PublicFolderServer>
<AD>dc.contoso.com</AD>
<ASUrl>https://mail.contoso.com/EWS/Exchange.asmx</ASUrl>
<EwsUrl>https://mail.contoso.com/EWS/Exchange.asmx</EwsUrl>
<EmwsUrl>https://mail.contoso.com/EWS/Exchange.asmx</EmwsUrl>
<EcpUrl>https://mail.contoso.com/ecp/</EcpUrl>
<EcpUrl-um>?rfr=olk&amp;p=customize/voicemail.aspx&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-um>
<EcpUrl-aggr>?rfr=olk&amp;p=personalsettings/EmailSubscriptions.slab&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-aggr>
<EcpUrl-mt>PersonalSettings/DeliveryReport.aspx?rfr=olk&amp;exsvurl=1&amp;IsOWA=&lt;IsOWA&gt;&amp;MsgID=&lt;MsgID&gt;&amp;Mbx=&lt;Mbx&gt;&amp;realm=contoso.com</EcpUrl-mt>
<EcpUrl-ret>?rfr=olk&amp;p=organize/retentionpolicytags.slab&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-ret>
<EcpUrl-sms>?rfr=olk&amp;p=sms/textmessaging.slab&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-sms>
<EcpUrl-publish>customize/calendarpublishing.slab?rfr=olk&amp;exsvurl=1&amp;FldID=&lt;FldID&gt;&amp;realm=contoso.com</EcpUrl-publish>
<EcpUrl-photo>PersonalSettings/EditAccount.aspx?rfr=olk&amp;chgPhoto=1&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-photo>
<EcpUrl-tm>?rfr=olk&amp;ftr=TeamMailbox&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-tm>
<EcpUrl-tmCreating>?rfr=olk&amp;ftr=TeamMailboxCreating&amp;SPUrl=&lt;SPUrl&gt;&amp;Title=&lt;Title&gt;&amp;SPTMAppUrl=&lt;SPTMAppUrl&gt;&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-tmCreating>
<EcpUrl-tmEditing>?rfr=olk&amp;ftr=TeamMailboxEditing&amp;Id=&lt;Id&gt;&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-tmEditing>
<EcpUrl-extinstall>Extension/InstalledExtensions.slab?rfr=olk&amp;exsvurl=1&amp;realm=contoso.com</EcpUrl-extinstall>
<OOFUrl>https://mail.contoso.com/EWS/Exchange.asmx</OOFUrl>
<UMUrl>https://mail.contoso.com/EWS/UM2007Legacy.asmx</UMUrl>
<OABUrl>https://mail.contoso.com/OAB/c21c7bc2-53b3-4ddc-ad89-1219b486c37c/</OABUrl>
<ServerExclusiveConnect>off</ServerExclusiveConnect>
</Protocol>
<Protocol>
<Type>EXPR</Type>
<Server>mail.contoso.com</Server>
<SSL>Off</SSL>
<AuthPackage>Ntlm</AuthPackage>
<ServerExclusiveConnect>on</ServerExclusiveConnect>
<CertPrincipalName>None</CertPrincipalName>
</Protocol>
<Protocol>
<Type>WEB</Type>
<Internal>
<OWAUrl AuthenticationMethod="Basic, Fba">https://mail.contoso.com/owa/</OWAUrl>
<Protocol>
<Type>EXCH</Type>
<ASUrl>https://mail.contoso.com/EWS/Exchange.asmx</ASUrl>
</Protocol>
</Internal>
</Protocol>
</Account>
</Response>
</Autodiscover>
Pasos siguientes
Después de recuperar los detalles de configuración necesarios para el usuario del servidor, está listo para comunicarse con Exchange para hacer lo que la aplicación necesita hacer. Lo que haga a continuación dependerá de cómo se comunique con Exchange y de lo que quiera lograr. Si necesita algo de inspiración y usa EWS, puede explorar los ejemplos de código de Exchange 101 para obtener algunas ideas.