You need to know what MIME type for the file, but they are pretty easy to discover. The most common ones I have used:
- image/gif
- image/x-icon
- image/vnd.microsoft.icon
- image/png
- image/jpeg
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 | ##### # # Base64.ps1 # Converts a file to or from base 64 # # Useful for generating data protocol image addresses: # In CSS: # background: #ff url('data:image/gif;base64,<Base64String>') # # In HTML: # <img src="data:image/gif;base64,<Base64String>" alt="X"> # # Usage (encode): # .\base64.ps1 favicon.ico favicon.b64 -encode # # Usage (encode & copy to clipboard): # .\base64.ps1 favicon.ico -encode -SetClipboard # # Usage (decode): # .\base64.ps1 favicon.b64 favicon.ico -decode # # ##### param ( [string] $source = $(Throw 'source: required parameter' ), [string] $destination = "" , [switch] $encode , [switch] $decode , [switch] $SetClipboard ) function Main { $file = Get-Item ( $source ); if ( $encode ) { $bytes = get-content -encoding byte $file .Fullname $result = [System.Convert]::ToBase64String( $bytes ); if ( $SetClipboard ) { Set -Clipboard $result ;} if ( $destination .length -eq 0) { return $result ; } else { set-content -encoding UTF8 -Path ".\$destination" -Value $result ; } } elseif ( $decode ) { $bytes = get-content -encoding UTF8 $file .Fullname; [System.Convert]::FromBase64String( $bytes ) | set-content -encoding Byte -Path ".\$destination" ; } else { Write-Host ( "The encode or decode switch is required." ); } } . Main |
For more information on Data URIs, refer to RFC2397 or the Wiki page for the Data URI Scheme for examples on how to use them.