Загрузите файл в SharePoint через встроенные веб-службы

StackOverflow https://stackoverflow.com/questions/31868

  •  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.Товары.Добавить действительно просто.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top