sha1.js 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889
  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(safe_add(rol(a, 5), sha1_ft(j, b, c, d)), safe_add(safe_add(e, w[j]), sha1_kt(j)));
  25. e = d;
  26. d = c;
  27. c = rol(b, 30);
  28. b = a;
  29. a = t;
  30. }
  31. a = safe_add(a, olda);
  32. b = safe_add(b, oldb);
  33. c = safe_add(c, oldc);
  34. d = safe_add(d, oldd);
  35. e = safe_add(e, olde);
  36. }
  37. return Array(a, b, c, d, e);
  38. }
  39. function sha1_ft(t, b, c, d) {
  40. if (t < 20) return (b & c) | (~b & d);
  41. if (t < 40) return b ^ c ^ d;
  42. if (t < 60) return (b & c) | (b & d) | (c & d);
  43. return b ^ c ^ d;
  44. }
  45. function sha1_kt(t) {
  46. return t < 20 ? 1518500249 : t < 40 ? 1859775393 : t < 60 ? -1894007588 : -899497514;
  47. }
  48. function safe_add(x, y) {
  49. var lsw = (x & 0xffff) + (y & 0xffff);
  50. var msw = (x >> 16) + (y >> 16) + (lsw >> 16);
  51. return (msw << 16) | (lsw & 0xffff);
  52. }
  53. function rol(num, cnt) {
  54. return (num << cnt) | (num >>> (32 - cnt));
  55. }
  56. function str2binb(str) {
  57. var bin = Array();
  58. var mask = (1 << chrsz) - 1;
  59. for (var i = 0; i < str.length * chrsz; i += chrsz) bin[i >> 5] |= (str.charCodeAt(i / chrsz) & mask) << (24 - (i % 32));
  60. return bin;
  61. }
  62. function binb2hex(binarray) {
  63. var hex_tab = hexcase ? '0123456789ABCDEF' : '0123456789abcdef';
  64. var str = '';
  65. for (var i = 0; i < binarray.length * 4; i++) {
  66. str += hex_tab.charAt((binarray[i >> 2] >> ((3 - (i % 4)) * 8 + 4)) & 0xf) + hex_tab.charAt((binarray[i >> 2] >> ((3 - (i % 4)) * 8)) & 0xf);
  67. }
  68. return str;
  69. }
  70. module.exports = {
  71. hex_sha1
  72. };