Я хочу использовать метод addFileAttachmentAsync Office.js/Outlook, чтобы добавить файл из OneDrive в новое составленное почтовое сообщение. Этот файл предоставлен мне другим пользователем Office365. Если я использую интерфейс Onedrive для создания ссылки и добавляю текст «&download=1», все работает как шарм.
Если я использую Graph createLink для создания ссылки, мы получаем URI, и этот URI, кажется, работает, но генерирует ошибку, как только загрузка завершена.
Как я могу сгенерировать URI с помощью Graph, который работает?
Заранее спасибо за ваши усилия!
Уилко
Ручной URI выглядит следующим образом:
и сгенерированный графом URI выглядит следующим образом:
Даже если мы убедимся, что ссылка общедоступна, мы не можем использовать ее для addFileAttachmentAsync. Использование Graph Createlink со следующей командой:
https://graph.microsoft.com/v1.0/me/drive/items/01ATENY5KYPNW2NH64F5CJEWPK4DYIHSX7/createLink
со следующим телом {"type": "edit", "scope": "anonymous"} доставляет webUrl:
Если я использую интерфейс OneDrive для создания той же ссылки, результат будет следующим:
Второй URL работает. Единственное отличие состоит в последней части ?e=fCWoUK. Как я могу получить необходимую последнюю часть из Graph?
Изображения результатов
Результат малого URL (возвращается по графу): https://softmakersbv-my.sharepoint.com/:i:/g/personal/wilcotroost_softmakers_nl/EaNXPGdDsBBDo_uVZPK2c0EB6gHaA3ASNj5ly0QyzKGgzQ?e=G30d5L
Результат более длинного URL (сделан вручную): https://softmakersbv-my.sharepoint.com/:i:/g/personal/wilcotroost_softmakers_nl/EUuTYN05rlNNpYn0IG7FMfkBnnCu6yUUdbj72YcsTc5Wow?e=jWU5Mw.
Пример запрошенного кода
let _fileName = 'Picos de Europa'
// graph url ..v1.0/me/drive/items/01ATENY5KYPNW2NH64F5CJEWPK4DYIHSX7/createLink {"type": "edit", "scope": "anonymous"}
//let _fileUrl = 'https://softmakersbv-my.sharepoint.com/:i:/g/personal/tim_softmakers_nl/EVh7baaf3C9Eklnq4PCDyv8BbjtwqSi-a92qYg0EYEE0kA'
// handmade url (create link from the onedrive interface)
let _fileUrl = 'https://softmakersbv-my.sharepoint.com/:i:/g/personal/tim_softmakers_nl/EVh7baaf3C9Eklnq4PCDyv8BbjtwqSi-a92qYg0EYEE0kA?e=fCWoUK'
Office.context.mailbox.item.addFileAttachmentAsync(_fileUrl + '&download=1', _fileName, {}, (result) => {
console.info(result)
})
Работает только созданная вручную ссылка Url. Моя проблема в том, что мне нравится создавать ссылку с API Graph.
Вы имеете в виду, что если последняя часть (?e=fCWoUK) отсутствует, вы не можете прикрепить файл с помощью API addFileAttachmentAsync? Я попробовал оба URL-адреса, которыми вы поделились, и смог прикрепить оба файла, поскольку они общедоступны. не могли бы вы поделиться, какую ошибку вы получаете, когда используете URL-адрес без последней части ?e=fCWoUK?
Еще раз спасибо за ваше время! Сообщение об ошибке отсутствует. Ответом [addFileAttachmentAsync] является OSF.DDA.AsyncResult {значение: "b5db42d1-a33c-4b2a-9eb8-96f406feeea915556209423260", статус: "успешно"}. Если я использую URL-адрес без последней части, получает только небольшая часть файла. загружен. Вы можете увидеть разницу в изображениях в исходном сообщении.
Можете ли вы помочь мне со следующим: Вы видите эту проблему в веб-приложении Outlook, клиентах для настольных компьютеров (Windows или Mac) или мобильных устройствах? Также не могли бы вы поделиться скриншотом случая, когда, как вы говорите, загружается небольшая часть файла.
@OutlookAdd-insTeam-MSFT Мы используем веб-приложение Outlook, и вы можете найти скриншот частично загруженного файла в URL-адресе, который я добавил в исходное сообщение в прошлый раз. (softmakersbv-my.sharepoint.com/:i:/g/personal/…)
1. Мы просмотрели снимок экрана, которым вы поделились, но не смогли понять, что вы подразумеваете под вложением, прикрепленным частично? Вы имеете в виду, что файл прикреплен, но после загрузки он не открывается в вашем приложении для просмотра изображений? 2. Когда вы говорите, что «Второй URL-адрес работает»: вы можете успешно прикрепить вложение, используя URL-адрес, загрузить его и правильно просмотреть в приложении для просмотра изображений?
Кроме того, 3. Здесь мы наблюдаем, что URL-адрес, которым вы поделились с нами, является html-страницей, и вы пытаетесь прикрепить HTML-страницу как (вероятно) имя файла png. HTML-страница успешно прикрепляется, но если вы попытаетесь загрузить такое вложение и просмотреть его в приложении ImageViewer, оно выдаст ошибку, поскольку файл не является png. Итак, убедитесь, что вы используете URL-адрес, который указывает непосредственно на ресурс изображения. Пример: softmakersbv-my.sharepoint.com/personal/tim_softmakers_nl/… в вашем API.
@OutlookAdd-insTeam-MSFT Пожалуйста, прочтите исходное сообщение; Первые 4 ссылки являются примерами источника прикрепляемого файла. Последние 2 ссылки - это просто скриншоты, показывающие разницу результатов. Если вы посмотрите на разницу в размере байтов между двумя снимками экрана, вы заключите с нами, что он частично загружен.
Не могли бы вы поделиться фрагментом кода, в котором вы используете addFileAttachmentAsync API?
@OutlookAdd-insTeam-MSFT Я добавил пример кода в исходное сообщение.
В addFileAttachmentAsync вы должны использовать URL-адрес изображения/файла (ресурса), который вам нужно прикрепить. В своем коде вы предоставляете URL-адрес HTML-страницы, на которой показано изображение. Например: Для этого URL: softmakersbv-my.sharepoint.com/:i:/g/personal/tim_softmakers_nl/… вы должны использовать softmakersbv-my.sharepoint.com/personal/tim_softmakers_nl/… в API.
Обратите внимание, что с URL: softmakersbv-my.sharepoint.com/:i:/g/personal/tim_softmakers_nl/… это также веб-страница (HTML), в которую встроено изображение.
Этот URL: softmakersbv-my.sharepoint.com/personal/tim_softmakers_nl/… также не будет работать в API, потому что он не является «действительно» общедоступным. Если вы откроете любой браузер в когнитивном (частном) режиме и нажмете на этот URL-адрес, вам будет предложено войти в систему, что доказывает, что это не общедоступный URL-адрес — требование для addFileAttachmentAsync API.
Хорошо @OutlookAdd-insTeam-MSFT Я хотел бы предоставить URL-адрес, отвечающий всем требованиям. Большой вопрос: как создать такой URL-адрес с помощью Graph API. Используя [sendLink], я получаю только те, что указаны выше. Какие вызовы API Graph следует использовать?
URI, который вы хотите использовать для addFileAttachmentAsync
API, должен быть общедоступным.
Для проверки, если вы откроете новый приватный браузер или режим инкогнито, вы сможете получить доступ к URI без входа в систему.
В этом случае первый URI (с добавленным &download=1) общедоступен, а второй — нет.
Пожалуйста, проверьте свой Graph API, чтобы сгенерировать общедоступный URI.
Спасибо за ваш вклад! Боюсь, это не исправление для меня. Остальная часть моего ответа в исходном сообщении
Пожалуйста, проверьте исходное сообщение для ответа
Решение этой проблемы оказалось более простым, чем предполагалось. Было ясно, что URL-адреса, предоставленные Graph API, не сокращают пирог. Команда надстроек Outlook ясно выразила это. Большой и остающийся вопрос был; как получить правильный URL-адрес из Graph.
Правильный ответ; вам не нужна такая функция, как createLink! Если вы просто используете идентификатор элемента файла OneDrive для получения свойств (например, https://graph.microsoft.com/v1.0//me/drive/items/01ATEIIBJLT455YK5FLISCBD37Y7SWE), вы найдете свойство @microsoft.graph.downloadUrl, которое содержит правильный URL-адрес. Этот URL-адрес действителен в течение часа и может успешно использоваться с addFileAttachmentAsync в Office.js.
Спасибо за время, которое вы, люди, вложили в мой вопрос.
Уилко.
Можете ли вы помочь мне с тем, какой API графа вы использовали?