Enumerar mensajes
Espacio de nombres: microsoft.graph
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.
Actualmente, esta operación devuelve los cuerpos de los mensajes solo en formato HTML.
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
Parámetros de consulta opcionales
Este método admite los parámetros de consulta de OData a modo de ayuda para personalizar la respuesta.
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. Obtenga más información sobre la autenticación y la autorización. |
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 200 OK
y la colección de objetos Message en el cuerpo de la respuesta.
Ejemplos
Ejemplo 1: mostrar todos los mensajes
Solicitud
A continuación se muestra un ejemplo donde se obtiene 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/v1.0/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/v1.0/$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"
}
}
}
]
}