org.mindrot.jbcrypt.BCrypt.encipher()方法的使用及代码示例

x33g5p2x  于2022-01-16 转载在 其他  
字(10.7k)|赞(0)|评价(0)|浏览(143)

本文整理了Java中org.mindrot.jbcrypt.BCrypt.encipher()方法的一些代码示例,展示了BCrypt.encipher()的具体用法。这些代码示例主要来源于Github/Stackoverflow/Maven等平台,是从一些精选项目中提取出来的代码,具有较强的参考意义,能在一定程度帮忙到你。BCrypt.encipher()方法的具体详情如下:
包路径:org.mindrot.jbcrypt.BCrypt
类名称:BCrypt
方法名:encipher

BCrypt.encipher介绍

[英]Blowfish encipher a single 64-bit block encoded as two 32-bit halves
[中]河豚对编码为两个32位半块的单个64位块进行加密

代码示例

代码示例来源:origin: hierynomus/sshj

/**
 * Key the Blowfish cipher
 * @param key    an array containing the key
 */
private void key(byte key[]) {
  int i;
  int koffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: hierynomus/sshj

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data    salt information
 * @param key    password information
 */
private void ekskey(byte data[], byte key[]) {
  int i;
  int koffp[] = { 0 }, doffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: hierynomus/sshj

/**
 * Compatibility with new OpenBSD function.
 */
public void hash(byte[] hpass, byte[] hsalt, byte[] output) {
  init_key();
  ekskey(hsalt, hpass);
  for (int i = 0; i < 64; i++) {
    key(hsalt);
    key(hpass);
  }
  int[] buf = new int[openbsd_iv.length];
  System.arraycopy(openbsd_iv, 0, buf, 0, openbsd_iv.length);
  for (int i = 0; i < 8; i += 2) {
    for (int j = 0; j < 64; j++) {
      encipher(buf, i);
    }
  }
  for (int i = 0, j = 0; i < buf.length; i++) {
    // Output of this is little endian
    output[j++] = (byte)(buf[i] & 0xff);
    output[j++] = (byte)((buf[i] >> 8) & 0xff);
    output[j++] = (byte)((buf[i] >> 16) & 0xff);
    output[j++] = (byte)((buf[i] >> 24) & 0xff);
  }
}

代码示例来源:origin: hierynomus/sshj

encipher(cdata, j << 1);

代码示例来源:origin: actframework/actframework

/**
 * Key the Blowfish cipher
 * @param key    an array containing the key
 */
private void key(byte key[]) {
  int i;
  int koffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: de.svenkubiak/jBCrypt

/**
 * Key the Blowfish cipher
 * @param key    an array containing the key
 */
private void key(byte key[]) {
  int i;
  int koffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: org.actframework/act

/**
 * Key the Blowfish cipher
 * @param key    an array containing the key
 */
private void key(byte key[]) {
  int i;
  int koffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: org.connectbot.jbcrypt/jbcrypt

/**
 * Key the Blowfish cipher
 * @param key    an array containing the key
 */
private void key(byte key[]) {
  int i;
  int koffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: org.mindrot/jbcrypt

/**
 * Key the Blowfish cipher
 * @param key    an array containing the key
 */
private void key(byte key[]) {
  int i;
  int koffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: com.hierynomus/sshj

/**
 * Key the Blowfish cipher
 * @param key    an array containing the key
 */
private void key(byte key[]) {
  int i;
  int koffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: rogerta/secrets-for-android

/**
 * Key the Blowfish cipher
 * @param key an array containing the key
 */
private void key(byte key[]) {
 int i;
 int koffp[] = { 0 };
 int lr[] = { 0, 0 };
 int plen = P.length, slen = S.length;
 for (i = 0; i < plen; i++)
  P[i] = P[i] ^ streamtoword(key, koffp);
 for (i = 0; i < plen; i += 2) {
  encipher(lr, 0);
  P[i] = lr[0];
  P[i + 1] = lr[1];
 }
 for (i = 0; i < slen; i += 2) {
  encipher(lr, 0);
  S[i] = lr[0];
  S[i + 1] = lr[1];
 }
}

代码示例来源:origin: de.svenkubiak/jBCrypt

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data    salt information
 * @param key    password information
 */
private void ekskey(byte data[], byte key[]) {
  int i;
  int koffp[] = { 0 }, doffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: actframework/actframework

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data    salt information
 * @param key    password information
 */
private void ekskey(byte data[], byte key[]) {
  int i;
  int koffp[] = { 0 }, doffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: org.mindrot/jbcrypt

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data    salt information
 * @param key    password information
 */
private void ekskey(byte data[], byte key[]) {
  int i;
  int koffp[] = { 0 }, doffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: com.hierynomus/sshj

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data    salt information
 * @param key    password information
 */
private void ekskey(byte data[], byte key[]) {
  int i;
  int koffp[] = { 0 }, doffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: org.connectbot.jbcrypt/jbcrypt

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data    salt information
 * @param key    password information
 */
private void ekskey(byte data[], byte key[]) {
  int i;
  int koffp[] = { 0 }, doffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: org.actframework/act

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data    salt information
 * @param key    password information
 */
private void ekskey(byte data[], byte key[]) {
  int i;
  int koffp[] = { 0 }, doffp[] = { 0 };
  int lr[] = { 0, 0 };
  int plen = P.length, slen = S.length;
  for (i = 0; i < plen; i++)
    P[i] = P[i] ^ streamtoword(key, koffp);
  for (i = 0; i < plen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    P[i] = lr[0];
    P[i + 1] = lr[1];
  }
  for (i = 0; i < slen; i += 2) {
    lr[0] ^= streamtoword(data, doffp);
    lr[1] ^= streamtoword(data, doffp);
    encipher(lr, 0);
    S[i] = lr[0];
    S[i + 1] = lr[1];
  }
}

代码示例来源:origin: rogerta/secrets-for-android

/**
 * Perform the "enhanced key schedule" step described by
 * Provos and Mazieres in "A Future-Adaptable Password Scheme"
 * http://www.openbsd.org/papers/bcrypt-paper.ps
 * @param data  salt information
 * @param key password information
 */
private void ekskey(byte data[], byte key[]) {
 int i;
 int koffp[] = { 0 }, doffp[] = { 0 };
 int lr[] = { 0, 0 };
 int plen = P.length, slen = S.length;
 for (i = 0; i < plen; i++)
  P[i] = P[i] ^ streamtoword(key, koffp);
 for (i = 0; i < plen; i += 2) {
  lr[0] ^= streamtoword(data, doffp);
  lr[1] ^= streamtoword(data, doffp);
  encipher(lr, 0);
  P[i] = lr[0];
  P[i + 1] = lr[1];
 }
 for (i = 0; i < slen; i += 2) {
  lr[0] ^= streamtoword(data, doffp);
  lr[1] ^= streamtoword(data, doffp);
  encipher(lr, 0);
  S[i] = lr[0];
  S[i + 1] = lr[1];
 }
}

代码示例来源:origin: org.connectbot.jbcrypt/jbcrypt

/**
 * Compatibility with new OpenBSD function.
 */
public void hash(byte[] hpass, byte[] hsalt, byte[] output) {
  init_key();
  ekskey(hsalt, hpass);
  for (int i = 0; i < 64; i++) {
    key(hsalt);
    key(hpass);
  }
  int[] buf = new int[openbsd_iv.length];
  System.arraycopy(openbsd_iv, 0, buf, 0, openbsd_iv.length);
  for (int i = 0; i < 8; i += 2) {
    for (int j = 0; j < 64; j++) {
      encipher(buf, i);
    }
  }
  for (int i = 0, j = 0; i < buf.length; i++) {
    // Output of this is little endian
    output[j++] = (byte)(buf[i] & 0xff);
    output[j++] = (byte)((buf[i] >> 8) & 0xff);
    output[j++] = (byte)((buf[i] >> 16) & 0xff);
    output[j++] = (byte)((buf[i] >> 24) & 0xff);
  }
}

代码示例来源:origin: com.hierynomus/sshj

/**
 * Compatibility with new OpenBSD function.
 */
public void hash(byte[] hpass, byte[] hsalt, byte[] output) {
  init_key();
  ekskey(hsalt, hpass);
  for (int i = 0; i < 64; i++) {
    key(hsalt);
    key(hpass);
  }
  int[] buf = new int[openbsd_iv.length];
  System.arraycopy(openbsd_iv, 0, buf, 0, openbsd_iv.length);
  for (int i = 0; i < 8; i += 2) {
    for (int j = 0; j < 64; j++) {
      encipher(buf, i);
    }
  }
  for (int i = 0, j = 0; i < buf.length; i++) {
    // Output of this is little endian
    output[j++] = (byte)(buf[i] & 0xff);
    output[j++] = (byte)((buf[i] >> 8) & 0xff);
    output[j++] = (byte)((buf[i] >> 16) & 0xff);
    output[j++] = (byte)((buf[i] >> 24) & 0xff);
  }
}

相关文章