]> granicus.if.org Git - imagemagick/blob - www/cipher.html
(no commit message)
[imagemagick] / www / cipher.html
1 \r
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" \r
3   "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">\r
4 <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" dir="ltr">\r
5 <head>\r
6   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>\r
7   <meta name="verify-v1" content="g222frIIxcQTrvDR3NBRUSKP3AnMNoqxOkIniCEkV7U="/>\r
8   <title>ImageMagick: Encipher or Decipher an Image</title>
9   <meta http-equiv="Content-Language" content="en-US"/>
10   <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
11   <meta http-equiv="Reply-to" content="magick-users@imagemagick.org"/>
12   <meta name="Application-name" content="ImageMagick"/>
13   <meta name="Description" content="ImageMagick is a software suite to create, edit, compose, or convert bitmap images in a variety of formats. Use ImageMagick to scale, rotate, shear, distort and transform images."/>
14   <meta name="Application-url" content="http://www.imagemagick.org"/>
15   <meta name="Generator" content="PHP"/>
16   <meta name="Keywords" content="encipher, or, decipher, an, image, ImageMagick, ImageMagic, MagickCore, MagickWand, PerlMagick, Magick++, RMagick, PythonMagick, JMagick, TclMagick, Image, Magick, Magic, Wand, ImageMagickObject, Swiss, Army, Knife, Image, Processing"/>
17   <meta name="Rating" content="GENERAL"/>
18   <meta name="Robots" content="INDEX, FOLLOW"/>
19   <meta name="Generator" content="ImageMagick Studio LLC"/>
20   <meta name="Author" content="ImageMagick Studio LLC"/>
21   <meta name="Revisit-after" content="2 DAYS"/>
22   <meta name="Resource-type" content="document"/>
23   <meta name="Copyright" content="Copyright (c) 1999-2011 ImageMagick Studio LLC"/>
24   <meta name="Distribution" content="Global"/>
25   <link rel="icon" href="../images/wand.png"/>
26   <link rel="shortcut icon" href="../images/wand.ico"  type="images/x-icon"/>
27   <link rel="meta" type="application/rdf+xml" title="ICI" href="http://imagemagick.org/ici.rdf"/>\r
28   <style type="text/css" media="all">\r
29     @import url("../www/magick.css");\r
30   </style>\r
31   <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>\r
32    <script type="text/javascript" src="../fancybox/jquery.fancybox-1.3.4.pack.js"></script>\r
33    <link rel="stylesheet" type="text/css" href="../fancybox/jquery.fancybox-1.3.4.css" media="screen" />\r
34    <script type="text/javascript">\r
35      $(document).ready(function() {\r
36        $("a[href$=.jpg],a[href$=.png],a[href$=.gif]").fancybox({\r
37          'transitionIn'  : 'elastic',\r
38          'transitionOut' : 'elastic',\r
39          'overlayShow'   : false,\r
40          'opacity'       : true\r
41        });\r
42      });\r
43    </script>\r
44 </head>\r
45 \r
46 <body id="www-imagemagick-org">\r
47 <div class="titlebar">\r
48 <a href="../index.html">\r
49   <img src="../images/script.png" alt="[ImageMagick]"\r
50   style="width: 350px; height: 60px; margin: 28px auto; float: left;" /></a>\r
51 <a href="http://www.networkredux.com">\r
52   <img src="../images/networkredux.png" alt="[sponsor]"\r
53   style="margin: 45px auto; border: 0px; float: left;" /></a>\r
54 <a href="http://www.imagemagick.org/discourse-server/">\r
55   <img src="../images/logo.jpg" alt=""\r
56   style="width: 114px; height: 118px; border: 0px; float: right;" /></a>\r
57 <a href="../index.html">\r
58   <img src="../images/sprite.jpg" alt=""\r
59   style="width: 114px; height: 118px; border: 0px; float: right;" /></a>\r
60 </div>\r
61 \r
62 <div class="westbar">\r
63 \r
64 <div class="menu">
65   <a title="About ImageMagick" href="../index.html">About ImageMagick</a>
66 </div>
67 <div class="sep"></div>\r
68 <div class="menu">
69   <a title="Binary Releases" href="../www/binary-releases.html">Binary Releases</a>
70 </div>
71 <div class="sub">
72     <a title="Binary Release: Unix" href="../www/binary-releases.html#unix">Unix</a>
73 </div>
74 <div class="sub">
75     <a title="Binary Release: MacOS X" href="../www/binary-releases.html#macosx">Mac OS X</a>
76 </div>
77 <div class="sub">
78     <a title="Binary Release: Windows" href="../www/binary-releases.html#windows">Windows</a>
79 </div>
80 <div class="sep"></div>\r
81 <div class="menu">
82   <a title="Command-line Tools" href="../www/command-line-tools.html">Command-line Tools</a>
83 </div>
84 <div class="sub">
85     <a title="Command-line Tools: Processing" href="../www/command-line-processing.html">Processing</a>
86 </div>
87 <div class="sub">
88     <a title="Command-line Tools: Options" href="../www/command-line-options.html">Options</a>
89 </div>
90 <div class="sub">
91     <a title="Command-line Tools: Usage" href="http://www.imagemagick.org/Usage/">Usage</a>
92 </div>
93 <div class="menu">
94   <a title="Program Interfaces" href="../www/api.html">Program Interfaces</a>
95 </div>
96 <div class="sub">
97     <a title="Program Interface: MagickWand" href="../www/magick-wand.html">MagickWand</a>
98 </div>
99 <div class="sub">
100     <a title="Program Interface: MagickCore" href="../www/magick-core.html">MagickCore</a>
101 </div>
102 <div class="sub">
103     <a title="Program Interface: PerlMagick" href="../www/perl-magick.html">PerlMagick</a>
104 </div>
105 <div class="sub">
106     <a title="Program Interface: Magick++" href="../www/magick++.html">Magick++</a>
107 </div>
108 <div class="sep"></div>\r
109 <div  class="menu">
110    <a title="Install from Source" href="../www/install-source.html">Install from Source</a>
111 </div>
112 <div class="sub">
113     <a title="Install from Source: Unix" href="../www/install-source.html#unix">Unix</a>
114 </div>
115 <div class="sub">
116     <a title="Install from Source: Windows" href="../www/install-source.html#windows">Windows</a>
117  </div>
118 <div class="menu">
119   <a title="Resources" href="../www/resources.html">Resources</a>
120 </div>
121 <div class="menu">
122   <a title="Architecture" href="../www/architecture.html">Architecture</a>
123 </div>
124 <div class="menu">
125   <a title="Download" href="../www/download.html">Download</a>
126 </div>
127 <div class="sep"></div>\r
128 <div class="menu">
129   <a title="Search" href="http://www.imagemagick.org/script/search.php">Search</a>
130 </div>
131 <div class="sep"></div>\r
132 <div class="menu">
133   <a title="Site Map" href="../www/sitemap.html">Site Map</a>
134 </div>
135 <div  class="sub">
136   <a title="Site Map: Links" href="../www/links.html">Links</a>
137 </div>
138 <div class="sep"></div>\r
139 <div  class="menu">
140   <a title="Sponsors" href="../www/sponsors.html">Sponsors:</a>
141
142 <div class="sponsbox">
143 <div  class="sponsor">
144    <a title="Sponsor: Fernsehdienst Berlin" href="http://www.atlas-multimedia.de">Fernsehdienst Berlin</a><!-- 2011040100025 atlas.multimedia-->
145 </div>
146 <div  class="sponsor">
147   <a title="Sponsor: Druckerei" href="http://print24.com/de/">Druckerei</a><!-- 201110010720 -->
148 </div>
149 <div  class="sponsor">
150   <a title="Sponsor: Image Converter" href="http://www.batchphoto.com">Image Converter</a><!-- 201103010900 Bits Coffee-->
151 </div>
152 <div  class="sponsor">
153   <a title="Sponsor: Flyer drucken" href="http://www.online-druck.biz">Flyer drucken</a><!-- 201109010900 Floeter-->
154 </div>
155 </div>
156 </div>
157 </div>\r
158 \r
159 <div class="eastbar">\r
160   <script type="text/javascript">\r
161   <!--\r
162     google_ad_client = "pub-3129977114552745";\r
163     google_ad_slot = "0574824969";\r
164     google_ad_width = 160;\r
165     google_ad_height = 600;\r
166   //-->\r
167   </script>\r
168   <script type="text/javascript"\r
169     src="http://pagead2.googlesyndication.com/pagead/show_ads.js">\r
170   </script>\r
171 </div>\r
172 \r
173 <div class="main">\r
174 \r
175 <h1>Enciphering and Deciphering Images</h2>
176 <p class="navigation-index">[<a href="#encipher">Encipher an Image</a> &bull; <a href="#decipher">Decipher an Image</a> &bull; <a href="#caveats">Encipher and Decipher Caveats</a>]</p>
177
178 <div class="doc-section">
179
180 <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>
181
182 <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>
183
184 </div>
185
186 <h2><a id="encipher"></a>Encipher an Image</h2>
187 <div class="doc-section">
188
189 <p>Use the <a href="../www/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>
190
191 <p class='crt'><span class="crtprompt"> $magick&gt; </span><span class='crtin'>convert rose.jpg -encipher passphrase.txt rose.png</span></p>
192 <p>Here we encipher an image using another image as the passphrase:</p>
193
194 <p class='crt'><span class="crtprompt"> $magick&gt; </span><span class='crtin'>convert rose.jpg -encipher smiley.gif rose.png</span></p>
195 </div>
196
197 <h2><a id="decipher"></a>Decipher an Image</h2>
198 <div class="doc-section">
199
200 <p>Use the <a href="../www/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>
201
202 <p class='crt'><span class="crtprompt"> $magick&gt; </span><span class='crtin'>convert rose.png -decipher passphrase.txt rose.jpg</span></p>
203 </div>
204
205 <h2><a id="caveats"></a>Encipher and Decipher Caveats</h2>
206 <div class="doc-section">
207
208 <p>Some formats do not support enciphered pixels-- the JPEG or GIF format, for
209 example.  To ensure your image format is supported, encipher a test image and
210 verify you can restore its original content <em>before</em> you encipher any
211 additional images in that format.</p>
212
213 <p>The image format also should be 8-bit and RGB (TrueColor). As such you may
214 like to include the options "-depth 8 -type TrueColor" before the output
215 filename. </p>
216
217 <p>The passphrase can be any combinations of letters and symbols.  It should
218 be a minimum of 12 character combinations to help ensure your image remains
219 private.  Also make sure your passphrase file permissions prevent others from
220 reading it otherwise unintended users may be able to view the original image
221 content.</p>
222
223 <p>You can only restore the original image content if you know your
224 passphrase.  If you lose or forget it, your original image content is lost
225 forever.</p>
226
227 <p>ImageMagick only scrambles the image pixels.  The image metadata remains
228 untouched and readable by anyone with access to the image file.</p>
229
230 <p>ImageMagick uses the <a
231 href="http://en.wikipedia.org/wiki/Advanced_Encryption_Standard">AES</a>
232 cipher in cipher feedback mode.  We use the passphrase to derive the cipher
233 key and the required nonce.</p>
234
235 <p>Currently only ImageMagick can restore your enciphered image content.  We
236 use a standard cipher and mode so other vendors are encouraged to support
237 enciphered image content.</p>
238
239 <p>Some small practical examples of image enciphering can be found in IM
240 Examples <A HREF="http://www.imagemagick.org/Usage/transform/#encipher"
241 >Encrypting Image Data</A>. </p>
242
243 </div>
244 \r
245 </div>\r
246 \r
247 <div id="linkbar">\r
248     <span id="linkbar-west">&nbsp;</span>\r
249     <span id="linkbar-center">\r
250       <a href="http://www.imagemagick.org/discourse-server/">Discourse Server</a> &bull;\r
251       <a href="http://www.imagemagick.org/MagickStudio/scripts/MagickStudio.cgi">Studio</a>\r
252     </span>\r
253     <span id="linkbar-east">&nbsp;</span>\r
254   </div>\r
255   <div class="footer">\r
256     <span id="footer-west">&copy; 1999-2011 ImageMagick Studio LLC</span>\r
257     <span id="footer-east"> <a href="http://www.imagemagick.org/script/contact.php">Contact the Wizards</a></span>\r
258   </div>\r
259   <div style="clear: both; margin: 0; width: 100%; "></div>\r
260   <script type="text/javascript">\r
261     var _gaq = _gaq || [];\r
262     _gaq.push(['_setAccount', 'UA-17690367-1']);\r
263     _gaq.push(['_trackPageview']);\r
264 \r
265     (function() {\r
266       var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;\r
267       ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';\r
268       var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);\r
269     })();\r
270   </script>\r
271 </body>\r
272 </html>\r