Upload file to SharePoint Online with PnP.PowerShell
Hi All,
A few weeks ago i had to upload a File to a SharePoint Site with a PowerShell Script.
In this Blog Article i explain how i did it.
All you need is
- Azure AD Application
- Sharepoint Permission
- PnPPowerShell https://www.powershellgallery.com/packages/PnP.PowerShell/
Here is the File i want to upload and replace with my PowerShell Script (Documents/Project/Script/AADUsers.csv)
data:image/s3,"s3://crabby-images/1db98/1db983ee22e3a76e1676194949e164e3952747aa" alt=""
Azure AD Application
You need to create an Azure AD Application. Copy the Application ID, you will need that later for the PowerShell Script
data:image/s3,"s3://crabby-images/f26ba/f26bacf7fad1ac92e92947072dac7b0fc37067d5" alt=""
The Application need to have a ClientSecret. Copy the ClientSecret, you will need that later for the PowerShell Script.
Sadly you can't use Certificates with PnPPowerShell for Authentication.
data:image/s3,"s3://crabby-images/2494a/2494ae3158d38fc762285870306ce0632058a6cb" alt=""
You don't need any Permissions. These will be set in the Sharepoint Site.
data:image/s3,"s3://crabby-images/96481/964813f5a7c646398331cec6f55de7f4b14f94a2" alt=""
SharePoint Permission
Go to the Sharepoint Site you want to Upload open the "/_layouts/appinv.aspx" and enter the App ID and klick on lookup.
https://[tenant].sharepoint.com/sites/[siteName]/_layouts/appinv.aspx
data:image/s3,"s3://crabby-images/d63d1/d63d166d6c17b4a5ff3f23e8d8afeb3220e868a1" alt=""
Now we add the Permission. It has to be done with an XML File
Add-in permissions in SharePoint
https://docs.microsoft.com/en-us/sharepoint/dev/sp-add-ins/add-in-permissions-in-sharepoint
http://sharepoint/content/tenant #Tenancy
http://sharepoint/content/sitecollection #Site Collection
http://sharepoint/content/sitecollection/web #Website
http://sharepoint/content/sitecollection/web/list #List
https://docs.microsoft.com/en-us/sharepoint/dev/sp-add-ins/add-in-permissions-in-sharepoint
http://sharepoint/content/tenant #Tenancy
http://sharepoint/content/sitecollection #Site Collection
http://sharepoint/content/sitecollection/web #Website
http://sharepoint/content/sitecollection/web/list #List
In this Example the Following XML is Sufficient
<AppPermissionRequests AllowAppOnlyPolicy="true">
<AppPermissionRequest Scope="http://sharepoint/content/sitecollection/web/list" Right="FullControl"/>
</AppPermissionRequests>
data:image/s3,"s3://crabby-images/ae111/ae111628203397578cd3fa6116011df0ad3375ff" alt=""
On the next Page we select "Documents" and hit "Trust it"
data:image/s3,"s3://crabby-images/d74f2/d74f2e52431aad23e438620b514cc27534775b68" alt=""
You can't change the Settings. But under the Site Settings > Site collection App permissions you can view the Applications
data:image/s3,"s3://crabby-images/8d3f3/8d3f31bf6cab5f121b61a95f20a33ebe27056ac9" alt=""
As mentioned, you can't edit. Simply delete the App.
data:image/s3,"s3://crabby-images/d639e/d639e465cbb5062902097afa9185609afa477bdd" alt=""
PowerShell Script
And here is the PowerShell Script to Upload a File with PnPPowerShell
###############################################################################
# Upload file to SharePoint with PnP.PowerShell
# 23.01.2022 - Andres Bohren
###############################################################################
#Variables
$AppID = "0d1c73de-c74d-4b06-8a35-e53c8e190258"
$ClientSecret = "YourClientSecret"
$SiteURL = "https://icewolfch.sharepoint.com/sites/DemoTemplate/"
$FileURL = "Freigegebene Dokumente/Project/Script/AADUsers.csv"
#Connect-PnPOnline
Write-Output "Connect-PnPOnline"
Connect-PnPOnline -Url $SiteURL -ClientId $AppID -ClientSecret $ClientSecret -WarningAction Ignore
Get-PnPContext
#Items in Folder
$RelativeURL = "Freigegebene Dokumente/Project/Script"
$Items = Get-PnPFolderItem -FolderSiteRelativeUrl $RelativeURL
$Items
#Upload File
$CSVFile = "C:\GIT_WorkingDir\PowerShellScripts\SharePoint\AADUsers.csv"
Write-Output "Uploading CSV to Sharepoint"
$FolderObject = Get-PnPFolder -Url $RelativeURL
$Upload = Add-PnPFile -Path $CSVFile -Folder $FolderObject
If ($Upload -ne $null)
{
Write-Output "File sucessfully uploaded"
}
# Upload file to SharePoint with PnP.PowerShell
# 23.01.2022 - Andres Bohren
###############################################################################
#Variables
$AppID = "0d1c73de-c74d-4b06-8a35-e53c8e190258"
$ClientSecret = "YourClientSecret"
$SiteURL = "https://icewolfch.sharepoint.com/sites/DemoTemplate/"
$FileURL = "Freigegebene Dokumente/Project/Script/AADUsers.csv"
#Connect-PnPOnline
Write-Output "Connect-PnPOnline"
Connect-PnPOnline -Url $SiteURL -ClientId $AppID -ClientSecret $ClientSecret -WarningAction Ignore
Get-PnPContext
#Items in Folder
$RelativeURL = "Freigegebene Dokumente/Project/Script"
$Items = Get-PnPFolderItem -FolderSiteRelativeUrl $RelativeURL
$Items
#Upload File
$CSVFile = "C:\GIT_WorkingDir\PowerShellScripts\SharePoint\AADUsers.csv"
Write-Output "Uploading CSV to Sharepoint"
$FolderObject = Get-PnPFolder -Url $RelativeURL
$Upload = Add-PnPFile -Path $CSVFile -Folder $FolderObject
If ($Upload -ne $null)
{
Write-Output "File sucessfully uploaded"
}
data:image/s3,"s3://crabby-images/4db9a/4db9ab1142957111767a2980481925902d24be57" alt=""
data:image/s3,"s3://crabby-images/6f502/6f5029d62d2e086a1cbbe79195e99e0fc61e01f3" alt=""
Regards
Andres Bohren
data:image/s3,"s3://crabby-images/cee64/cee64f015bff40aaa097f848f1580a118f21b3b2" alt=""