Enumerar mensajes
Espacio de nombres: microsoft.graph
Importante
Las API de la versión /beta
de Microsoft Graph están sujetas a cambios. No se admite el uso de estas API en aplicaciones de producción. Para determinar si una API está disponible en la versión 1.0, use el selector de Versión.
Obtenga los mensajes del buzón del usuario que ha iniciado sesión (incluidas las carpetas Elementos eliminados y Otros correos).
Dependiendo de los datos del buzón y del tamaño de la página, recibir mensajes desde un buzón puede conllevar varias solicitudes. El tamaño de página predeterminado es de 10 mensajes. Use $top
para personalizar el tamaño de página, dentro del intervalo de 1 y 1000.
Para mejorar el tiempo de respuesta de la operación, use $select
para especificar las propiedades exactas que necesita; consulte el siguienteejemplo 1. Ajuste los valores de $select
y $top
, especialmente cuando debe usar un tamaño de página más grande, ya que devolver una página con cientos de mensajes cada uno con una carga de respuesta completa puede desencadenar el tiempo de espera de la puerta de enlace (HTTP 504).
Para obtener la página siguiente de mensajes, basta con aplicar la dirección URL completa devuelta en @odata.nextLink
a la siguiente solicitud get-messages. Esta dirección URL contiene todos los parámetros de consulta que haya especificado en la solicitud inicial.
No intente extraer el valor $skip
de la dirección URL @odata.nextLink
para manipular las respuestas. Esta API usa el valor $skip
para mantener el recuento de todos los elementos que ha recorrido en el buzón del usuario para devolver una página de elementos de tipo de mensaje. Por tanto, es posible que incluso en la respuesta inicial, el valor de $skip
sea mayor que el tamaño de la página. Para obtener más información, vea Paginación de los datos de Microsoft Graph en su aplicación.
Puede filtrar por los mensajes y obtener solo aquellos que incluyan una mención del usuario que ha iniciado sesión. Vea un ejemplo a continuación.
De forma predeterminada, la GET /me/messages
operación no devuelve la propiedad mentions . Use el parámetro de $expand
consulta para buscar detalles de cada mención en un mensaje.
Hay dos posibles escenarios donde una aplicación puede obtener mensajes en la carpeta de correo de otro usuario:
- Si la aplicación tiene permisos de aplicación, o bien,
- Si la aplicación tiene los correspondientes permisos delegados de un usuario y otro usuario ha compartido una carpeta de correo con ese usuario, o bien, le ha concedido acceso delegado a ese usuario. Vea detalles y un ejemplo.
Esta API está disponible en las siguientes implementaciones nacionales de nube.
Servicio global | Gobierno de EE. UU. L4 | Us Government L5 (DOD) | China operada por 21Vianet |
---|---|---|---|
✅ | ✅ | ✅ | ✅ |
Permissions
Elija el permiso o los permisos marcados como con privilegios mínimos para esta API. Use un permiso o permisos con privilegios superiores solo si la aplicación lo requiere. Para obtener más información sobre los permisos delegados y de aplicación, consulte Tipos de permisos. Para obtener más información sobre estos permisos, consulte la referencia de permisos.
Tipo de permiso | Permisos con privilegios mínimos | Permisos con privilegios más altos |
---|---|---|
Delegado (cuenta profesional o educativa) | Mail.ReadBasic | Mail.ReadWrite, Mail.Read |
Delegado (cuenta personal de Microsoft) | Mail.ReadBasic | Mail.ReadWrite, Mail.Read |
Aplicación | Mail.ReadBasic.All | Mail.ReadWrite, Mail.Read |
Solicitud HTTP
Para obtener todos los mensajes del buzón de un usuario:
GET /me/messages
GET /users/{id | userPrincipalName}/messages
Para obtener los mensajes de una carpeta específica del buzón del usuario:
GET /me/mailFolders/{id}/messages
GET /users/{id | userPrincipalName}/mailFolders/{id}/messages
Para obtener todos los mensajes en el buzón del usuario que incluyen una mención del usuario:
GET /me/messages?$filter=mentionsPreview/isMentioned eq true
GET /users/{id | userPrincipalName}/messages?$filter=mentionsPreview/isMentioned eq true
Parámetros de consulta opcionales
Este método admite los parámetros de consulta de OData a modo de ayuda para personalizar la respuesta.
Puede usar el parámetro de $filter
consulta en la propiedad mentionsPreview para obtener los mensajes que mencionan al usuario que ha iniciado sesión.
Usar Filter y OrderBy en la misma consulta
Cuando este usando $filter
y $orderby
en la misma consulta para obtener mensajes, asegúrese de especificar las propiedades de las siguientes maneras:
- Las propiedades que aparecen
$orderby
en también deben aparecer$filter
en. - Las propiedades que aparecen
$orderby
en están en el mismo orden que$filter
en. - Las propiedades presentes en
$orderby
aparecen en antes de$filter
las propiedades que no lo sean.
Si no lo hace, se produce el siguiente error:
- Código de error
InefficientFilter
- Mensaje de error:
The restriction or sort order is too complex for this operation.
Encabezados de solicitud
Nombre | Tipo | Descripción |
---|---|---|
Authorization | string | {token} de portador. Obligatorio. |
Prefer: outlook.body-content-type | string | Formato de las propiedades body y uniqueBody que se devolverá. Los valores pueden ser "text" o "html". Si no se especifica el encabezado, las propiedades body y uniqueBody se devuelven en formato HTML. Opcional. |
Cuerpo de la solicitud
No proporcione un cuerpo de solicitud para este método.
Respuesta
Si se ejecuta correctamente, este método devuelve un código de respuesta y una 200 OK
colección de objetos de mensaje en el cuerpo de la respuesta.
Ejemplos
Ejemplo 1: mostrar todos los mensajes
Solicitud
En el primer ejemplo se obtienen los 10 mensajes principales predeterminados en el buzón del usuario que ha iniciado sesión. Usa $select
para devolver un subconjunto de las propiedades de cada mensaje en la respuesta.
GET https://graph.microsoft.com/beta/me/messages?$select=sender,subject
Respuesta
En el ejemplo siguiente se muestra la respuesta. Para obtener la página siguiente de mensajes, aplique la dirección URL devuelta en @odata.nextLink
en una solicitud GET siguiente.
HTTP/1.1 200 OK
Content-type: application/json
{
"@odata.context": "https://graph.microsoft.com/beta/$metadata#users('bb8775a4-4d8c-42cf-a1d4-4d58c2bb668f')/messages(sender,subject)",
"value": [
{
"@odata.etag": "W/\"CQAAABYAAADHcgC8Hl9tRZ/hc1wEUs1TAAAwR4Hg\"",
"id": "AAMkAGUAAAwTW09AAA=",
"subject": "You have late tasks!",
"sender": {
"emailAddress": {
"name": "Microsoft Planner",
"address": "noreply@Planner.Office365.com"
}
}
}
]
}
Ejemplo 2: Uso de $filter para obtener todos los mensajes que cumplen una condición específica
Solicitud
En el siguiente ejemplo se filtran todos los mensajes del buzón del usuario que ha iniciado sesión para aquellos que mencionan al usuario. También usa $select
para devolver un subconjunto de las propiedades de cada mensaje de la respuesta.
En el ejemplo siguiente también se incorpora la codificación de direcciones URL para los caracteres de espacio en la cadena del parámetro de consulta.
GET https://graph.microsoft.com/beta/me/messages?$filter=MentionsPreview/IsMentioned%20eq%20true&$select=Subject,Sender,ReceivedDateTime,MentionsPreview
Respuesta
En el ejemplo siguiente se muestra la respuesta.
Nota: Se puede acortar el objeto de respuesta que se muestra aquí para mejorar la legibilidad.
HTTP/1.1 200 OK
Content-type: application/json
{
"@odata.context":"https://graph.microsoft.com/beta/$metadata#me/messages(subject,sender,receivedDateTime,mentionsPreview)",
"value":[
{
"@odata.id":"https://graph.microsoft.com/beta/users('266efe5a-0fd7-4edd-877b-b2d1e561f193@ae01a323-3934-4475-a32d-af1274312bb0')/messages('AQMkADJmMTUAAAgVZAAAA')",
"@odata.etag":"W/\"CQAAABYAAAAPFhK2FclcRbABBJhCde8iAAAAAATI\"",
"id":"AQMkADJmMTUAAAgVZAAAA",
"receivedDateTime":"2016-07-21T07:40:21Z",
"subject":"Re: Start planning soon",
"sender":{
"emailAddress":{
"name":"Adele Vance",
"address":"AdeleV@contoso.com"
}
},
"mentionsPreview":{
"isMentioned":true
}
}
]
}
Ejemplo 3: Use prefer header para obtener el cuerpo del mensaje y uniqueBody es el formato de texto.
Solicitud
En el tercer ejemplo se muestra cómo usar un Prefer: outlook.body-content-type="text"
encabezado para obtener el cuerpo y las propiedades uniqueBody de cada mensaje en formato de texto.
GET https://graph.microsoft.com/beta/me/messages?$select=subject,body,bodyPreview,uniqueBody
Prefer: outlook.body-content-type="text"
Respuesta
En el ejemplo siguiente se muestra la respuesta.
HTTP/1.1 200 OK
Content-type: application/json
{
"@odata.context":"https://graph.microsoft.com/beta/$metadata#users('cd209b0b-3f83-4c35-82d2-d88a61820480')/messages(subject,body,bodyPreview,uniqueBody)",
"value":[
{
"@odata.type":"#microsoft.graph.eventMessageRequest",
"@odata.etag":"W/\"CwAAABYAAABmWdbhEgBXTophjCWt81m9AAAoZYj5\"",
"id":"AAMkAGIAAAoZCfIAAA=",
"subject":"Orientation ",
"bodyPreview":"Dana, this is the time you selected for our orientation. Please bring the notes I sent you.",
"body":{
"contentType":"text",
"content":"Dana, this is the time you selected for our orientation. Please bring the notes I sent you.\r\n"
},
"uniqueBody":{
"contentType":"text",
"content":"Dana, this is the time you selected for our orientation. Please bring the notes I sent you.\r\n"
}
}
]
}
Comentarios
https://aka.ms/ContentUserFeedback.
Próximamente: A lo largo de 2024 iremos eliminando gradualmente GitHub Issues como mecanismo de comentarios sobre el contenido y lo sustituiremos por un nuevo sistema de comentarios. Para más información, vea:Enviar y ver comentarios de