Senden und Empfangen von Dateien mithilfe von Bots
Wichtig
Dieser Artikel basiert auf dem Bot Framework SDK v3. Wenn Sie nach der aktuellen Dokumentationsversion 4.6 oder höher des SDK suchen, lesen Sie den Abschnitt Konversationsbots .
Es gibt zwei Möglichkeiten zum Senden von Dateien an und von einem Bot:
- Verwenden der Microsoft Graph-APIs Diese Methode funktioniert für Bots in allen Bereichen in Teams:
personal
channel
groupchat
- Verwenden der Teams-APIs Diese unterstützen nur Dateien in einem Kontext:
personal
Verwenden der Microsoft Graph-APIs
Sie können Nachrichten mit Kartenanlagen, die auf vorhandene SharePoint-Dateien verweisen, mithilfe der Microsoft Graph-APIs für OneDrive und SharePoint posten. Die Verwendung der Graph-APIs erfordert den Zugriff auf den OneDrive-Ordner eines Benutzers (für personal
- und groupchat
-Dateien) oder die Dateien in den Kanälen eines Teams (für channel
-Dateien) über den standardmäßigen OAuth 2.0-Autorisierungsfluss. Diese Methode funktioniert in allen Teams-Bereichen.
Verwenden der Teams-Bot-APIs
Hinweis
Diese Methode funktioniert nur im personal
-Kontext. Sie funktioniert weder im channel
- noch im groupchat
-Kontext.
Mit Teams-APIs kann der Bot Dateien an Benutzer im personal
-Kontext, auch als persönliche Chats bezeichnet, direkt senden und von diesen empfangen. Auf diese Weise können Sie Spesenabrechnung, Bilderkennung, Dateiarchivierung, E-Signaturen und andere Szenarien implementieren, die eine direkte Bearbeitung von Dateiinhalten beinhalten. In Teams freigegebene Dateien werden in der Regel als Karten angezeigt und ermöglichen eine umfassende Anzeige in der App.
In den folgenden Abschnitten wird beschrieben, wie Sie dies tun, um Dateiinhalte als Ergebnis direkter Benutzerinteraktion, wie das Versenden einer Nachricht, zu versenden. Diese API wird als Teil der Microsoft Teams-Bot-Plattform bereitgestellt.
Konfigurieren Ihres Bots zur Unterstützung von Dateien
Um Dateien in Ihrem Bot zu senden und zu empfangen, müssen Sie die supportsFiles
-Eigenschaft im Manifest auf true
festlegen. Diese Eigenschaft wird im Abschnitt Bots der Manifestreferenz beschrieben.
Die Definition sieht wie folgt aus: "supportsFiles": true
. Wenn Ihr Bot nicht aktiviert supportsFiles
, funktionieren die folgenden Features nicht.
Empfangen von Dateien im persönlichen Chat
Wenn ein Benutzer eine Datei an Ihren Bot sendet, wird die Datei zuerst in den OneDrive for Business-Speicher des Benutzers hochgeladen. Ihr Bot erhält dann eine Nachrichtenaktivität, die Sie über den Benutzerupload informiert. Die Aktivität enthält Dateimetadaten, z. B. den Namen und die Inhalts-URL. Sie können direkt aus dieser URL lesen, um den binären Inhalt abzurufen.
Beispiel für Nachrichtenaktivität mit Dateianlage
{
"attachments": [{
"contentType": "application/vnd.microsoft.teams.file.download.info",
"contentUrl": "https://contoso.sharepoint.com/personal/johnadams_contoso_com/Documents/Applications/file_example.txt",
"name": "file_example.txt",
"content": {
"downloadUrl" : "https://download.link",
"uniqueId": "1150D938-8870-4044-9F2C-5BBDEBA70C9D",
"fileType": "txt",
"etag": "123"
}
}]
}
In der folgenden Tabelle werden die Inhaltseigenschaften der Anlage beschrieben:
Eigenschaft | Zweck |
---|---|
downloadUrl |
OneDrive-URL zum Abrufen des Dateiinhalts Sie können eine HTTP GET direkt über diese URL ausgeben. |
uniqueId |
Eindeutige Datei-ID Dies ist die OneDrive-Laufwerkelement-ID, wenn der Benutzer eine Datei an Ihren Bot sendet. |
fileType |
Dateierweiterungstyp, z. B. pdf oder docx. |
In der Regel sollten Sie den Dateiupload bestätigen, indem Sie eine Nachricht an den Benutzer senden.
Hochladen von Dateien in einen persönlichen Chat
Das Hochladen einer Datei für einen Benutzer umfasst die folgenden Schritte:
- Senden Sie eine Nachricht an den Benutzer, in der Sie um die Berechtigung zum Schreiben der Datei bitten. Diese Nachricht muss eine
FileConsentCard
-Anlage mit dem Namen der hochzuladenden Datei enthalten. - Wenn der Benutzer den Dateidownload akzeptiert, erhält Ihr Bot eine Invoke-Aktivität mit einer Standort-URL.
- Um die Datei zu übertragen, führt Ihr Bot einen
HTTP POST
direkt in die angegebene Speicherort-URL aus. - Optional können Sie die ursprüngliche Zustimmungskarte entfernen, wenn Sie dem Benutzer nicht erlauben möchten, weitere Uploads derselben Datei zu akzeptieren.
Nachricht für die Anforderung der Berechtigung zum Hochladen
Diese Desktopnachricht enthält ein einfaches Anlageobjekt, in dem der Benutzer um die Berechtigung zum Hochladen der Datei gebeten wird:
Die mobile Nachricht enthält ein Anlageobjekt, das die Benutzerberechtigung zum Hochladen der Datei anfordert:
{
"attachments": [{
"contentType": "application/vnd.microsoft.teams.card.file.consent",
"name": "file_example.txt",
"content": {
"description": "<Purpose of the file, such as: this is your monthly expense report>",
"sizeInBytes": 1029393,
"acceptContext": {
},
"declineContext": {
}
}
}]
}
In der folgenden Tabelle werden die Inhaltseigenschaften der Anlage beschrieben:
Eigenschaft | Zweck |
---|---|
description |
Beschreibung der Datei Kann dem Benutzer angezeigt werden, um den Zweck zu beschreiben oder den Inhalt zusammenzufassen. |
sizeInBytes |
Bietet dem Benutzer eine Schätzung der Dateigröße und des Speicherplatzes, der in OneDrive benötigt wird. |
acceptContext |
Zusätzlicher Kontext, der automatisch an Ihren Bot übertragen wird, wenn der Benutzer die Datei akzeptiert. |
declineContext |
Zusätzlicher Kontext, der automatisch an Ihren Bot übertragen wird, wenn der Benutzer die Datei ablehnt. |
Aufrufaktivität, wenn der Benutzer die Datei akzeptiert
Eine Aufrufaktivität wird an Ihren Bot gesendet, wenn der Benutzer die Datei akzeptiert. Sie enthält die OneDrive for Business-Platzhalter-URL, damit Ihr Bot dann eine PUT
ausstellen kann, um den Dateiinhalt zu übertragen. Informationen zum Hochladen in die OneDrive-URL finden Sie in diesem Artikel: Hochladen von Bytes in die Uploadsitzung.
Das folgende Beispiel zeigt eine gekürzte Version der Aufrufaktivität, die Ihr Bot empfängt:
{
...
"name": "fileConsent/invoke",
"value": {
"type": "fileUpload",
"action": "accept",
"context": {
},
"uploadInfo": {
"contentUrl": "https://contoso.sharepoint.com/personal/johnadams_contoso_com/Documents/Applications/file_example.txt",
"name": "file_example.txt",
"uploadUrl": "https://upload.link",
"uniqueId": "1150D938-8870-4044-9F2C-5BBDEBA70C8C",
"fileType": "txt",
"etag": "123"
}
}
}
Wenn der Benutzer die Datei ablehnt, empfängt Ihr Bot auf ähnliche Weise das folgende Ereignis mit demselben Allgemeinen Aktivitätsnamen:
{
"name": "fileConsent/invoke",
"value": {
"type": "fileUpload",
"action": "decline",
"context": {
}
}
}
Benachrichtigen des Benutzers über eine hochgeladene Datei
Nachdem Sie eine Datei in die OneDrive-Instanz des Benutzers hochgeladen haben, sollten Sie unabhängig davon, ob Sie den oben beschriebenen Mechanismus oder benutzerdelegierte OneDrive-APIs verwenden, eine Bestätigungsmeldung an den Benutzer senden. Diese Nachricht sollte eine FileCard
Anlage enthalten, die der Benutzer auswählen kann, um eine Vorschau anzuzeigen, sie in OneDrive zu öffnen oder lokal herunterzuladen.
{
"attachments": [{
"contentType": "application/vnd.microsoft.teams.card.file.info",
"contentUrl": "https://contoso.sharepoint.com/personal/johnadams_contoso_com/Documents/Applications/file_example.txt",
"name": "file_example.txt",
"content": {
"uniqueId": "1150D938-8870-4044-9F2C-5BBDEBA70C8C",
"fileType": "txt",
}
}]
}
In der folgenden Tabelle werden die Inhaltseigenschaften der Anlage beschrieben:
Eigenschaft | Zweck |
---|---|
uniqueId |
OneDrive-/SharePoint-Laufwerkelement-ID |
fileType |
Dateityp, z. B. pdf oder docx. |
Einfaches Beispiel in C
Das folgende Beispiel zeigt, wie Sie Dateiuploads verarbeiten und Dateizustimmungsanforderungen im Dialogfeld Ihres Bots senden können:
// This sample dialog shows two simple flows:
// 1) A silly example of receiving a file from the user, processing the key elements,
// and then constructing the attachment and sending it back.
// 2) Creating a new file consent card requesting user permission to upload a file.
private async Task MessageReceivedAsync(IDialogContext context, IAwaitable<object> result)
{
var replyMessage = context.MakeMessage();
Attachment returnCard;
var message = await result as Activity;
// Check to see if the user is sending the bot a file.
if (message.Attachments != null && message.Attachments.Any())
{
var attachment = message.Attachments.First();
if (attachment.ContentType == FileDownloadInfo.ContentType)
{
FileDownloadInfo downloadInfo = (attachment.Content as JObject).ToObject<FileDownloadInfo>();
if (downloadInfo != null)
{
returnCard = CreateFileInfoAttachment(downloadInfo, attachment.Name, attachment.ContentUrl);
replyMessage.Attachments.Add(returnCard);
}
}
}
else
{
// Illustrates creating a file consent card.
returnCard = CreateFileConsentAttachment();
replyMessage.Attachments.Add(returnCard);
}
await context.PostAsync(replyMessage);
}
private static Attachment CreateFileInfoAttachment(FileDownloadInfo downloadInfo, string name, string contentUrl)
{
FileInfoCard card = new FileInfoCard()
{
FileType = downloadInfo.FileType,
UniqueId = downloadInfo.UniqueId
};
Attachment att = card.ToAttachment();
att.ContentUrl = contentUrl;
att.Name = name;
return att;
}
private static Attachment CreateFileConsentAttachment()
{
JObject acceptContext = new JObject();
// Fill in any additional context to be sent back when the user accepts the file.
JObject declineContext = new JObject();
// Fill in any additional context to be sent back when the user declines the file.
FileConsentCard card = new FileConsentCard()
{
AcceptContext = acceptContext,
DeclineContext = declineContext,
SizeInBytes = 102635,
Description = "File description"
};
Attachment att = card.ToAttachment();
att.Name = "Example file";
return att;
}
Siehe auch
Platform Docs