sha1.js 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. var hexcase = 0;
  2. var chrsz = 8;
  3. function hex_sha1(s) {
  4. return binb2hex(core_sha1(str2binb(s), s.length * chrsz));
  5. }
  6. function core_sha1(x, len) {
  7. x[len >> 5] |= 0x80 << (24 - (len % 32));
  8. x[(((len + 64) >> 9) << 4) + 15] = len;
  9. var w = Array(80);
  10. var a = 1732584193;
  11. var b = -271733879;
  12. var c = -1732584194;
  13. var d = 271733878;
  14. var e = -1009589776;
  15. for (var i = 0; i < x.length; i += 16) {
  16. var olda = a;
  17. var oldb = b;
  18. var oldc = c;
  19. var oldd = d;
  20. var olde = e;
  21. for (var j = 0; j < 80; j++) {
  22. if (j < 16) w[j] = x[i + j];
  23. else w[j] = rol(w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16], 1);
  24. var t = safe_add(
  25. safe_add(rol(a, 5), sha1_ft(j, b, c, d)),
  26. safe_add(safe_add(e, w[j]), sha1_kt(j))
  27. );
  28. e = d;
  29. d = c;
  30. c = rol(b, 30);
  31. b = a;
  32. a = t;
  33. }
  34. a = safe_add(a, olda);
  35. b = safe_add(b, oldb);
  36. c = safe_add(c, oldc);
  37. d = safe_add(d, oldd);
  38. e = safe_add(e, olde);
  39. }
  40. return Array(a, b, c, d, e);
  41. }
  42. function sha1_ft(t, b, c, d) {
  43. if (t < 20) return (b & c) | (~b & d);
  44. if (t < 40) return b ^ c ^ d;
  45. if (t < 60) return (b & c) | (b & d) | (c & d);
  46. return b ^ c ^ d;
  47. }
  48. function sha1_kt(t) {
  49. return t < 20
  50. ? 1518500249
  51. : t < 40
  52. ? 1859775393
  53. : t < 60
  54. ? -1894007588
  55. : -899497514;
  56. }
  57. function safe_add(x, y) {
  58. var lsw = (x & 0xffff) + (y & 0xffff);
  59. var msw = (x >> 16) + (y >> 16) + (lsw >> 16);
  60. return (msw << 16) | (lsw & 0xffff);
  61. }
  62. function rol(num, cnt) {
  63. return (num << cnt) | (num >>> (32 - cnt));
  64. }
  65. function str2binb(str) {
  66. var bin = Array();
  67. var mask = (1 << chrsz) - 1;
  68. for (var i = 0; i < str.length * chrsz; i += chrsz)
  69. bin[i >> 5] |= (str.charCodeAt(i / chrsz) & mask) << (24 - (i % 32));
  70. return bin;
  71. }
  72. function binb2hex(binarray) {
  73. var hex_tab = hexcase ? "0123456789ABCDEF" : "0123456789abcdef";
  74. var str = "";
  75. for (var i = 0; i < binarray.length * 4; i++) {
  76. str +=
  77. hex_tab.charAt((binarray[i >> 2] >> ((3 - (i % 4)) * 8 + 4)) & 0xf) +
  78. hex_tab.charAt((binarray[i >> 2] >> ((3 - (i % 4)) * 8)) & 0xf);
  79. }
  80. return str;
  81. }
  82. module.exports = {
  83. hex_sha1,
  84. }