亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? idea.java

?? jpeg2000編解碼
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
// $Id: IDEA.java,v 1.1.1.1 2002/08/27 12:32:09 grosbois Exp $//// $Log: IDEA.java,v $// Revision 1.1.1.1  2002/08/27 12:32:09  grosbois// Add cryptix 3.2//// Revision 1.4  2000/08/17 11:40:51  edwin// java.* -> xjava.*//// Revision 1.3  1997/11/29 04:42:55  hopwood// + Changes to engineUpdate method.//// + Fixed invertKey to do the right thing (i.e. nothing) when the native//   library is being used.// + Formatting changes.//// Revision 1.2  1997/11/20 19:31:39  hopwood// + cryptix.util.* name changes.//// Revision 1.1.1.1  1997/11/03 22:36:56  hopwood// + Imported to CVS (tagged as 'start').//// Revision 0.3.2.0  1997/08/21  David Hopwood// + Removed all deprecated methods and fields. Cryptix 2.2 compatibility//   is now handled by the separate cryptix.security.IDEA class.// + Tightened some of the access specifiers (e.g. SPI methods were public,//   and are now protected).// + Ensured that this class is final, and added a comment that this is for//   security reasons.//   If it were not final, some VMs have a bug that would allow a subclass//   that implements Cloneable to call Object's or Cipher's clone() method//   using invokenonvirtual, which would duplicate the pointer to the native//   state. Then calling finalize() on the original and using the clone (for//   example) would result in freed memory being written to :-(.// + Required native code version is 2.3.//// Revision 0.3.1.0  1997/07/14  David Hopwood// + Blowfish, DES, IDEA, and Square 3.1.0 are now at the same API//   level and in the same style.// + Fixed security bug (out-of-bounds read) introduced in 3.0.1 -//   same bug as for Blowfish 3.0.5.// + Renamed outs variable in engineUpdate to temp, to avoid similarity//   with out.//// Revision 0.3.0.1  1997/07/09  R. Naffah// + Fully IJCE-compliant!// + Tested OK with and without IDEA.DLL.// + Re-wrote the JNI code to conform with modifs;// + Changed method signatures to follow same style/params as the other//   ciphers in the library;// + Changed methods mul and inv to return shorts;// + Now use one short[] as the session key;// + Brought it to the same API level as Blowfish 3.0.5 and DES 3.0.2;//// Revision 0.3.0.0  1997/07/0?  David Hopwood// + JCE, native linking, debugging, etc...//// Revision 0.2.5.2  1997/04/03  Systemics// + Documentation.  Deprecated public variables and made methods private.//// Revision 0.2.5.1  1997/03/15  Jill Baker// + Moved this file here from old namespace.//// Revision 0.2.5.0  1997/02/24  Systemics// + Original version.//// $Endlog$/* * Copyright (c) 1995-97 Systemics Ltd * on behalf of the Cryptix Development Team.  All rights reserved. */ package cryptix.provider.cipher;import cryptix.util.core.Debug;import cryptix.CryptixException;import cryptix.util.core.ArrayUtil;import cryptix.util.core.Hex;import cryptix.provider.key.RawSecretKey;import java.io.PrintWriter;import xjava.security.Cipher;import java.security.Key;import java.security.InvalidKeyException;import xjava.security.SymmetricCipher;/** * IDEA is a block cipher with a key length of 16 bytes and a block length of * 8 bytes. It is highly popular, being the original cipher in PGP, and has * received a lot of cryptanalytic attention. * <p> * IDEA was written by Dr. X. Lai and Prof. J. Massey. * <p> * <b>References:</b> * <ol> *   <li> See the <a href="http://www.ascom.ch/Web/systec/security/idea.htm">IDEA page</a> *        for more details. *        <p> *   <li> The algorithm is subject to patent claims by *        <a href="http://www.ascom.ch/systec/">Ascom Systec Ltd</a> *        (applied for May 1991), and is *        <a href="http://www.ascom.ch/Web/systec/policy/normal/policy.html">licensable</a>. * </ol> * <p> * * <b>Copyright</b> &copy; 1995-1997 * <a href="http://www.systemics.com/">Systemics Ltd</a> on behalf of the * <a href="http://www.systemics.com/docs/cryptix/">Cryptix Development Team</a>. * <br>All rights reserved. * * <p><b>$Revision: 1.1.1.1 $</b> * @author  Systemics Ltd * @author  David Hopwood * @author  Raif S. Naffah * @since   Cryptix 2.2.2 */public final class IDEA // must be final for security reasonsextends Cipherimplements SymmetricCipher{// Debugging methods and vars.//...........................................................................    private static final boolean DEBUG = Debug.GLOBAL_DEBUG;    private static final boolean DEBUG_SLOW = Debug.GLOBAL_DEBUG_SLOW;    private static final int debuglevel = DEBUG ? Debug.getLevel("IDEA") : 0;    private static final PrintWriter err = DEBUG ? Debug.getOutput() : null;    private static void debug(String s) { err.println("IDEA: " + s); }// Native library linking methods and vars.//...........................................................................    private static NativeLink linkStatus = new NativeLink("IDEA", 2, 3);    /**     * Gets an object representing the native linking status of this class.     */    public static cryptix.util.core.LinkStatus getLinkStatus() { return linkStatus; }    /**     * The native reference to the current native key schedule     * structure. Defaults to 0 but is set by native code after a     * successful call to native_init().     * <p>     * IMPORTANT: Do not change the name of this variable without     * duplicating the same in the native code.     */    private long native_cookie;    /**     * This object must be synchronized on while calling any native instance     * method. It is null if the native code is not being used (e.g. the     * library did not load successfully, or the user disabled its use in     * the properties file).     */    private Object native_lock; // defaults to null    private void link() {        synchronized(linkStatus) {            try {                if (linkStatus.attemptLoad()) {                    linkStatus.checkVersion(getLibMajorVersion(), getLibMinorVersion());                    linkStatus.check(native_clinit());                }                if (linkStatus.useNative()) {                    linkStatus.check(native_init());                    native_lock = new Object();                }            } catch (UnsatisfiedLinkError e) {                linkStatus.fail(e);if (DEBUG && debuglevel > 2) debug(e.getMessage());            }if (DEBUG && debuglevel > 2) debug("Using native library? " + (native_lock != null));        }    }// Native support API//...........................................................................    // The methods that get the library version.    private native static int getLibMajorVersion();    private native static int getLibMinorVersion();    /**     * Static initialization and self-test method for the native code.     *     * @return a string if an error occurred or null otherwise.     */    private native String native_clinit();    /**     * Initializes the native state for this cipher object and allocates     * needed native storage for the internal key schedule. A reference     * to the newly allocated space, if successful, is stored in the     * instance variable <code>native_cookie</code>.     *     * @return a string if an error occurred or null otherwise.     */    private native String native_init();    /**     * This function expands the user key to an internal form.     *     * @param  cookie   a valid reference to the native key structure. This     *                  value is set by the native library upon return from     *                  native_init() (see link() method at the top).     * @param  userKey  a byte array representing the user key     * @return an error String, or null if there was no error     */    private native String native_ks(long cookie, byte[] userKey);    /**     * Encrypts/decrypts a data block.     * <p>     * FUTURE: possibly change this to be able to process more than one block,     * to reduce native method call overhead.     * <p>     * SECURITY: the caller <strong>must</strong> ensure that:     * <ul>     *   <li> <code>in != null</code>     *   <li> <code>out != null</code>     *   <li> <code>inOffset >= 0</code>     *   <li> <code>(long)inOffset + BLOCK_SIZE <= in.length</code>     *   <li> <code>outOffset >= 0</code>     *   <li> <code>(long)outOffset + BLOCK_SIZE <= out.length</code>     * </ul>     *     * @param  cookie       a valid reference to the native key structure. This     *                      value is set by the native library upon return from     *                      native_init() (see link() method at the top).     * @param  in           input array containing data to encrypt or decrypt     *                      depending on the value of the encrypt boolean parameter.     * @param  inOffset     index of where we should start reading from input.     * @param  out          output array containing data decrypted or encrypted     *                      depending on the value of the encrypt boolean parameter.     * @param  outOffset    index of where we should start writing to output.     * @param  encrypt      if true then encrypt, otherwise decrypt.     * @return the number of bytes crypted (always BLOCK_SIZE) or 0 if an error     *                      occurred.     */    private native int native_crypt(long cookie, byte[] in, int inOffset,                                    byte[] out, int outOffset, boolean encrypt);    /**     * Finalizes the native state for this object.     *     * @return a string if an error occurred or null otherwise.     */    private native String native_finalize();// IDEA constants and variables//............................................................................    private static final int        ROUNDS = 8,        BLOCK_SIZE = 8,        KEY_LENGTH = 16;    /**     * The number of array elements in the expanded key schedule, i.e. both     * encryption and decryption keys.     * <p>     * For IDEA this is <code>6 * ROUNDS + 4 = 52</code>.     */    private static final int INTERNAL_KEY_LENGTH = 52;    /**     * The key schedule.     */    private short[] ks = new short[INTERNAL_KEY_LENGTH];// Constructor, finalizer, and clone()//............................................................................    /**     * Constructs an IDEA cipher object, in the UNINITIALIZED state.     * This calls the Cipher constructor with <i>implBuffering</i> false,     * <i>implPadding</i> false and the provider set to "Cryptix".     */    public IDEA() {        super(false, false, "Cryptix");        link();    }    /**     * Cleans up resources used by this instance, if necessary.     */    protected final void finalize() {        if (native_lock != null) {            synchronized(native_lock) {                String error = native_finalize(); // may be called more than once                if (error != null)                    debug(error + " in native_finalize");            }        }    }    /**     * Always throws a CloneNotSupportedException (cloning of ciphers is not     * supported for security reasons).     */    public final Object clone() throws CloneNotSupportedException {        throw new CloneNotSupportedException();    }// Implementation of JCE methods//............................................................................        /**     * <b>SPI</b>: Returns the length of an input block, in bytes.     *     * @return the length in bytes of an input block for this cipher.     */    protected int engineBlockSize () { return BLOCK_SIZE; }    /**     * <b>SPI</b>: Initializes this cipher for encryption, using the     * specified key.     *     * @param  key  the key to use for encryption.     * @exception InvalidKeyException if one of the following occurs: <ul>     *                <li> key.getEncoded() == null;     *                <li> The length of the user key array is not KEY_LENGTH.     *              </ul>     */    protected void engineInitEncrypt (Key key)    throws InvalidKeyException, CryptixException {        makeKey(key);    }    /**     * <b>SPI</b>: Initializes this cipher for decryption, using the     * specified key.     *     * @param  key  the key to use for encryption.     * @exception InvalidKeyException if one of the following occurs: <ul>     *                <li> key.getEncoded() == null;     *                <li> The length of the user key array is not KEY_LENGTH.     *              </ul>     */    protected void engineInitDecrypt (Key key)    throws InvalidKeyException, CryptixException {        makeKey(key);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美国产一区二区在线观看| 婷婷六月综合网| 一区二区三区四区不卡视频| 美腿丝袜在线亚洲一区| 色视频一区二区| 国产亚洲精品资源在线26u| 天堂va蜜桃一区二区三区漫画版| 成人国产一区二区三区精品| 精品少妇一区二区三区免费观看 | 日韩美女视频一区二区| 毛片av一区二区| 欧美最猛性xxxxx直播| 亚洲国产精品二十页| 国产美女精品人人做人人爽| 欧美一区国产二区| 视频一区二区不卡| 欧美午夜电影网| 17c精品麻豆一区二区免费| 国产精品影视在线| 中文字幕在线播放不卡一区| 国模无码大尺度一区二区三区| 欧美人成免费网站| 亚洲一级电影视频| 97久久人人超碰| 自拍偷拍亚洲欧美日韩| 97超碰欧美中文字幕| 欧美高清在线一区二区| 国产精品白丝av| 国产蜜臀97一区二区三区| 国产乱子伦视频一区二区三区 | 精品一区二区三区av| 欧美一区二区在线播放| 日韩激情一区二区| 日韩欧美三级在线| 狠狠色狠狠色综合系列| 久久午夜国产精品| 国产精品99久久久久久久vr| 国产精品视频一区二区三区不卡| 国产69精品久久久久毛片| 国产精品素人一区二区| 91在线观看地址| 亚洲国产成人porn| 日韩三级视频在线看| 精品一区二区在线免费观看| 国产日产欧美一区二区三区 | 自拍偷自拍亚洲精品播放| 波多野结衣欧美| 亚洲精品亚洲人成人网 | 久久久久久电影| av不卡免费在线观看| 亚洲精品乱码久久久久| 欧美日韩aaa| 狠狠色2019综合网| 自拍偷自拍亚洲精品播放| 日本高清不卡一区| 麻豆成人免费电影| 久久精品欧美日韩| 欧美综合欧美视频| 韩国三级电影一区二区| 国产精品的网站| 欧美狂野另类xxxxoooo| 国产美女av一区二区三区| 亚洲人成伊人成综合网小说| 91精品国产欧美一区二区18| 国产很黄免费观看久久| 亚洲免费资源在线播放| 精品少妇一区二区三区在线播放 | 精品一区二区综合| 青青草原综合久久大伊人精品优势| 日韩欧美一区二区视频| kk眼镜猥琐国模调教系列一区二区 | 这里只有精品99re| 国产激情视频一区二区三区欧美 | 91精品国产乱码久久蜜臀| 国产在线精品一区二区夜色 | 午夜精品一区二区三区免费视频 | 欧美精品三级日韩久久| 成人性生交大片免费看在线播放| 亚洲成人tv网| 亚洲国产精品传媒在线观看| 欧美一区二区女人| 欧美吞精做爰啪啪高潮| 国产在线视频一区二区| 婷婷开心久久网| 亚洲欧美韩国综合色| 久久久久久久久久美女| 欧美一区二区在线观看| 欧美这里有精品| 不卡一二三区首页| 精品一区二区三区久久| 亚洲123区在线观看| 亚洲欧美色图小说| 国产日韩精品一区| 日韩美女在线视频| 欧美美女网站色| 色妞www精品视频| 成人美女视频在线看| 精品一区二区三区在线观看| 日韩影院免费视频| 亚洲一区二区综合| 亚洲精品伦理在线| 亚洲精品免费看| 亚洲美女视频在线| 亚洲日本va午夜在线影院| 中文字幕不卡的av| 国产精品卡一卡二卡三| 中文一区在线播放| 国产精品拍天天在线| 日本一区二区动态图| 国产亚洲美州欧州综合国| 337p日本欧洲亚洲大胆色噜噜| 91精品国产乱码| 日韩欧美久久一区| 精品国精品自拍自在线| 精品成人私密视频| 26uuu成人网一区二区三区| 日韩欧美国产精品一区| 日韩美女天天操| 久久这里只有精品视频网| 国产亚洲污的网站| 国产日韩av一区二区| 视频一区二区中文字幕| 亚洲成人第一页| 久久精工是国产品牌吗| 黑人精品欧美一区二区蜜桃| 国产a级毛片一区| 95精品视频在线| 欧美精品成人一区二区三区四区| 欧美一区二区三区婷婷月色| 欧美精品一区二| 国产精品沙发午睡系列990531| 亚洲精品视频一区| 午夜久久久久久久久久一区二区| 日韩在线一区二区三区| 国产一区二区三区高清播放| 成人午夜视频网站| 欧美色图天堂网| 日韩免费一区二区| 国产欧美日韩另类视频免费观看| 18欧美乱大交hd1984| 日韩国产在线观看一区| 国产在线精品免费av| 色网站国产精品| 日韩精品中文字幕在线不卡尤物| 中文字幕欧美区| 香蕉久久夜色精品国产使用方法| 久久精品国产精品亚洲红杏| 99久久99久久久精品齐齐| 欧美色中文字幕| 国产欧美日韩视频在线观看| 亚洲午夜羞羞片| 国产一区二区在线电影| 91黄视频在线观看| 欧美videofree性高清杂交| 亚洲视频一区二区在线| 石原莉奈在线亚洲二区| 国产精品自在欧美一区| 欧美猛男男办公室激情| 国产精品电影一区二区| 麻豆精品国产传媒mv男同 | 亚洲综合男人的天堂| 国产一区二区在线免费观看| 在线观看日产精品| 欧美经典一区二区| 人人精品人人爱| 色视频成人在线观看免| 欧美极品另类videosde| 亚洲成人一区二区在线观看| 成a人片亚洲日本久久| 日韩一区和二区| 亚洲小说欧美激情另类| 成人开心网精品视频| 精品国产sm最大网站| 婷婷夜色潮精品综合在线| 色综合激情五月| 国产精品午夜久久| 国模少妇一区二区三区| 欧美午夜精品久久久久久孕妇 | 国产精品嫩草影院com| 日韩电影在线看| 欧美日韩一区二区三区视频| 国产精品丝袜一区| 国产精品一区二区你懂的| 在线成人av影院| 天堂蜜桃91精品| 欧美日韩国产电影| 亚洲夂夂婷婷色拍ww47| 99久久综合99久久综合网站| 国产欧美一区二区三区鸳鸯浴| 日本精品一级二级| 中文字幕一区免费在线观看| 国产91富婆露脸刺激对白| 国产清纯美女被跳蛋高潮一区二区久久w| 日本在线不卡视频| 91精品黄色片免费大全| 午夜精品久久久久久久久久| 欧美色男人天堂| 香港成人在线视频| 91精品国产综合久久久久久漫画 | 亚洲一区在线观看视频|