質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
SharePoint

SharePointは、マイクロソフトにより開発された、ソフトウェア開発のドキュメント管理やコラボレーションを行うプラットフォームの総称です

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

Q&A

解決済

1回答

23516閲覧

PowerShellで、SharePoint Online上のファイルをダウンロードしたい。

mie.8

総合スコア28

SharePoint

SharePointは、マイクロソフトにより開発された、ソフトウェア開発のドキュメント管理やコラボレーションを行うプラットフォームの総称です

PowerShell

Windows PowerShellはコマンドラインインターフェースであり、システム管理を含むWindowsタスク自動化のためのスクリプト言語です。

0グッド

0クリップ

投稿2017/06/07 04:45

編集2017/06/08 05:28

前提・実現したい事

PowerShellを使い、SharePoint Online上のファイルを
ローカル(任意の場所)に保存したいと考えております。

発生している問題・Error Message

ネットで調べ、「Invoke-WebRequest -Uri <Uri> -OutFile <保存場所>」
のコマンドを試してみましたが、ダウンロードは出来るのですが、ファイルの中身が全て同じになってしまう。
容量:45KB
中身:<!DOCTYPE HTML PUBLIC "・・・ から始まり、約660行位ある「HTML」が書かれています。
*HTMLの知識が乏しい為、「何が・どんな事が」書いてあるかが分かりません。
恐らくログ??? 対象のページ情報丸々記載されている???

実際のソースコード

試したコード其の一
*認証無し

PowerShell

1<# 対象URL -- ファイル保存場所 -- #> 2$url = "https://○○○○/sites/Lesson/○○○○/Library/test.txt" 3 4<# 保存先パス -- ファイル名まで完全指定 -- #> 5$path = "C:\temp\test.txt" 6 7<# File Download Command #> # -- Pattern 1 -- # 8Invoke-WebRequest -Uri $url -OutFile $path

試したコード其の二
*どこかのサイトで、認証する。みたいな事が書いてあったので改良

PowerShell

1<# 対象URL -- ファイル保存場所 -- #> 2$url = "https://○○○○/sites/Lesson/○○○○/Library/test.txt" 3 4<# 保存先パス -- ファイル名まで完全指定 -- #> 5$path = "C:\temp\test.txt" 6 7<# File Download Command #> # -- Pattern 2 -- # 8$USER = "ユーザーID" 9$PASS = "パスワード" 10$secpasswd = ConvertTo-SecureString $PASS -AsPlainText -Force 11$cred = New-Object System.Management.Automation.PSCredential($USER, $secpasswd) 12Invoke-WebRequest -Uri $url -OutFile $path -Credential $cred

試した事

「DownloadFile」も試しましたが、エラーが出ました。
サーバー応答なし(403 or 404)みたいなエラー。。
調べた結果、SharePoint Onlineにログイン出切ていないエラーだと分かり、
其の二のプログラムを作成してみました。。

補足情報(言語/FW/ツール等のVersion)

・PowerShell Version 5.0
・SharePoint Online
・Window7(64bit)

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

こちらのソースコードで、無事ダウンロードする事が出来ました。

PowerShell

1[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client") | Out-Null 2[System.Reflection.Assembly]::LoadWithPartialName("Microsoft.SharePoint.Client.Runtime") | Out-Null 3 4$pass = convertto-securestring "password" -AsPlainText -Force 5$credentials = New-Object Microsoft.SharePoint.Client.SharePointOnlineCredentials("userAccount", $pass) 6$cookieValue = $credentials.GetAuthenticationCookie("https://xxxxxxx.sharepoint.com/sites/site/") 7 8$cookieValue = $cookieValue.Replace("SPOIDCRL=","") 9$cookie = New-Object System.Net.Cookie 10$cookie.Name = "SPOIDCRL" 11$cookie.Value = $cookieValue 12 13$cookieContainer = New-Object System.net.CookieContainer 14$cookieContainer.Add("https://xxxxxxx.sharepoint.com/sites/site/",$cookie) 15 16$request = [System.Net.WebRequest]::Create("https://xxxxxxx.sharepoint.com/sites/site/Shared%20Documents/test.xlsx") 17$request.CookieContainer = $cookieContainer 18$response = $request.GetResponse() 19$responseStream = $response.GetResponseStream() 20 21$outputFile = [System.IO.File]::Create("C:\work\test.xlsx") 22$Buffer = New-Object Byte[] 1024 23Do { 24 $BytesRead = $responseStream.Read($Buffer, 0, $Buffer.Length) 25 $outputFile.Write($Buffer, 0, $BytesRead) 26} While ($BytesRead -gt 0) 27 28$responseStream.Close() 29$responseStream.Dispose() 30 31$outputFile.Flush() 32$outputFile.Close() 33$outputFile.Dispose()

投稿2017/06/08 08:07

mie.8

総合スコア28

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問