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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? security.java

?? jsp數(shù)據(jù)庫系統(tǒng)
?? JAVA
字號(hào):
/*
   Copyright (C) 2002 MySQL AB

      This program is free software; you can redistribute it and/or modify
      it under the terms of the GNU General Public License as published by
      the Free Software Foundation; either version 2 of the License, or
      (at your option) any later version.

      This program is distributed in the hope that it will be useful,
      but WITHOUT ANY WARRANTY; without even the implied warranty of
      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      GNU General Public License for more details.

      You should have received a copy of the GNU General Public License
      along with this program; if not, write to the Free Software
      Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA

 */
package com.mysql.jdbc;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;


/**
 * Methods for doing secure authentication with MySQL-4.1
 * and newer.
 *
 * @author Mark Matthews
 *
 * @version $Id: Security.java,v 1.1.4.4 2003/09/11 19:34:01 mmatthew Exp $
 */
class Security {
    private static final int SHA1_HASH_SIZE = 20;
    private static final char PVERSION41_CHAR = '*';

    /**
     * Prevent construction.
     */
    private Security() {
        super();
    }

    /*
      Convert password in salted form to binary string password and hash-salt
      For old password this involes one more hashing

      SYNOPSIS
            get_hash_and_password()
            salt         IN  Salt to convert from
            pversion     IN  Password version to use
            hash         OUT Store zero ended hash here
            bin_password OUT Store binary password here (no zero at the end)

      RETURN
            0 for pre 4.1 passwords
       !0 password version char for newer passwords
    */

    /**
     * DOCUMENT ME!
     *
     * @param salt DOCUMENT ME!
     * @param usingNewPasswords DOCUMENT ME!
     *
     * @return DOCUMENT ME!
     *
     * @throws NoSuchAlgorithmException if the message digest 'SHA-1' is not
     * available.
     */
    static byte[] getBinaryPassword(int[] salt, boolean usingNewPasswords)
        throws NoSuchAlgorithmException {
        int val = 0;

        byte[] binaryPassword = new byte[SHA1_HASH_SIZE]; /* Binary password loop pointer */

        if (usingNewPasswords) /* New password version assumed */ {
            int pos = 0;

            for (int i = 0; i < 4; i++) /* Iterate over these elements*/ {
                val = salt[i];

                for (int t = 3; t >= 0; t--) {
                    binaryPassword[pos++] = (byte) (val & 255);
                    val >>= 8; /* Scroll 8 bits to get next part*/
                }
            }

            return binaryPassword;
        } else {
            int offset = 0;

            for (int i = 0; i < 2; i++) /* Iterate over these elements*/ {
                val = salt[i];

                for (int t = 3; t >= 0; t--) {
                    binaryPassword[t + offset] = (byte) (val % 256);
                    val >>= 8; /* Scroll 8 bits to get next part*/
                }

                offset += 4;
            }

            MessageDigest md = MessageDigest.getInstance("SHA-1");

            md.update(binaryPassword, 0, 8);

            return md.digest();
        }
    }

    /**
     * Creates key from old password to decode scramble
     * Used in 4.1 authentication with passwords stored
     * pre-4.1 hashing.
     *
     * @param passwd the password to create the key from
     *
     * @return 20 byte generated key
     *
     * @throws NoSuchAlgorithmException if the message digest 'SHA-1'
     *          is not available.
     */
    static byte[] createKeyFromOldPassword(String passwd)
        throws NoSuchAlgorithmException {
        /* At first hash password to the string stored in password */
        passwd = makeScrambledPassword(passwd);

        /* Now convert it to the salt form */
        int[] salt = getSaltFromPassword(passwd);

        /* Finally get hash and bin password from salt */
        return getBinaryPassword(salt, false);
    }

