繁体   English   中英

使用 Powershell 将文件上传到 Sharepoint Online (Microsoft 365)(选项 4 - 使用 Microsoft.SharePoint.Client.ClientContext)

[英]Upload file to Sharepoint Online (Microsoft 365) using Powershell (Option 4 - Using Microsoft.SharePoint.Client.ClientContext)

我正在尝试将文件上传到 Sharepoint Online (M365) 库,但它一直给我错误。 我尝试了很多脚本。 这篇文章是关于使用 Microsoft.SharePoint.Client.ClientContext (我已经发布了有关其他脚本的问题,希望有人可以帮助我解决任何问题)

这是代码:

$WebUrl = "https://myDomain.sharepoint.com/sites/mySite/"
$LibraryName ="myLibrary"
$SourceFile="C:\myFolder\myFile.csv"
$AdminName ="mail@myDomain.com"
$AdminPassword ="myPassword"
  
$Credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials($AdminName,(ConvertTo-SecureString $AdminPassword -AsPlainText -Force))
  
$Context = New-Object Microsoft.SharePoint.Client.ClientContext($WebUrl) 
$Context.Credentials = $Credentials
 
$Library =  $Context.Web.Lists.GetByTitle($LibraryName)
 
$FileStream = ([System.IO.FileInfo] (Get-Item $SourceFile)).OpenRead()
#Get File Name from source file path
$SourceFileName = Split-path $SourceFile -leaf
   
$FileCreationInfo = New-Object Microsoft.SharePoint.Client.FileCreationInformation
$FileCreationInfo.Overwrite = $true
$FileCreationInfo.ContentStream = $FileStream
$FileCreationInfo.URL = $SourceFileName
$FileUploaded = $Library.RootFolder.Files.Add($FileCreationInfo)
  
$Context.Load($FileUploaded) 
$Context.ExecuteQuery() 
 
$FileStream.Close()

刚开始,我有这个错误:

新对象:找不到类型 [Microsoft.SharePoint.Client.SharePointOnlineCredentials]:确保加载了包含此类型的程序集。

我想我必须加载它们。 我见过这个代码:

#Load SharePoint CSOM Assemblies
Add-Type -Path "C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\16\ISAPI\Microsoft.SharePoint.Client.dll"
Add-Type -Path "C:\Program Files\Common Files\Microsoft Shared\Web Server Extensions\16\ISAPI\Microsoft.SharePoint.Client.Runtime.dll"

但是我没有安装这样的库

奇怪的是,如果我以前执行此命令(只需执行,然后取消询问 URL 的提示):

Connect-PnPOnline

然后,不知何故,引用被加载,因为脚本然后完美地工作。

你能告诉我如何加载这些库吗?

终于我让这个脚本工作了!!

首先,您必须安装 SharePoint Online Management Shell:

https://docs.microsoft.com/en-us/powershell/sharepoint/sharepoint-online/connect-sharepoint-online?view=sharepoint-ps

基本上,执行:

Install-Module -Name Microsoft.Online.SharePoint.PowerShell

它会提示你安装 NuGet 包,而不是未安装

然后,找到您的库,并在开头添加路径。 就我而言:

#Load SharePoint CSOM Assemblies
Add-Type -Path "C:\Program Files\WindowsPowerShell\Modules\Microsoft.Online.SharePoint.PowerShell\16.0.21411.12000\Microsoft.SharePoint.Client.dll"
Add-Type -Path "C:\Program Files\WindowsPowerShell\Modules\Microsoft.Online.SharePoint.PowerShell\16.0.21411.12000\Microsoft.SharePoint.Client.Runtime.dll"

脚本就像魅力一样工作:)

注意:我从以下位置获得此脚本:

https://www.sharepointdiary.com/2016/06/upload-files-to-sharepoint-online-using-powershell.html

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM