2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
3 "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
4 <html version="-//W3C//DTD XHTML 1.1//EN"
5 xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"
6 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
7 xsi:schemaLocation="http://www.w3.org/1999/xhtml
8 http://www.w3.org/MarkUp/SCHEMA/xhtml11.xsd">
10 <meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
11 <meta name="google-site-verification" content="MxsMq6bdLOx0KSuz1MY6yG9ZTIJ7_7DVRfl5NCAT5Yg"/>
12 <title>ImageMagick: Encipher or Decipher an Image</title>
13 <meta http-equiv="content-language" content="en-US"/>
14 <meta http-equiv="content-type" content="text/html; charset=utf-8"/>
15 <meta http-equiv="reply-to" content="magick-users@imagemagick.org"/>
16 <meta name="application-name" content="ImageMagick"/>
17 <meta name="description" content="Use ImageMagick to convert, edit, or compose bitmap images in a variety of formats. In addition resize, rotate, shear, distort and transform images automagically."/>
18 <meta name="application-url" content="http://www.imagemagick.org"/>
19 <meta name="generator" content="PHP"/>
20 <meta name="keywords" content="encipher, or, decipher, an, image, ImageMagick, PerlMagick, image processing, OpenMP, software development library, image, photo, software, Magick++, MagickWand"/>
21 <meta name="rating" content="GENERAL"/>
22 <meta name="robots" content="INDEX, FOLLOW"/>
23 <meta name="generator" content="ImageMagick Studio LLC"/>
24 <meta name="author" content="ImageMagick Studio LLC"/>
25 <meta name="revisit-after" content="2 DAYS"/>
26 <meta name="resource-type" content="document"/>
27 <meta name="copyright" content="Copyright (c) 1999-2013 ImageMagick Studio LLC"/>
28 <meta name="distribution" content="Global"/>
29 <link rel="icon" href="../images/wand.png"/>
30 <link rel="shortcut icon" href="../images/wand.ico" type="images/x-icon"/>
31 <link rel="canonical" href="http://www.imagemagick.org" />
32 <link rel="meta" type="application/rdf+xml" title="ICI" href="http://imagemagick.org/ici.rdf"/>
33 <!-- Add jQuery library -->
34 <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
36 <!-- Optionaly include easing and/or mousewheel plugins -->
37 <script type="text/javascript" src="http://www.imagemagick.org/fancybox/jquery.easing-1.3.pack.js"></script>
38 <script type="text/javascript" src="http://www.imagemagick.org/fancybox/jquery.mousewheel-3.0.6.pack.js"></script>
41 <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/jquery.fancybox.css?v=2.0.4" type="text/css" media="screen" />
42 <script type="text/javascript" src="http://www.imagemagick.org/fancybox/jquery.fancybox.pack.js?v=2.0.4"></script>
44 <!-- Optionaly include button and/or thumbnail helpers -->
45 <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-buttons.css?v=2.0.4" type="text/css" media="screen" />
46 <script type="text/javascript" src="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-buttons.js?v=2.0.4"></script>
48 <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-thumbs.css?v=2.0.4" type="text/css" media="screen" />
49 <script type="text/javascript" src="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-thumbs.js?v=2.0.4"></script>
50 <script type="text/javascript">
51 $(document).ready(function() {
52 $(".fancybox").fancybox();
55 <!-- ImageMagick style -->
56 <link rel="stylesheet" href="http://www.google.com/cse/style/look/default.css" type="text/css" />
57 <style type="text/css" media="all">
58 @import url("../www/magick.css");
62 <body id="www-imagemagick-org">
63 <div class="titlebar">
64 <div style="margin: 17px auto; float: left;">
65 <script type="text/javascript">
67 google_ad_client = "pub-3129977114552745";
68 google_ad_slot = "5439289906";
69 google_ad_width = 728;
70 google_ad_height = 90;
73 <script type="text/javascript"
74 src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
77 <a href="../discourse-server">
78 <img src="../images/logo.jpg"
79 alt="ImageMagick Logo"
80 style="width: 123px; height: 118px; border: 0px; float: right;" /></a>
81 <a href="../index.html">
82 <img src="../images/sprite.jpg"
83 alt="ImageMagick Sprite"
84 style="width: 114px; height: 118px; border: 0px; float: right;" /></a>
90 <a title="About ImageMagick" href="../index.html">About ImageMagick</a>
93 <a title="Binary Releases" href="binary-releases.html">Binary Releases</a>
96 <a title="Binary Release: Unix" href="binary-releases.html#unix">Unix</a>
99 <a title="Binary Release: MacOS X" href="binary-releases.html#macosx">Mac OS X</a>
102 <a title="Binary Release: iOS" href="binary-releases.html#iOS">iOS</a>
105 <a title="Binary Release: Windows" href="binary-releases.html#windows">Windows</a>
107 <div class="sep"></div>
109 <a title="Command-line Tools" href="command-line-tools.html">Command-line Tools</a>
112 <a title="Command-line Tools: Processing" href="command-line-processing.html">Processing</a>
115 <a title="Command-line Tools: Options" href="command-line-options.html">Options</a>
118 <a title="Command-line Tools: Usage" href="http://www.imagemagick.org/Usage/">Usage</a>
121 <a title="Program Interfaces" href="api.html">Program Interfaces</a>
124 <a title="Program Interface: MagickWand" href="magick-wand.html">MagickWand</a>
127 <a title="Program Interface: MagickCore" href="magick-core.html">MagickCore</a>
130 <a title="Program Interface: PerlMagick" href="perl-magick.html">PerlMagick</a>
133 <a title="Program Interface: Magick++" href="magick++.html">Magick++</a>
135 <div class="sep"></div>
137 <a title="Install from Source" href="install-source.html">Install from Source</a>
140 <a title="Install from Source: Unix" href="install-source.html#unix">Unix</a>
143 <a title="Install from Source: Windows" href="install-source.html#windows">Windows</a>
146 <a title="Resources" href="resources.html">Resources</a>
149 <a title="Architecture" href="architecture.html">Architecture</a>
152 <a title="Download" href="download.html">Download</a>
154 <div class="sep"></div>
156 <a title="Search" href="search.html">Search</a>
158 <div class="sep"></div>
160 <a title="Site Map" href="sitemap.html">Site Map</a>
163 <a title="Site Map: Links" href="links.html">Links</a>
165 <div class="sep"></div>
167 <a rel="follow" title="Sponsors" href="sponsors.html">Sponsors:</a>
169 <a href="http://www.networkredux.com"> <img src="../images/networkredux.png" width="140" height="31" alt="[sponsor]" style="margin-top: 4px; margin-left: 4px; border: 0px; float: left;" /></a>
170 <a href="http://www.dinodirect.com/ipads-tablets/"> <img src="../images/dino-direct.jpg" width="140" height="90" alt="[sponsor]" style="margin-top: 4px; margin-left: 4px; border: 0px; float: left;" /></a><!-- 201208010120 mickey@163... -->
171 <div class="sponsbox">
172 <div class="sponsor">
173 <a rel="follow" title="Sponsor: The Fastest & Easiest Way to Find Images" href="http://www.graphicsfactory.com">The Fastest & Easiest Way to Find Images</a><!-- 201210010270 graphicsfac... -->
175 <div class="sponsor">
176 <a rel="follow" title="Sponsor: VPS" href="http://www.interdominios.com/vps">VPS</a><!-- 201209010090 barsh@inter... -->
178 <div class="sponsor">
179 <a rel="follow" title="Werbebanner Werbeplane" href="http://www.allesbanner.de">Werbebanner Werbeplane</a><!-- 201212010450 info@druck... -->
181 <div class="sponsor">
182 <a rel="follow" title="Entertainment News & Photos" href="http://www.zimbio.com">Entertainment News & Photos</a><!-- 201211010540 bd@zimb... -->
184 <div class="sponsor">
185 <a rel="follow" title="Sponsor: LED24" href="http://led24.de/">LED24</a><!-- 201207010270 info@led24... -->
187 <div class="sponsor">
188 <a rel="follow" title="Sponsor: Best Website Hosting" href="http://www.top-cheap-web-hosting.com">Best Website Hosting</a><!-- 201304010090 eunge.liu-->
190 <div class="sponsor">
191 <a rel="follow" title="Android Tablet" href="http://www.dinodirect.com/ipads-tablets/">Android Tablet</a><!-- 201208010120 mickey@163... -->
193 <div class="sponsor">
194 <a rel="follow" title="Sponsor: Web Site Hosting" href="http://webhostinggeeks.com">Web Site Hosting</a><!-- 201302010900 funds@enmob... -->
196 <div class="sponsor">
197 <a rel="follow" title="Sponsor: Premium Quality Stock Photos" href="http://www.f1online.pro/en/">Premium Quality Stock Photos</a><!-- 2012080100540 ... -->
199 <div class="sponsor">
200 <a rel="follow" title="Sponsor: Druckerei" href="http://print24.com/de/">Druckerei</a><!-- 2012070100250 ... -->
202 <div class="sponsor">
203 <a rel="follow" title="Sponsor: Managed Server" href="http://www.robhost.de">Managed Server</a><!-- 201210010720 klikics... -->
205 <div class="sponsor">
206 <a rel="follow" title="Sponsor: Druckerei" href="http://www.allesdruck.de">Druckerei</a><!-- 201303011500 r.leo -->
208 <div class="sponsor">
209 <a rel="follow" title="Sponsor: Notebook Reparatur" href="http://www.notebook-reparaturen-berlin.de">Notebook Reparatur</a><!-- 2012080100300 atlas-multimedia-->
211 <div class="sponsor">
212 <a rel="follow" title="Sponsor: Web Hosting" href="http://www.hostucan.com">Web Hosting</a><!-- 2012120100150 racent marketing@webhosting...-->
218 <div class="eastbar">
219 <div class="g-plusone" id="gplusone"></div>
220 <script type="text/javascript">
226 var po = document.createElement('script');
227 po.type = 'text/javascript'; po.async = true;
228 po.src = 'https://apis.google.com/js/plusone.js';
229 var script = document.getElementsByTagName('script')[0];
230 script.parentNode.insertBefore(po, script);
232 var gplusone = document.getElementById("gplusone");
233 gplusone.setAttribute("data-size","medium");
234 gplusone.setAttribute("data-count","false");
240 <h1>Enciphering and Deciphering Images</h1>
241 <p class="navigation-index">[<a href="cipher.html#encipher">Encipher an Image</a> • <a href="cipher.html#decipher">Decipher an Image</a> • <a href="cipher.html#caveats">Encipher and Decipher Caveats</a>]</p>
243 <div class="doc-section">
245 <p>Most images, by design, are made to be viewed often and by many people. Web images, for example, may be viewed hundreds of times a day by a multitude of web vistors. However, in some cases, you may want to keep a particular image private so that only you or perhaps a select group of your friends or web visitors can view it. ImageMagick permits you to scramble your images such that unless someone knows your passphrase, they will be unable to view the original content.</p>
247 <p>You could use an <a href="http://www.wizards-toolkit.org/www/encipher.html">enciphering</a> utility to scramble your image but they typically scramble the entire file making it unrecognizable as an image format. With ImageMagick, only the pixels are scrambled. The scrambled image continues to be recognized as an image and will even display in your web page. However, the content appears as gibberish, nothing like the original content.</p>
251 <h2><a id="encipher"></a>Encipher an Image</h2>
252 <div class="doc-section">
254 <p>Use the <a href="command-line-options.html#encipher">-encipher</a> option to scramble your image so that it is unrecognizable. The option requires a filename that contains your passphrase. In this example we scramble an image and save it in the PNG format:</p>
256 <p class='crt'><span class="crtprompt"> $ </span><span class='crtin'>convert rose.jpg -encipher passphrase.txt rose.png</span></p>
257 <p>Here we encipher an image using another image as the passphrase:</p>
259 <p class='crt'><span class="crtprompt"> $ </span><span class='crtin'>convert rose.jpg -encipher smiley.gif rose.png</span></p>
262 <h2><a id="decipher"></a>Decipher an Image</h2>
263 <div class="doc-section">
265 <p>Use the <a href="command-line-options.html#decipher">-decipher</a> option to unscramble your image so that it is recognizable once again. The option requires a filename that contains your passphrase. In this example we unscramble an image and save it in the JPEG format:</p>
267 <p class='crt'><span class="crtprompt"> $ </span><span class='crtin'>convert rose.png -decipher passphrase.txt rose.jpg</span></p>
270 <h2><a id="caveats"></a>Encipher and Decipher Caveats</h2>
271 <div class="doc-section">
273 <p>Some formats do not support enciphered pixels-- the JPEG or GIF format, for
274 example. To ensure your image format is supported, encipher a test image and
275 verify you can restore its original content <em>before</em> you encipher any
276 additional images in that format.</p>
278 <p>The image format also should be 8-bit and RGB (TrueColor). As such you may
279 like to include the options "-depth 8 -type TrueColor" before the output
282 <p>The passphrase can be any combinations of letters and symbols. It should
283 be a minimum of 12 character combinations to help ensure your image remains
284 private. Also make sure your passphrase file permissions prevent others from
285 reading it otherwise unintended users may be able to view the original image
288 <p>You can only restore the original image content if you know your
289 passphrase. If you lose or forget it, your original image content is lost
292 <p>ImageMagick only scrambles the image pixels. The image metadata remains
293 untouched and readable by anyone with access to the image file.</p>
295 <p>ImageMagick uses the <a
296 href="http://en.wikipedia.org/wiki/Advanced_Encryption_Standard">AES</a>
297 cipher in cipher feedback mode. We use the passphrase to derive the cipher
298 key and the required nonce.</p>
300 <p>Currently only ImageMagick can restore your enciphered image content. We
301 use a standard cipher and mode so other vendors are encouraged to support
302 enciphered image content.</p>
304 <p>Some small practical examples of image enciphering can be found in IM
305 Examples <a href="http://www.imagemagick.org/Usage/transform/#encipher"
306 >Encrypting Image Data</a>. </p>
313 <span id="linkbar-west"> </span>
314 <span id="linkbar-center">
315 <a href="../discourse-server">Discourse Server</a> •
316 <a href="http://www.imagemagick.org/MagickStudio/scripts/MagickStudio.cgi">Studio</a>
318 <span id="linkbar-east"> </span>
321 <span id="footer-west">© 1999-2013 ImageMagick Studio LLC</span>
322 <span id="footer-east"> <a href="contact.html">Contact the Wizards</a></span>
324 <div style="clear: both; margin: 0; width: 100%; "></div>
325 <script type="text/javascript">
326 var _gaq = _gaq || [];
327 _gaq.push(['_setAccount', 'UA-17690367-1']);
328 _gaq.push(['_trackPageview']);
331 var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
332 ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
333 var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);