Загрузите файл в SharePoint через встроенные веб-службы
-
09-06-2019 - |
Вопрос
Каков наилучший способ загрузить файл в библиотеку документов на сервере SharePoint с помощью встроенных веб-служб, доступных в версии WSS 3.0?
Следуя двум первоначальным ответам...
Нам определенно нужно использовать уровень веб-сервиса, поскольку мы будем выполнять эти вызовы из удаленных клиентских приложений.
Метод WebDAV будет работать для нас, но мы предпочли бы быть совместимыми с методом интеграции веб-сервисов.
Кроме того, существует веб-сервис для загрузки файлов, болезненный, но работающий постоянно.
Вы имеете в виду услугу “Копирование”?Мы добились успеха с помощью этого сервиса CopyIntoItems
способ.Будет ли это рекомендуемым способом загрузки файла в библиотеки документов, используя только API веб-службы WSS?
Я опубликовал наш код в качестве предлагаемого ответа.
Решение
Пример использования веб-службы WSS "Копировать" для загрузки документа в библиотеку...
public static void UploadFile2007(string destinationUrl, byte[] fileData)
{
// List of desination Urls, Just one in this example.
string[] destinationUrls = { Uri.EscapeUriString(destinationUrl) };
// Empty Field Information. This can be populated but not for this example.
SharePoint2007CopyService.FieldInformation information = new
SharePoint2007CopyService.FieldInformation();
SharePoint2007CopyService.FieldInformation[] info = { information };
// To receive the result Xml.
SharePoint2007CopyService.CopyResult[] result;
// Create the Copy web service instance configured from the web.config file.
SharePoint2007CopyService.CopySoapClient
CopyService2007 = new CopySoapClient("CopySoap");
CopyService2007.ClientCredentials.Windows.ClientCredential =
CredentialCache.DefaultNetworkCredentials;
CopyService2007.ClientCredentials.Windows.AllowedImpersonationLevel =
System.Security.Principal.TokenImpersonationLevel.Delegation;
CopyService2007.CopyIntoItems(destinationUrl, destinationUrls, info, fileData, out result);
if (result[0].ErrorCode != SharePoint2007CopyService.CopyErrorCode.Success)
{
// ...
}
}
Другие советы
Другой вариант - использовать обычный HTTP PUT:
WebClient webclient = new WebClient();
webclient.Credentials = new NetworkCredential(_userName, _password, _domain);
webclient.UploadFile(remoteFileURL, "PUT", FilePath);
webclient.Dispose();
Где remoteFileURL указывает на вашу библиотеку документов SharePoint...
Есть пара вещей, которые следует учитывать:
- Копировать.Элементы CopyIntoItems
требуется, чтобы документ уже присутствовал на каком-либо сервере.Документ передается как параметр вызова webservice, который ограничивает размер документа.(См . http://social.msdn.microsoft.com/Forums/en-AU/sharepointdevelopment/thread/e4e00092-b312-4d4c-a0d2-1cfc2beb9a6c) - метод "http put" (т.Е. webdav ...) только поместит документ в библиотеку, но не установит значения полей
- чтобы обновить значения полей, вы можете вызвать списки.UpdateListItem после "http put"
- библиотеки документов могут иметь каталоги, вы можете создать их с помощью "http mkcol"
- возможно, вы захотите проверить файлы с помощью списков.Проверьте файл
- вы также можете создать пользовательский веб-сервис, который использует SPxxx .Net API, но этот новый веб-сервис должен быть установлен на сервере.Это могло бы сэкономить время на переходах на сервер.
public static void UploadFile(byte[] fileData) {
var copy = new Copy {
Url = "http://servername/sitename/_vti_bin/copy.asmx",
UseDefaultCredentials = true
};
string destinationUrl = "http://servername/sitename/doclibrary/filename";
string[] destinationUrls = {destinationUrl};
var info1 = new FieldInformation
{
DisplayName = "Title",
InternalName = "Title",
Type = FieldType.Text,
Value = "New Title"
};
FieldInformation[] info = {info1};
var copyResult = new CopyResult();
CopyResult[] copyResults = {copyResult};
copy.CopyIntoItems(
destinationUrl, destinationUrls, info, fileData, out copyResults);
}
ПРИМЕЧАНИЕ: Изменение 1-го параметра CopyIntoItems
к имени файла, Path.GetFileName(destinationUrl)
, приводит к исчезновению сообщения о разрыве связи.
Мне повезло с использованием класса-оболочки DocLibHelper, описанного здесь: http://geek.hubkey.com/2007/10/upload-file-to-sharepoint-document.html
От коллеги по работе:
Ленивый способ:интерфейс файловой системы Windows WebDAV.Это плохое программное решение, потому что оно полагается на службу WindowsClient, работающую в вашей операционной системе, а также работает только на веб-сайтах, работающих на порту 80.Сопоставьте диск с библиотекой документов и приступайте к копированию файла.
Кроме того, существует веб-сервис для загрузки файлов, болезненный, но работающий постоянно.
Я полагаю, что вы можете загружать файлы через FrontPage API, но я не знаю никого, кто действительно им пользуется.
Не уверен, какой именно веб-сервис использовать, но если вы в состоянии использовать библиотеки DLL SharePoint .NET API, то используйте SPList и SPLibrary.Товары.Добавить действительно просто.