    /**
     * Creates password to be stored in user database
     * from raw string.
     *
     * Handles Pre-MySQL 4.1 passwords.
     *
     * @param password plaintext password
     *
     * @return scrambled password
     *
     * @throws NoSuchAlgorithmException if the message digest 'SHA-1' is not
     *          available.
     */
    static String makeScrambledPassword(String password)
        throws NoSuchAlgorithmException {
        long[] passwordHash = Util.newHash(password);
        StringBuffer scramble = new StringBuffer();

        scramble.append(longToHex(passwordHash[0]));
        scramble.append(longToHex(passwordHash[1]));

        return scramble.toString();
    }

    /**
     * Encrypt/Decrypt function used for password encryption in authentication
     *
     * Simple XOR is used here but it is OK as we crypt random strings
     *
     * @param from     IN     Data for encryption
     * @param to       OUT    Encrypt data to the buffer (may be the same)
     * @param password IN     Password used for encryption (same length)
     * @param length   IN     Length of data to encrypt
     */
    static void passwordCrypt(byte[] from, byte[] to, byte[] password,
        int length) {
        int pos = 0;

        while ((pos < from.length) && (pos < length)) {
            to[pos] = (byte) (from[pos] ^ password[pos]);
            pos++;
        }
    }

    /**
     * Stage one password hashing, used in MySQL 4.1 password handling
     *
     * @param password plaintext password
     *
     * @return stage one hash of password
     *
     * @throws NoSuchAlgorithmException if the message digest 'SHA-1' is not
     *          available.
     */
    static byte[] passwordHashStage1(String password)
        throws NoSuchAlgorithmException {
        MessageDigest md = MessageDigest.getInstance("SHA-1");
        StringBuffer cleansedPassword = new StringBuffer();

        int passwordLength = password.length();

        for (int i = 0; i < passwordLength; i++) {
            char c = password.charAt(i);

            if ((c == ' ') || (c == '\t')) {
                continue; /* skip space in password */
            }

            cleansedPassword.append(c);
        }

        return md.digest(cleansedPassword.toString().getBytes());
    }

    /**
     * Stage two password hashing used in MySQL 4.1
     * password handling
     *
     * @param hash from passwordHashStage1
     * @param salt salt used for stage two hashing
     *
     * @return result of stage two password hash
     *
     * @throws NoSuchAlgorithmException if the message digest 'SHA-1' is not
     * available.
     */
    static byte[] passwordHashStage2(byte[] hashedPassword, byte[] salt)
        throws NoSuchAlgorithmException {
        MessageDigest md = MessageDigest.getInstance("SHA-1");

        // hash 4 bytes of salt
        md.update(salt, 0, 4);

        md.update(hashedPassword, 0, SHA1_HASH_SIZE);

        return md.digest();
    }

    private static int[] getSaltFromPassword(String password) {
        int[] result = new int[6];

        if ((password == null) || (password.length() == 0)) {
            return result;
        }

        if (password.charAt(0) == PVERSION41_CHAR) {
            // new password
            String saltInHex = password.substring(1, 5);

            int val = 0;

            for (int i = 0; i < 4; i++) {
                val = (val << 4) + charVal(saltInHex.charAt(i));
            }

            return result;
        } else {
            int resultPos = 0;
            int pos = 0;
            int length = password.length();

            while (pos < length) {
                int val = 0;

                for (int i = 0; i < 8; i++) {
                    val = (val << 4) + charVal(password.charAt(pos++));
                }

                result[resultPos++] = val;
            }

            return result;
        }
    }

    /**
     * Returns hex value for given char
     */
    private static int charVal(char c) {
        return (int) (((c >= '0') && (c <= '9')) ? (c - '0')
                                                 : (((c >= 'A') && (c <= 'Z'))
        ? (c - 'A' + 10) : (c - 'a' + 10)));
    }

    private static String longToHex(long val) {
        String longHex = Long.toHexString(val);

        int length = longHex.length();

        if (length < 8) {
            int padding = 8 - length;
            StringBuffer buf = new StringBuffer();

            for (int i = 0; i < padding; i++) {
                buf.append("0");
            }

            buf.append(longHex);

            return buf.toString();
        } else {
            return longHex.substring(0, 8);
        }
    }

