encryption.html 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="utf-8" lang="utf-8">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
  5. <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=0" />
  6. <title>加密类 - CodeIgniter 中文手册|用户手册|用户指南|Wiki文档</title>
  7. <link rel="shortcut icon" href="http://codeigniter.org.cn/user_guide/../images/design/favicon.ico" type="image/x-icon" />
  8. <link rel="stylesheet" type="text/css" media="all" href="../userguide.css" />
  9. <link rel="search" href="http://codeigniter.org.cn/user_guide/../CodeIgniterSearch.xml" type="application/opensearchdescription+xml" title="CodeIgniter 搜索"/>
  10. <link rel="canonical" href="http://codeigniter.org.cn/user_guide/libraries/encryption.html" />
  11. <script type="text/javascript" src="../nav/mootools.js-ver=20130324.js"></script>
  12. <script type="text/javascript" src="../nav/mootools-more.js-ver=20130324.js"></script>
  13. <script type="text/javascript" src="../nav/nav.js-ver=20130324.js"></script>
  14. <script type="text/javascript" src="../nav/user_guide_menu.js-ver=20130324.js"></script>
  15. <meta name="robots" content="all" />
  16. <meta name="author" content="ExpressionEngine Dev Team" />
  17. <meta name="description" content="CodeIgniter 中文手册, CodeIgniter 用户指南, CodeIgniter User Guide, Wiki 文档" />
  18. </head>
  19. <body>
  20. <!-- START NAVIGATION -->
  21. <div id="nav">
  22. <div id="nav_inner">
  23. <script type="text/javascript">create_menu('../');</script>
  24. </div>
  25. </div>
  26. <script type="text/javascript">_setNavigation();</script>
  27. <div id="nav2"><a name="top"></a><a href="javascript:void(0);" onclick="myHeight.toggle();"><img src="../images/nav_toggle_darker.jpg" width="154" height="43" border="0" title="切换目录" alt="切换目录" /></a></div>
  28. <div id="masthead" class="clearfix">
  29. <div class="topbar-hd"><h1>CodeIgniter 用户指南 版本 2.2.0</h1></div>
  30. <div class="topbar-tip">编辑文档、查看近期更改请 <a href="#">登录</a> 或 <a href="#">注册</a>  <a href="#">找回密码</a></div> <div id="breadcrumb_right"><a href="../toc.html">目录页</a></div>
  31. </div>
  32. <!-- END NAVIGATION -->
  33. <!-- START BREADCRUMB -->
  34. <table cellpadding="0" cellspacing="0" border="0" style="width:100%">
  35. <tr>
  36. <td id="breadcrumb">
  37. <a href="#" target="_blank">CodeIgniter 中国首页</a>&nbsp;&#8250;&nbsp;
  38. <a href="../index.html">用户指南首页</a>&nbsp;&#8250;&nbsp;加密类 </td>
  39. <td id="searchbox">
  40. <form method="get" action="http://www.google.com.hk/search" target="google_window">
  41. <input type="hidden" name="client" value="pub-0176846097796333"></input>
  42. <input type="hidden" name="forid" value="1"></input>
  43. <input type="hidden" name="ie" value="UTF-8"></input>
  44. <input type="hidden" name="oe" value="UTF-8"></input>
  45. <input type="hidden" name="as_sitesearch" id="as_sitesearch" value="codeigniter.org.cn/user_guide/" />
  46. 搜索用户指南&nbsp;
  47. <input type="text" class="input" style="width:200px;" name="q" id="q" size="31" maxlength="255" value="" />
  48. &nbsp;
  49. <input type="submit" class="submit" name="sa" value="Go" />
  50. </form>
  51. </td>
  52. </tr>
  53. </table>
  54. <!-- END BREADCRUMB -->
  55. <div style="clear:both;text-align:right;padding: 6px 40px 0 0;">
  56. <a href="#" target="_blank">查看原文</a>
  57. </div>
  58. <!--<br clear="all" />--><!-- START CONTENT -->
  59. <div id="content">
  60. <h1>加密类</h1>
  61. <p>数据加密类提供了双向数据加密方式。加密类使用 Mcrypt 库加密数据,所以需要 Mcrypt 扩展才能运行。</p>
  62. <h2>设置你的密钥</h2>
  63. <p><em>密钥</em>实际上是一些会控制密码加密过程并且允许被加密的字串被解码的信息片段。实际上,你选择的密钥会提供一个<strong>唯一</strong>的方法来解密一些被加密的数据,所以你需要非常谨慎的设置你的密钥,如果你想给一些固定的数据加密的话,你最好不要更改这个密钥。</p>
  64. <p>很自然,你需要非常小心的保守你的密钥。如果某人对您的密钥能够存取,那么数据将会很容易地被解码。如果您的服务器不完全在您的控制之下而想保证数据安全是不可能的,因此您可以在使用它之前仔细地想一下要求高安全存放信用卡数字对象的方法。</p>
  65. <p>为了发挥加密算法的最大优势,你的解密密钥需要被设置为 32 个字符长度(128 位)。你可以设置一个编造的随机字符串作为你的密钥,最好包括数字、大写字母、小写字母。你的密钥<strong>不能</strong>设置为一个简单的文本字符串。为了被安全可靠的加密,它也有一个随机的可能性。</p>
  66. <p>你的密钥可以放在 <dfn>application/config/config.php</dfn> 文件中,你也可以自己设置一个存储机制用于数据的加密和解密。</p>
  67. <p>为了在 <dfn>application/config/config.php</dfn> 文件中保存你的密钥,打开文件设置一下:</p>
  68. <code>$config['encryption_key'] = &quot;YOUR KEY&quot;;</code>
  69. <h2>消息长度</h2>
  70. <p>知道加密信息的长度会是原来函数长度的 2.6 倍是很重要的。如果你加密这个字符串&ldquo;my super secret data&rdquo;,它的长度是 21 个字符,所以你加密后的字符串的长度大概是 55 个字符(我们说它大概是,因为编码的字符串长度增量 64 位并非是线性增长的),当你选择你的数据存储机制的时候一定要记住这一点。例如,Cookie 可以占用 4k 的数据空间。</p>
  71. <h2>初始化类</h2>
  72. <p>在 Codeigniter 中,像大多数其他的类一样,加密类也需要在你的控制器函数中用 <dfn>$this-&gt;load-&gt;library</dfn> 函数加载:</p>
  73. <code>$this-&gt;load-&gt;library('encrypt');</code>
  74. <p>一旦被加载,加密类库就可以这样使用:<dfn>$this-&gt;encrypt</dfn></p>
  75. <h2>$this-&gt;encrypt-&gt;encode()</h2>
  76. <p>执行数据加密并返回一个字符串。例如:</p>
  77. <code>$msg = 'My secret message';<br />
  78. <br />
  79. $encrypted_string = $this-&gt;encrypt-&gt;encode($msg);</code>
  80. <p>如果你不想使用配置文件中的密钥,你可以通过可选的第二个参数随意设置你的密钥。</p>
  81. <code>$msg = 'My secret message';<br />
  82. $key = 'super-secret-key';<br />
  83. <br />
  84. $encrypted_string = $this-&gt;encrypt-&gt;encode($msg, $key);</code>
  85. <h2>$this-&gt;encrypt-&gt;decode()</h2>
  86. <p>解密一个已加密的字符串。例如:</p>
  87. <code>$encrypted_string = 'APANtByIGI1BpVXZTJgcsAG8GZl8pdwwa84';<br />
  88. <br />
  89. $plaintext_string = $this-&gt;encrypt-&gt;decode($encrypted_string);</code>
  90. <p>如果你不想使用配置文件中的密钥,你可以通过可选的第二个参数随意设置你的密钥。</p>
  91. <code>
  92. $msg = 'My secret message';<br />
  93. $key = 'super-secret-key';<br />
  94. <br />
  95. $encrypted_string = $this-&gt;encrypt-&gt;decode($msg, $key);</code>
  96. <h2>$this-&gt;encrypt-&gt;set_cipher();</h2>
  97. <p>允许你设置一个 Mcrypt 算法。默认使用 <samp>MCRYPT_RIJNDAEL_256</samp>。例如:</p>
  98. <code>$this-&gt;encrypt-&gt;set_cipher(MCRYPT_BLOWFISH);</code>
  99. <p>请访问 php.net 看一下<a href="#">可用的算法</a>。</p>
  100. <p>如果你想手动测试一下你的服务器是否支持 Mcrypt,你可以使用:</p>
  101. <code>echo ( ! function_exists('mcrypt_encrypt')) ? 'Nope' : 'Yup';</code>
  102. <h2>$this-&gt;encrypt-&gt;set_mode();</h2>
  103. <p>允许你设置一个 Mcrypt 模式。默认使用 <samp>MCRYPT_MODE_CBC</samp>。例如:</p>
  104. <code>$this-&gt;encrypt-&gt;set_mode(MCRYPT_MODE_CFB);</code>
  105. <p>请访问 php.net 看一下<a href="#">可用的模式</a>。</p>
  106. <h2>$this-&gt;encrypt-&gt;sha1();</h2>
  107. <p>SHA1 编码函数。提供一个字符串,然后它返回一个 160 位的 Hash 信息。说明:SHA1,就像 MD5 一样不可解密。例如:</p>
  108. <code>$hash = $this-&gt;encrypt-&gt;sha1('Some string');</code>
  109. <p>许多 PHP 安装程序默认都支持 SHA1,所以你可以很简单的使用它的原始函数进行加密:</p>
  110. <code>$hash = sha1('Some string');</code>
  111. <p>如果你的服务器不支持 SHA1,你可以使用别人提供的函数。</p>
  112. <h2 id="legacy">$this-&gt;encrypt-&gt;encode_from_legacy(<kbd>$orig_data</kbd>, <kbd>$legacy_mode</kbd> = MCRYPT_MODE_ECB, <kbd>$key</kbd> = '');</h2>
  113. <p>允许你重新加密由Codeigniter 1.x版本加密过的数据,以便与CodeIgniter 2.x中的加密类匹配。只有当加密过的数据已经在数据库或者文件当中存储,同时所在服务器支持Mcrypt的时候才会用到这个函数。"Light" use encryption
  114. such as encrypted session data or transitory encrypted flashdata require no intervention on your part. However, 已经存在的加密session会被销毁 since data encrypted prior to 2.x will not be decoded.</p>
  115. <p class="important"><strong>为什么只有重新加密的方式而不是继续支持原有的加密和解密方式呢?</strong>CodeIgniter 2.x中的加密库算法无论是性能还是安全性都有了很大的进步,因此我们不希望继续支持大家使用原有的加密方法。当然,如果你有需求,可以自行扩展加密库并添加原来的加密方式以便无缝兼容CodeIgniter 1.x,但作为一个开发者,这样的决定还是谨慎点,多想想好啊。</p>
  116. <code>$new_data = $this-&gt;encrypt-&gt;encode_from_legacy(<kbd>$old_encrypted_string</kbd>);</code>
  117. <table cellpadding="0" cellspacing="1" border="0" style="width:100%" class="tableborder">
  118. <tr>
  119. <th>参数</th>
  120. <th>默认值</th>
  121. <th>介绍</th>
  122. </tr>
  123. <tr>
  124. <td class="td"><strong>$orig_data</strong></td>
  125. <td class="td">n/a</td>
  126. <td class="td">原始数据,用CodeIgniter 1.x加密过的</td>
  127. </tr>
  128. <tr>
  129. <td class="td"><strong>$legacy_mode</strong></td>
  130. <td class="td">MCRYPT_MODE_ECB</td>
  131. <td class="td">生成原始数据的Mcrypt加密模式。CodeIgniter 1.x的默认加密方式是MCRYPT_MODE_ECB, 在没有通过参数设定方式的时候就会默认采用这个方式。</td>
  132. </tr>
  133. <tr>
  134. <td class="td"><strong>$key</strong></td>
  135. <td class="td">n/a</td>
  136. <td class="td">加密密钥. 这个值通常在配置文件里面。</td>
  137. </tr>
  138. </table><p>&nbsp;</p>
  139. <div id="Contributors">
  140. 翻译贡献者:
  141. baiyuxiong, binota, csfhc, Hex, popcorner, qixingyue, zhupeng, 志明</div>
  142. <div id="DocDate">
  143. 最后修改: 2014-06-10 14:01:25</div>
  144. </div>
  145. <!-- END CONTENT -->
  146. <div id="footer">
  147. <p>
  148. 上一个主题:&nbsp;&nbsp;<a href="email.html">Email 类</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;<a href="#top">页首</a>
  149. &nbsp;&middot;&nbsp;&nbsp;<a href="../index.html">用户指南首页</a>&nbsp;&nbsp;&middot;&nbsp;&nbsp;下一个主题:&nbsp;&nbsp;<a href="file_uploading.html">文件上传类</a> </p>
  150. <p><a href="#">CodeIgniter</a> &nbsp;&middot;&nbsp; 版权所有 &#169; 2006-2013 &nbsp;&middot;&nbsp; <a href="#">Ellislab, Inc.</a></p>
  151. <p>中文化: <a href="#">CodeIgniter 中国</a> &nbsp;&middot;&nbsp; 制作: Hex &nbsp;&middot;&nbsp; 版本: 1.30 &nbsp;&middot;&nbsp; 鸣谢: 子非鱼</p>
  152. </div>
  153. </body>
  154. </html>