$i = 720 1..$i | ?{}
;)
$ar = @("a","b","c") invoke-command -ArgumentList $ar -ComputerName mypc1 -ScriptBlock {param($opts);write-host $opts;write-host $opts.length}
$ar = @("a","b","c") invoke-command -ArgumentList (,$ar) -ComputerName mypc1 -ScriptBlock {param($opts);write-host $opts;write-host $opts.count}
var a = (b == 1)?true:false;
$a = 4 @{$true=1;$false=0}[$a -lt 5]
function retValue($ret){ return " "+$ret } $b = 0 $a = @{$true=retValue "FOO!";$false=retValue "BAR!"}[$b -eq 1]
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Security.Cryptography; namespace SHA1Crypt { [System.Management.Automation.Cmdlet(System.Management.Automation.VerbsCommon.Get, "Encrypted")] public class Encrypt : System.Management.Automation.PSCmdlet { [System.Management.Automation.Parameter(Position = 0, Mandatory = true, HelpMessage = "String to be encrypted")] public string PlainString; [System.Management.Automation.Parameter(Position = 1, Mandatory = true, HelpMessage = "Pass Key should be the same as used to encrypt if decrypting")] public string passKey; protected override void ProcessRecord() { byte[] Results; System.Text.UTF8Encoding UTF8 = new System.Text.UTF8Encoding(); TripleDESCryptoServiceProvider TDESAlgorithm = new TripleDESCryptoServiceProvider(); SHA1CryptoServiceProvider HashProvider = new SHA1CryptoServiceProvider(); byte[] TDESKey = HashProvider.ComputeHash(UTF8.GetBytes(passKey)); byte[] key = new byte[24]; TDESKey.CopyTo(key, 0); TDESAlgorithm.Key = key; TDESAlgorithm.Mode = CipherMode.ECB; TDESAlgorithm.Padding = PaddingMode.PKCS7; byte[] DataToEncrypt = UTF8.GetBytes(PlainString); try { ICryptoTransform Encryptor = TDESAlgorithm.CreateEncryptor(); Results = Encryptor.TransformFinalBlock(DataToEncrypt, 0, DataToEncrypt.Length); } finally { TDESAlgorithm.Clear(); HashProvider.Clear(); } this.WriteObject(Convert.ToBase64String(Results), true); } } [System.Management.Automation.Cmdlet(System.Management.Automation.VerbsCommon.Get, "Decrypted")] public class Decrypt : System.Management.Automation.PSCmdlet { [System.Management.Automation.Parameter(Position = 0, Mandatory = true, HelpMessage = "Encrypted string to be decrypted")] public string EncryptedString; [System.Management.Automation.Parameter(Position = 1, Mandatory = true, HelpMessage = "Pass Key should be the same as used to encrypt if decrypting")] public string passKey; protected override void ProcessRecord() { byte[] Results; System.Text.UTF8Encoding UTF8 = new System.Text.UTF8Encoding(); TripleDESCryptoServiceProvider TDESAlgorithm = new TripleDESCryptoServiceProvider(); SHA1CryptoServiceProvider HashProvider = new SHA1CryptoServiceProvider(); byte[] TDESKey = HashProvider.ComputeHash(UTF8.GetBytes(passKey)); byte[] key = new byte[24]; TDESKey.CopyTo(key, 0); TDESAlgorithm.Key = key; TDESAlgorithm.Mode = CipherMode.ECB; TDESAlgorithm.Padding = PaddingMode.PKCS7; byte[] DataToDecrypt = Convert.FromBase64String(EncryptedString); try { ICryptoTransform Decryptor = TDESAlgorithm.CreateDecryptor(); Results = Decryptor.TransformFinalBlock(DataToDecrypt, 0, DataToDecrypt.Length); } finally { TDESAlgorithm.Clear(); HashProvider.Clear(); } this.WriteObject(UTF8.GetString(Results), true); } } }
Import-Module .\SHA1Crypt.dll Get-Module ModuleType Name ExportedCommands ---------- ---- ---------------- Binary SHA1Crypt {Get-Decrypted, Get-Encrypted} Get-Encrypted -PlainString woohoo -passKey thisismykey xhWWiEyQDhs= Get-Decrypted -EncryptedString xhWWiEyQDhs= -passKey thisismykey woohoo
param( [parameter(Mandatory = $true, HelpMessage = "Action type: e.g. Encrypt(E)/Decrypt(D)")] [string] $Action, [parameter(Mandatory = $true, HelpMessage = "Pass Key should be the same as used to encrypt if decrypting")] [string] $passKey, [parameter(Mandatory = $true, HelpMessage = "String to be encrypted or decrypted")] [string] $message ) [System.Reflection.Assembly]::LoadWithPartialName('System.Security.Cryptography') [System.Reflection.Assembly]::LoadWithPartialName('System.Collections.Generic') [System.Reflection.Assembly]::LoadWithPartialName('System.Text') $HashProvider = New-Object System.Security.Cryptography.SHA1CryptoServiceProvider $TDESAlgorithm = New-Object System.Security.Cryptography.TripleDESCryptoServiceProvider [Byte[]] $TDESKey = $HashProvider.ComputeHash([System.Text.UTF8Encoding]::UTF8.GetBytes($passKey)); $keyByte = New-Object byte[] 24 $TDESKey.CopyTo($keyByte, 0); $TDESAlgorithm.Key = $keyByte $TDESAlgorithm.Mode = [System.Security.Cryptography.CipherMode]::ECB $TDESAlgorithm.Padding = [System.Security.Cryptography.PaddingMode]::PKCS7 switch -regex ($Action.toLower()){ "d(ecrypt)?"{ try{ [Byte[]] $DataToDecrypt = [convert]::FromBase64String($Message) $Decryptor = $TDESAlgorithm.CreateDecryptor() $Results = $Decryptor.TransformFinalBlock($DataToDecrypt, 0, $DataToDecrypt.Length) }finally{ $TDESAlgorithm.Clear() $HashProvider.Clear() } return [System.Text.UTF8Encoding]::UTF8.GetString($Results) } "e(ncrypt)?"{ [Byte[]] $DataToEncrypt = [System.Text.UTF8Encoding]::UTF8.GetBytes($Message) try{ $Encryptor = $TDESAlgorithm.CreateEncryptor(); $Results = $Encryptor.TransformFinalBlock($DataToEncrypt, 0, $DataToEncrypt.Length); }finally{ $TDESAlgorithm.Clear(); $HashProvider.Clear(); } return [Convert]::ToBase64String($Results) } } <# .SYNOPSIS Encrypt or Decrypt strings with a pass key .DESCRIPTION Uses SHA1 Crypto provider to create a Hash of a pass key to tripledes encrypt/decrypt a string EDIT HISTORY: 08/10/2012 v1.0 Initial Release .PARAMETER Action Choose to Encrypt (E) or Decrypt (D) .PARAMETER passKey Pass key to be used to encrypt or decrypt a string .PARAMETER message String to be encrypted or decrypted .INPUTS None. .OUTPUTS Returns string .EXAMPLE PS > .\SHA1Crypt.ps1 -Action e -message testmessage -passKey thisismykey1 .EXAMPLE PS > .\SHA1Crypt.ps1 -Action Decrypt -message "IZTkBEuz6JbWvBlNQaN2wA==" -passKey thisismykey1 #>
function retBase64Image($path){ $newImg = [convert]::ToBase64String((get-content $path -encoding byte)) $ext = gci $path | select @{Name="Ext";Expression={$_.Extension.substring(1)}} | select -ExpandProperty Ext Write-Host "style='background:url(data:image/$ext;base64,$newImg) right bottom no-repeat'" Write-Host "<img src='data:image/$ext;base64,$newImg' />" } retBase64Image -path "C:\MyImages\Image1.gif"