Export-Clixml
1 つまたは複数のオブジェクトの XML ベースの表現を作成し、ファイルに格納します。
構文
Export-Clixml
[-Depth <Int32>]
[-Path] <String>
-InputObject <PSObject>
[-Force]
[-NoClobber]
[-Encoding <Encoding>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Export-Clixml
[-Depth <Int32>]
-LiteralPath <String>
-InputObject <PSObject>
[-Force]
[-NoClobber]
[-Encoding <Encoding>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
説明
コマンドレットは Export-Clixml
、オブジェクトまたはオブジェクトの共通言語インフラストラクチャ (CLI) XML ベースの表現を作成し、ファイルに格納します。 その後、 コマンドレットを Import-Clixml
使用して、そのファイルの内容に基づいて保存されたオブジェクトを再作成できます。
CLI の詳細については、「 言語の独立性」を参照してください。
このコマンドレットは、 に ConvertTo-Xml
似ていますが、結果の XML をファイルに格納する Export-Clixml
点が除きます。 ConvertTo-XML
は XML を返すので、PowerShell で引き続き処理できます。
Windows コンピューターでの の Export-Clixml
重要な用途は、資格情報とセキュリティで保護された文字列を XML として安全にエクスポートすることです。 例については、「例 3」を参照してください。
例
例 1: XML ファイルに文字列をエクスポートする
この例では、現在のディレクトリに格納する XML ファイルを作成します。これは テストです。
"This is a test" | Export-Clixml -Path .\sample.xml
文字列 This is a test
はパイプラインに送信されます。 Export-Clixml
は Path パラメーターを使用して、現在のディレクトリに という名前sample.xml
の XML ファイルを作成します。
例 2: オブジェクトを XML ファイルにエクスポートする
この例では、オブジェクトを XML ファイルにエクスポートし、エクスポートしたファイルから XML をインポートしてオブジェクトを作成する方法を示します。
Get-Acl C:\test.txt | Export-Clixml -Path .\FileACL.xml
$fileacl = Import-Clixml -Path .\FileACL.xml
コマンドレットは Get-Acl
、ファイルのセキュリティ記述子を Test.txt
取得します。 オブジェクトをパイプラインの下に送信して、セキュリティ記述子を に Export-Clixml
渡します。 オブジェクトの XML ベースの表現は、 という名前 FileACL.xml
のファイルに格納されます。
コマンドレットは Import-Clixml
、 ファイル内の XML から オブジェクトを FileACL.xml
作成します。 次に、 オブジェクトを 変数に $fileacl
保存します。
例 3: Windows でエクスポートされた資格情報オブジェクトを暗号化する
この例では、 コマンドレットを実行して変数に$Credential
格納した資格情報を指定すると、 コマンドレットをExport-Clixml
実行Get-Credential
して資格情報をディスクに保存できます。
重要
Export-Clixml
は、Windows で暗号化された資格情報のみをエクスポートします。 macOS や Linux などの Windows 以外のオペレーティング システムでは、資格情報は Unicode 文字配列として格納されたプレーン テキストとしてエクスポートされます。 これにより、いくつかの難読化が提供されますが、暗号化は提供されません。
$Credxmlpath = Join-Path (Split-Path $Profile) TestScript.ps1.credential
$Credential | Export-Clixml $Credxmlpath
$Credxmlpath = Join-Path (Split-Path $Profile) TestScript.ps1.credential
$Credential = Import-Clixml $Credxmlpath
コマンドレットは Export-Clixml
、Windows Data Protection API を使用して資格情報オブジェクトを暗号化します。 暗号化により、資格情報オブジェクトの内容を暗号化解除できるのは、そのコンピューター上のユーザー アカウントのみです。
エクスポートされた CLIXML
ファイルは、別のコンピューターまたは別のユーザーで使用することはできません。
この例では、資格情報が格納されているファイルは で TestScript.ps1.credential
表されます。 TestScript を、資格情報を読み込むスクリプトの名前に置き換えます。
パイプラインの下に資格情報オブジェクトを Export-Clixml
送信し、 $Credxmlpath
最初のコマンドで指定したパス () に保存します。
資格情報をスクリプトに自動的にインポートするには、最後の 2 つのコマンドを実行します。 を実行 Import-Clixml
して、セキュリティで保護された資格情報オブジェクトをスクリプトにインポートします。 このインポートにより、スクリプトでプレーンテキスト パスワードが公開されるリスクがなくなります。
例 4: Linux または macOS での資格情報オブジェクトのエクスポート
この例では、 コマンドレットを使用して、変数に $Credential
PSCredential をGet-Credential
作成します。 次に、 を使用 Export-Clixml
して資格情報をディスクに保存します。
重要
Export-Clixml
は、Windows で暗号化された資格情報のみをエクスポートします。 macOS や Linux などの Windows 以外のオペレーティング システムでは、資格情報は Unicode 文字配列として格納されたプレーン テキストとしてエクスポートされます。 これにより、いくつかの難読化が提供されますが、暗号化は提供されません。
PS> $Credential = Get-Credential
PowerShell credential request
Enter your credentials.
User: User1
Password for user User1: ********
PS> $Credential | Export-Clixml ./cred2.xml
PS> Get-Content ./cred2.xml
...
<Props>
<S N="UserName">User1</S>
<SS N="Password">700061007300730077006f0072006400</SS>
</Props>
...
PS> 'password' | Format-Hex -Encoding unicode
Label: String (System.String) <52D60C91>
Offset Bytes Ascii
00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F
------ ----------------------------------------------- -----
0000000000000000 70 00 61 00 73 00 73 00 77 00 6F 00 72 00 64 00 p a s s w o r d
この例の の Get-Content
出力は、XML ファイル内の資格情報に注目するために切り捨てられました。 パスワードのプレーン テキスト値は、 によって証明されている Unicode 文字配列として XML ファイルに Format-Hex
格納されることに注意してください。 そのため、値はエンコードされますが、暗号化されません。
パラメーター
-Confirm
コマンドレットの実行前に確認を求めるメッセージが表示されます。
Type: | SwitchParameter |
Aliases: | cf |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Depth
XML 表現に含める子オブジェクトのレベルを指定します。 既定値は 2
です。
既定値は、ファイル内のオブジェクトの種類に対して Types.ps1xml
オーバーライドできます。 詳細については、「 about_Types.ps1xml」を参照してください。
Type: | Int32 |
Position: | Named |
Default value: | 2 |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Encoding
ターゲット ファイルのエンコードの種類を指定します。 既定値は utf8NoBOM
です。
このパラメーターに使用できる値は次のとおりです。
ascii
: ASCII (7 ビット) 文字セットのエンコードを使用します。bigendianunicode
: ビッグ エンディアンのバイト順を使用して UTF-16 形式でエンコードします。bigendianutf32
: ビッグ エンディアンのバイト順を使用して UTF-32 形式でエンコードします。oem
: MS-DOS およびコンソール プログラムの既定のエンコードを使用します。unicode
: リトル エンディアンバイト順を使用して UTF-16 形式でエンコードします。utf7
: UTF-7 形式でエンコードします。utf8
: UTF-8 形式でエンコードします。utf8BOM
: バイト オーダー マーク (BOM) を使用して UTF-8 形式でエンコードしますutf8NoBOM
: バイト オーダー マーク (BOM) を使用せずに UTF-8 形式でエンコードしますutf32
: UTF-32 形式でエンコードします。
PowerShell 6.2 以降では、 Encoding パラメーターを使用すると、登録済みコード ページの数値 ID (など -Encoding 1251
) または登録済みコード ページの文字列名 (など -Encoding "windows-1251"
) も許可されます。 詳細については、 Encoding.CodePage の .NET ドキュメントを参照してください。
注意
UTF-7* の使用は推奨されなくなりました。 PowerShell 7.1 以降では、Encoding パラメーターに を指定utf7
すると警告が書き込まれます。
Type: | Encoding |
Accepted values: | ASCII, BigEndianUnicode, BigEndianUTF32, OEM, Unicode, UTF7, UTF8, UTF8BOM, UTF8NoBOM, UTF32 |
Position: | Named |
Default value: | UTF8NoBOM |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Force
ユーザーに確認せずに、直ちにコマンドを実行します。
必要に応じて、このコマンドレットは出力ファイルの読み取り専用の属性をクリアします。 コマンドが完了すると、このコマンドレットが読み取り専用の属性をリセットしようとします。
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-InputObject
変換するオブジェクトを指定します。 オブジェクトが格納されている変数を入力するか、オブジェクトを取得するコマンドまたは式を入力します。 オブジェクトを に Export-Clixml
パイプすることもできます。
Type: | PSObject |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-LiteralPath
オブジェクトの XML 表現が格納されるファイルへのパスを指定します。 Path とは異なり、LiteralPath パラメーターの値は、型指定されたとおりに使用されます。 ワイルドカードとして解釈される文字はありません。 パスにエスケープ文字が含まれている場合は、単一引用符で囲みます。 単一引用符は、文字をエスケープ シーケンスとして解釈しないように PowerShell に指示します。
Type: | String |
Aliases: | PSPath, LP |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-NoClobber
コマンドレットが既存のファイルの内容を上書きしないことを示します。 既定では、指定したパスにファイルが存在する場合は、 Export-Clixml
警告なしでファイルを上書きします。
Type: | SwitchParameter |
Aliases: | NoOverwrite |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Path
オブジェクトの XML 表現が格納されるファイルへのパスを指定します。
Type: | String |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-WhatIf
コマンドレットの実行時に発生する内容を示します。 コマンドレットは実行されません。
Type: | SwitchParameter |
Aliases: | wi |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
入力
任意のオブジェクトを に Export-Clixml
パイプラインできます。
出力
Export-Clixml
は、XML を含むファイルを作成します。