	//	SERVER:  public_seed=create_random_string()
		//			 send(public_seed)
		//
		//	CLIENT:  recv(public_seed)
		//			 hash_stage1=sha1("password")
		//			 hash_stage2=sha1(hash_stage1)
		//			 reply=xor(hash_stage1, sha1(public_seed,hash_stage2)
		//
		//			 // this three steps are done in scramble()
		//
		//			 send(reply)
		//
		//
		//	SERVER:  recv(reply)
		//			 hash_stage1=xor(reply, sha1(public_seed,hash_stage2))
		//			 candidate_hash2=sha1(hash_stage1)
		//			 check(candidate_hash2==hash_stage2)
		
	static byte[] scramble411(String password, String seed) throws NoSuchAlgorithmException {
		MessageDigest md = MessageDigest.getInstance("SHA-1");
		
		byte[] passwordHashStage1 = md.digest(password.getBytes());
		md.reset();
		byte[] passwordHashStage2 = md.digest(passwordHashStage1);
		md.reset();
		byte[] seedAsBytes = seed.getBytes(); // for debugging
		md.update(seedAsBytes);
		md.update(passwordHashStage2);
		
		byte[] toBeXord = md.digest();
		
		int numToXor = toBeXord.length;
		
		for (int i = 0; i < numToXor; i++) {
			toBeXord[i] = (byte)(toBeXord[i] ^ passwordHashStage1[i]);
		}
		
		return toBeXord;
		
	}
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久免费网| 2017欧美狠狠色| 久久激情五月激情| 成人欧美一区二区三区黑人麻豆| 欧美性三三影院| 国v精品久久久网| 日日夜夜免费精品| 亚洲欧美激情小说另类| 亚洲精品在线免费观看视频| 欧洲精品在线观看| 国产精品123| 奇米四色…亚洲| 亚洲综合色噜噜狠狠| 久久久激情视频| 日韩精品一区二区三区中文不卡| 色综合久久久久网| 成人一区二区三区视频在线观看| 日韩不卡一二三区| 一区二区三区精品视频| 中文字幕在线一区二区三区| 欧美大胆人体bbbb| 91精品久久久久久久99蜜桃| 色婷婷av一区二区三区gif| 国产91精品精华液一区二区三区| 麻豆国产精品777777在线| 亚洲成人免费视频| 一个色综合网站| 专区另类欧美日韩| 国产精品蜜臀av| 国产三级久久久| 久久这里只有精品6| 欧美成va人片在线观看| 日韩一区二区三区视频| 欧美精品一卡二卡| 欧美日韩不卡在线| 欧美午夜在线观看| 欧美日韩电影在线播放| 欧美羞羞免费网站| 欧美老肥妇做.爰bbww视频| 在线精品亚洲一区二区不卡| 色屁屁一区二区| 色综合天天性综合| 91福利精品视频| 欧美网站大全在线观看| 欧美熟乱第一页| 91精品国产综合久久久久久久 | 欧美一区二区三区在| 欧美浪妇xxxx高跟鞋交| 欧美二区三区的天堂| 欧美精品自拍偷拍| 日韩午夜av电影| 欧美精品一区视频| 久久精品男人天堂av| 国产欧美日韩不卡| 亚洲免费观看高清完整版在线观看 | 国产精品私人自拍| 国产精品成人免费在线| 自拍av一区二区三区| 亚洲最大成人网4388xx| 三级成人在线视频| 韩国av一区二区| 暴力调教一区二区三区| 97se狠狠狠综合亚洲狠狠| 日本乱人伦一区| 777精品伊人久久久久大香线蕉| 日韩区在线观看| 国产亚洲精品精华液| 亚洲精选一二三| 日本中文在线一区| 国产精品18久久久久久vr| 99久久免费精品| 欧美久久久久久久久| 国产亚洲精品福利| 亚洲一区二区视频| 精品亚洲欧美一区| 99国产精品久久久久| 欧美日韩精品福利| 国产日韩精品久久久| 亚洲欧美激情小说另类| 日本特黄久久久高潮| 国产精品一区二区三区乱码| 色婷婷av一区| 久久一留热品黄| 亚洲国产视频在线| 国产精品一区二区免费不卡 | 欧美三级三级三级| 精品免费99久久| 亚洲激情五月婷婷| 久久99久久99| 色94色欧美sute亚洲13| 久久久美女毛片| 亚洲成人1区2区| 成人黄色综合网站| 日韩午夜av一区| 依依成人精品视频| 国产 日韩 欧美大片| 欧美一级欧美一级在线播放| 国产精品视频一二三区| 蜜臀久久99精品久久久久宅男| 91在线播放网址| 亚洲精品一区在线观看| 亚洲国产色一区| 不卡一区二区在线| 欧美大尺度电影在线| 亚洲bt欧美bt精品| 91丨国产丨九色丨pron| 久久免费美女视频| 青青草国产成人av片免费| 色婷婷综合中文久久一本| 日本一区二区三区在线观看| 三级在线观看一区二区| 日本韩国欧美一区| 中文字幕久久午夜不卡| 激情av综合网| 日韩一级大片在线| 亚洲午夜久久久久久久久电影院| 国产a精品视频| 精品久久久久久久久久久久久久久| 亚洲国产色一区| 欧美一a一片一级一片| 国产精品成人免费| 成人激情文学综合网| 久久午夜老司机| 麻豆91免费看| 欧美日本在线播放| 午夜精品久久久久久久久久| 欧美私模裸体表演在线观看| 亚洲精品国产品国语在线app| 成人动漫一区二区三区| 亚洲国产激情av| 成人av免费在线| 欧美高清在线精品一区| 国产精品77777| 国产欧美日韩另类一区| 国产成人精品亚洲午夜麻豆| 久久久久久亚洲综合影院红桃| 国内精品写真在线观看| 精品对白一区国产伦| 国产中文一区二区三区| 国产性做久久久久久| 国产v综合v亚洲欧| 国产精品久久777777| 成人av网站在线观看免费| 一区二区中文字幕在线| 成人网在线免费视频| 国产精品久久看| 91在线porny国产在线看| 一区二区三区在线免费| 欧美日韩中文国产| 日韩精品五月天| 欧美精品一区二区蜜臀亚洲| 精品一区免费av| 国产亚洲一本大道中文在线| www.欧美色图| 一区二区成人在线| 欧美日韩色综合| 蜜臀a∨国产成人精品| 精品国产一区二区三区av性色| 国内精品不卡在线| 一色桃子久久精品亚洲| 欧美三级日韩三级| 老司机午夜精品99久久| 久久日韩精品一区二区五区| 成人永久免费视频| 亚洲国产精品久久久久秋霞影院| 制服丝袜激情欧洲亚洲| 国产一区二区三区日韩| 国产精品家庭影院| 欧美日韩在线观看一区二区| 麻豆久久一区二区| 欧美国产精品劲爆| 欧美性淫爽ww久久久久无| 久久99精品网久久| 亚洲免费成人av| 日韩欧美一级在线播放| 床上的激情91.| 亚洲国产欧美在线人成| 精品福利一区二区三区免费视频| 99精品久久久久久| 日本不卡免费在线视频| 中文字幕精品一区| 欧美日韩三级一区二区| 国产99一区视频免费| 亚洲一区在线观看网站| 色综合中文字幕国产 | 国产精品麻豆欧美日韩ww| 欧洲一区在线观看| 国产精品一区二区在线观看不卡| 伊人一区二区三区| 久久亚洲精品小早川怜子| 在线视频欧美区| 国产乱码精品一区二区三区av | 欧美男女性生活在线直播观看| 国产在线一区二区综合免费视频| 亚洲天堂精品在线观看| 26uuu色噜噜精品一区| 欧洲激情一区二区| 成人网在线播放| 国内精品国产三级国产a久久| 亚洲一区成人在线|