Как вы загружаете файл в библиотеку документов в sharepoint? - PullRequest
43 голосов
/ 22 января 2009

Как программно загрузить файл в библиотеку документов в sharepoint?

В настоящее время я создаю приложение для Windows с использованием C #, которое будет добавлять документы в список библиотек документов.

Ответы [ 6 ]

63 голосов
/ 22 января 2009

Вы можете загружать документы в библиотеки SharePoint, используя объектную модель или SharePoint Webservices .

Загрузка с использованием объектной модели:

String fileToUpload = @"C:\YourFile.txt";
String sharePointSite = "http://yoursite.com/sites/Research/";
String documentLibraryName = "Shared Documents";

using (SPSite oSite = new SPSite(sharePointSite))
{
    using (SPWeb oWeb = oSite.OpenWeb())
    {
        if (!System.IO.File.Exists(fileToUpload))
            throw new FileNotFoundException("File not found.", fileToUpload);                    

        SPFolder myLibrary = oWeb.Folders[documentLibraryName];

        // Prepare to upload
        Boolean replaceExistingFiles = true;
        String fileName = System.IO.Path.GetFileName(fileToUpload);
        FileStream fileStream = File.OpenRead(fileToUpload);

        // Upload document
        SPFile spfile = myLibrary.Files.Add(fileName, fileStream, replaceExistingFiles);

        // Commit 
        myLibrary.Update();
    }
}
12 голосов
/ 05 декабря 2012

если вы получите эту ошибку " Значение не попадает в ожидаемый диапазон " в этой строке:

SPFolder myLibrary = oWeb.Folders[documentLibraryName];

используйте вместо этого, чтобы исправить ошибку:

SPFolder myLibrary = oWeb.GetList(URL OR NAME).RootFolder;

Всегда используйте URl для получения списков или других, потому что они уникальны, имена не лучший способ;)

8 голосов
/ 10 октября 2012
    string filePath = @"C:\styles\MyStyles.css"; 
    string siteURL = "http://MyDomain.net/"; 
    string libraryName = "Style Library"; 

    using (SPSite oSite = new SPSite(siteURL)) 
    { 
        using (SPWeb oWeb = oSite.OpenWeb()) 
        { 
            if (!System.IO.File.Exists(filePath)) 
                throw new FileNotFoundException("File not found.", filePath);                     

            SPFolder libFolder = oWeb.Folders[libraryName]; 

            // Prepare to upload 
            string fileName = System.IO.Path.GetFileName(filePath); 
            FileStream fileStream = File.OpenRead(filePath); 

            //Check the existing File out if the Library Requires CheckOut
            if (libFolder.RequiresCheckout)
            {
                try {
                    SPFile fileOld = libFolder.Files[fileName];
                    fileOld.CheckOut();
                } catch {}
            }

            // Upload document 
            SPFile spfile = libFolder.Files.Add(fileName, fileStream, true); 

            // Commit  
            myLibrary.Update(); 

            //Check the File in and Publish a Major Version
            if (libFolder.RequiresCheckout)
            {
                    spFile.CheckIn("Upload Comment", SPCheckinType.MajorCheckIn);
                    spFile.Publish("Publish Comment");
            }
        } 
    } 
5 голосов
/ 13 июля 2014

С новой библиотекой SharePoint 2013 мне удалось сделать что-то вроде этого:

    private void UploadToSharePoint(string p, out string newUrl)  //p is path to file to load
    {
        string siteUrl = "https://myCompany.sharepoint.com/site/";
        //Insert Credentials
        ClientContext context = new ClientContext(siteUrl);

        SecureString passWord = new SecureString();
        foreach (var c in "mypassword") passWord.AppendChar(c);
        context.Credentials = new SharePointOnlineCredentials("myUserName", passWord);
        Web site = context.Web;

        //Get the required RootFolder
        string barRootFolderRelativeUrl = "Shared Documents/foo/bar";
        Folder barFolder = site.GetFolderByServerRelativeUrl(barRootFolderRelativeUrl);

        //Create new subFolder to load files into
        string newFolderName = baseName + DateTime.Now.ToString("yyyyMMddHHmm");
        barFolder.Folders.Add(newFolderName);
        barFolder.Update();

        //Add file to new Folder
        Folder currentRunFolder = site.GetFolderByServerRelativeUrl(barRootFolderRelativeUrl + "/" + newFolderName);
        FileCreationInformation newFile = new FileCreationInformation { Content = System.IO.File.ReadAllBytes(@p), Url = Path.GetFileName(@p), Overwrite = true };
        currentRunFolder.Files.Add(newFile);
        currentRunFolder.Update();

        context.ExecuteQuery();

        //Return the URL of the new uploaded file
        newUrl = siteUrl + barRootFolderRelativeUrl + "/" + newFolderName + "/" + Path.GetFileName(@p);
    }
5 голосов
/ 22 января 2009

В качестве альтернативы веб-сервисам можно использовать вызов put document из RPC-интерфейса FrontPage. Это дает дополнительное преимущество, позволяя вам предоставлять метаданные (столбцы) в том же запросе, что и данные файла. Очевидным недостатком является то, что протокол немного более неясен (по сравнению с очень хорошо документированными веб-сервисами).

Справочное приложение, объясняющее использование Frontpage RPC, см. В проекте SharePad на CodePlex.

0 голосов
/ 08 мая 2019
        try
        {
            //Variablen für die Verarbeitung
            string source_file = @"C:\temp\offer.pdf";
            string web_url = "https://stackoverflow.sharepoint.com";
            string library_name = "Documents";
            string admin_name = "admin@stackoverflow.com";
            string admin_password = "Password";

            //Verbindung mit den Login-Daten herstellen
            var sercured_password = new SecureString();
            foreach (var c in admin_password) sercured_password.AppendChar(c);
            SharePointOnlineCredentials credent = new 
            SharePointOnlineCredentials(admin_name, sercured_password);

            //Context mit Credentials erstellen
            ClientContext context = new ClientContext(web_url);
            context.Credentials = credent;

            //Bibliothek festlegen
            var library = context.Web.Lists.GetByTitle(library_name);

            //Ausgewählte Datei laden
            FileStream fs = System.IO.File.OpenRead(source_file);

            //Dateinamen aus Pfad ermitteln
            string source_filename = Path.GetFileName(source_file);

            //Datei ins SharePoint-Verzeichnis hochladen
            FileCreationInformation fci = new FileCreationInformation();
            fci.Overwrite = true;
            fci.ContentStream = fs;
            fci.Url = source_filename;
            var file_upload = library.RootFolder.Files.Add(fci);

            //Ausführen
            context.Load(file_upload);
            context.ExecuteQuery();

            //Datenübertragen schließen
            fs.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message, "Fehler");
            throw;
        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...