]> granicus.if.org Git - imagemagick/blob - www/cipher.html
(no commit message)
[imagemagick] / www / cipher.html
1
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">
9 <head>
10   <meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
11   <meta name="google-site-verification" content="_bMOCDpkx9ZAzBwb2kF3PRHbfUUdFj2uO8Jd1AXArz4"/>
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 or 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-2012 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
34   <!-- Add jQuery library -->
35   <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>
36   
37   <!-- Add mousewheel plugin (this is optional) -->
38   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/lib/jquery.mousewheel-3.0.6.pack.js"></script>
39   
40   <!-- Add fancyBox -->
41   <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/source/jquery.fancybox.css?v=2.0.6" type="text/css" media="screen" />
42   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/source/jquery.fancybox.pack.js?v=2.0.6"></script>
43   
44   <!-- Optionally add helpers - button, thumbnail and/or media -->
45   <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/source/helpers/jquery.fancybox-buttons.css?v=1.0.2" type="text/css" media="screen" />
46   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/source/helpers/jquery.fancybox-buttons.js?v=1.0.2"></script>
47   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/source/helpers/jquery.fancybox-media.js?v=1.0.0"></script>
48   
49   <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/source/helpers/jquery.fancybox-thumbs.css?v=2.0.6" type="text/css" media="screen" />
50   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/source/helpers/jquery.fancybox-thumbs.js?v=2.0.6"></script>
51   
52   <script type="text/javascript">
53         $(document).ready(function() {
54                 $(".fancybox").fancybox();
55         });
56   </script>
57
58   <!-- ImageMagick style -->
59   <style type="text/css" media="all">
60     @import url("../www/magick.css");
61   </style>
62 </head>
63
64 <body id="www-imagemagick-org">
65
66 <script>
67   (function(i,s,o,g,r,a,m){i['GoogleAnalyticsObject']=r;i[r]=i[r]||function(){
68   (i[r].q=i[r].q||[]).push(arguments)},i[r].l=1*new Date();a=s.createElement(o),
69   m=s.getElementsByTagName(o)[0];a.async=1;a.src=g;m.parentNode.insertBefore(a,m)
70   })(window,document,'offline-script','//127.0.0.1/analytics.js','ga');
71
72   ga('create', 'UA-40133312-1', 'imagemagick.org');
73   ga('send', 'pageview');
74 </script>
75
76 <div class="titlebar">
77 <div style="margin: 17px auto; float: left;">
78   <script type="text/javascript">
79   <!--
80     google_ad_client = "pub-3129977114552745";
81     google_ad_slot = "5439289906";
82     google_ad_width = 728;
83     google_ad_height = 90;
84   //-->
85   </script>
86   <script type="text/javascript"
87     src="http://127.0.0.1/pagead/show_ads.js">
88   </script>
89 </div>
90 <a href="http://www.imagemagick.org/discourse-server/">
91   <img src="../images/logo.jpg"
92   alt="ImageMagick Logo"
93   style="width: 123px; height: 118px; border: 0px; float: right;" /></a>
94 <a href="../index.html">
95   <img src="../images/sprite.jpg"
96   alt="ImageMagick Sprite"
97   style="width: 114px; height: 118px; border: 0px; float: right;" /></a>
98 </div>
99
100 <div class="westbar">
101
102 <div class="menu">
103   <a title="About ImageMagick" href="../index.html">About ImageMagick</a>
104 </div>
105 <div class="menu">
106   <a title="Binary Releases" href="binary-releases.html">Binary Releases</a>
107 </div>
108 <div class="sub">
109     <a title="Binary Release: Unix" href="binary-releases.html#unix">Unix</a>
110 </div>
111 <div class="sub">
112     <a title="Binary Release: MacOS X" href="binary-releases.html#macosx">Mac OS X</a>
113 </div>
114 <div class="sub">
115     <a title="Binary Release: iOS" href="binary-releases.html#iOS">iOS</a>
116 </div>
117 <div class="sub">
118     <a title="Binary Release: Windows" href="binary-releases.html#windows">Windows</a>
119 </div>
120 <div class="sep"></div>
121 <div class="menu">
122   <a title="Command-line Tools" href="command-line-tools.html">Command-line Tools</a>
123 </div>
124 <div class="sub">
125     <a title="Command-line Tools: Processing" href="command-line-processing.html">Processing</a>
126 </div>
127 <div class="sub">
128     <a title="Command-line Tools: Options" href="command-line-options.html">Options</a>
129 </div>
130 <div class="sub">
131     <a title="Command-line Tools: Usage" href="http://www.imagemagick.org/Usage/">Usage</a>
132 </div>
133 <div class="menu">
134   <a title="Program Interfaces" href="api.html">Program Interfaces</a>
135 </div>
136 <div class="sub">
137     <a title="Program Interface: MagickWand" href="magick-wand.html">MagickWand</a>
138 </div>
139 <div class="sub">
140     <a title="Program Interface: MagickCore" href="magick-core.html">MagickCore</a>
141 </div>
142 <div class="sub">
143     <a title="Program Interface: PerlMagick" href="perl-magick.html">PerlMagick</a>
144 </div>
145 <div class="sub">
146     <a title="Program Interface: Magick++" href="magick++.html">Magick++</a>
147 </div>
148 <div class="sep"></div>
149 <div  class="menu">
150    <a title="Install from Source" href="install-source.html">Install from Source</a>
151 </div>
152 <div class="sub">
153     <a title="Install from Source: Unix" href="install-source.html#unix">Unix</a>
154 </div>
155 <div class="sub">
156     <a title="Install from Source: Windows" href="install-source.html#windows">Windows</a>
157  </div>
158 <div class="menu">
159   <a title="Resources" href="resources.html">Resources</a>
160 </div>
161 <div class="menu">
162   <a title="Architecture" href="architecture.html">Architecture</a>
163 </div>
164 <div class="menu">
165   <a title="Download" href="download.html">Download</a>
166 </div>
167 <div class="sep"></div>
168 <div class="menu">
169   <a title="Search" href="search.html">Search</a>
170 </div>
171 <div class="sep"></div>
172 <div class="menu">
173   <a title="Site Map" href="sitemap.html">Site Map</a>
174 </div>
175 <div  class="sub">
176   <a title="Site Map: Links" href="links.html">Links</a>
177 </div>
178 <div class="sep"></div>
179 <div class="menu">
180   <a title="Support ImageMagick Development" href="support.html">Support ImageMagick Development</a>
181 </div>
182 </div>
183
184 <div class="eastbar">
185   <script type="text/javascript">
186     /* <![CDATA[ */
187     (function() {
188         var po = document.createElement('offline-script'), t = document.getElementsByTagName('offline-script')[0];
189         po.type = 'text/javascript';
190         po.async = true;
191         po.src = 'http://api.flattr.com/js/0.6/load.js?mode=auto';
192         var script = document.getElementsByTagName('offline-script')[0];
193         script.parentNode.insertBefore(po, script);
194     })();
195     /* ]]> */
196   </script>
197   <div> <a class="FlattrButton" style="display:none;" rev="flattr;button:compact;" href="http://www.imagemagick.org/"></a></div>
198   <noscript>
199     <a href="http://flattr.com/thing/947300/Convert-Edit-And-Compose-Images" target="_blank">
200     <img src="http://api.flattr.com/button/flattr-badge-large.png" alt="Flattr this" title="Flattr this" width="93" height="20" border="0" /></a>
201   </noscript>
202     <div class="g-plusone" id="gplusone"></div>
203     <script type="text/javascript">
204       /* <![CDATA[ */
205       window.___gcfg = {
206         lang: 'en-US'
207       };
208
209       (function() {
210         var po = document.createElement('offline-script');
211         po.type = 'text/javascript';
212         po.async = true;
213         po.src = 'https://127.0.0.1/js/plusone.js';
214         var script = document.getElementsByTagName('offline-script')[0];
215         script.parentNode.insertBefore(po, script);
216       })();
217       var gplusone = document.getElementById("gplusone");
218       gplusone.setAttribute("data-size","medium");
219       gplusone.setAttribute("data-count","true");
220       /* ]]> */
221     </script>
222 </div>
223
224 <div class="main">
225
226 <h1>Enciphering and Deciphering Images</h1>
227 <p class="navigation-index">[<a href="cipher.html#encipher">Encipher an Image</a> &#8226; <a href="cipher.html#decipher">Decipher an Image</a> &#8226; <a href="cipher.html#caveats">Encipher and Decipher Caveats</a>]</p>
228
229 <div class="doc-section">
230
231 <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 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>
232
233 <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>
234
235 </div>
236
237 <h2><a id="encipher"></a>Encipher an Image</h2>
238 <div class="doc-section">
239
240 <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>
241
242 <p class='crt'><span class="crtprompt"> $ </span><span class='crtin'>convert rose.jpg -encipher passphrase.txt rose.png</span></p>
243 <p>Here we encipher an image using another image as the passphrase:</p>
244
245 <p class='crt'><span class="crtprompt"> $ </span><span class='crtin'>convert rose.jpg -encipher smiley.gif rose.png</span></p>
246 </div>
247
248 <h2><a id="decipher"></a>Decipher an Image</h2>
249 <div class="doc-section">
250
251 <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>
252
253 <p class='crt'><span class="crtprompt"> $ </span><span class='crtin'>convert rose.png -decipher passphrase.txt rose.jpg</span></p>
254 </div>
255
256 <h2><a id="caveats"></a>Encipher and Decipher Caveats</h2>
257 <div class="doc-section">
258
259 <p>Some formats do not support enciphered pixels-- the JPEG or GIF format, for
260 example.  To ensure your image format is supported, encipher a test image and
261 verify you can restore its original content <em>before</em> you encipher any
262 additional images in that format.</p>
263
264 <p>The image format may only support 8-bit and RGB (TrueColor). As such you may
265 like to include the options "-depth 8 -type TrueColor" before the output
266 filename.</p>
267
268 <p>The passphrase can be any combinations of letters and symbols.  It should
269 be a minimum of 12 character combinations to help ensure your image remains
270 private.  Also make sure your passphrase file permissions prevent others from
271 reading it otherwise unintended users may be able to view the original image
272 content.</p>
273
274 <p>You can only restore the original image content if you know your
275 passphrase.  If you lose or forget it, your original image content is lost
276 forever.</p>
277
278 <p>ImageMagick only scrambles the image pixels.  The image metadata remains
279 untouched and readable by anyone with access to the image file.</p>
280
281 <p>ImageMagick uses the <a
282 href="http://en.wikipedia.org/wiki/Advanced_Encryption_Standard">AES</a>
283 cipher in Counter mode.  We use the the first half of your passphrase to derive the nonce.  The second half is the cipher key. When used correctly, AES-CTR provides a high level of confidentiality. To avoid information leaks, you must use a fresh passphrase for each image your encrypt.</p>
284
285 <p>Currently only ImageMagick can restore your enciphered image content.  We
286 use a standard cipher and mode so other vendors are could support enciphered image content.</p>
287
288 <p>Some small practical examples of image enciphering can be found in IM
289 Examples <a href="http://www.imagemagick.org/Usage/transform/#encipher"
290 >Encrypting Image Data</a>. </p>
291
292 </div>
293
294 </div>
295
296 <div id="linkbar">
297     <span id="linkbar-west"> </span>
298
299     <span id="linkbar-center">
300       <a href="http://www.imagemagick.org/discourse-server/">Discourse Server</a> &#8226;
301       <a href="http://www.imagemagick.org/MagickStudio/scripts/MagickStudio.cgi">Studio</a> &#8226;
302       <a href="http://jqmagick.imagemagick.org/">JqMagick</a>
303     </span>
304     <span id="linkbar-east"> </span>
305   </div>
306   <div class="footer">
307     <span id="footer-west">©  1999-2013 ImageMagick Studio LLC</span>
308     <span id="footer-east"> <a href="contact.html">Contact the Wizards</a></span>
309   </div>
310   <div style="clear: both; margin: 0; width: 100%; "></div>
311 </body>
312 </html>