sha1.js 2.3 KB

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