SHA1.js
上传用户:kimgenplus
上传日期:2016-06-05
资源大小:20877k
文件大小:4k
源码类别:

OA系统

开发平台:

Java

  1. /*
  2. Copyright (c) 2004-2006, The Dojo Foundation
  3. All Rights Reserved.
  4. Licensed under the Academic Free License version 2.1 or above OR the
  5. modified BSD license. For more information on Dojo licensing, see:
  6. http://dojotoolkit.org/community/licensing.shtml
  7. */
  8. dojo.require("dojo.crypto");
  9. dojo.provide("dojo.crypto.SHA1");
  10. dojo.require("dojo.experimental");
  11. dojo.experimental("dojo.crypto.SHA1");
  12. dojo.crypto.SHA1 = new function () {
  13. var chrsz = 8;
  14. var mask = (1 << chrsz) - 1;
  15. function toWord(s) {
  16. var wa = [];
  17. for (var i = 0; i < s.length * chrsz; i += chrsz) {
  18. wa[i >> 5] |= (s.charCodeAt(i / chrsz) & mask) << (i % 32);
  19. }
  20. return wa;
  21. }
  22. function toString(wa) {
  23. var s = [];
  24. for (var i = 0; i < wa.length * 32; i += chrsz) {
  25. s.push(String.fromCharCode((wa[i >> 5] >>> (i % 32)) & mask));
  26. }
  27. return s.join("");
  28. }
  29. function toHex(wa) {
  30. var h = "0123456789abcdef";
  31. var s = [];
  32. for (var i = 0; i < wa.length * 4; i++) {
  33. s.push(h.charAt((wa[i >> 2] >> ((i % 4) * 8 + 4)) & 15) + h.charAt((wa[i >> 2] >> ((i % 4) * 8)) & 15));
  34. }
  35. return s.join("");
  36. }
  37. function toBase64(wa) {
  38. var p = "=";
  39. var tab = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  40. var s = [];
  41. for (var i = 0; i < wa.length * 4; i += 3) {
  42. var t = (((wa[i >> 2] >> 8 * (i % 4)) & 255) << 16) | (((wa[i + 1 >> 2] >> 8 * ((i + 1) % 4)) & 255) << 8) | ((wa[i + 2 >> 2] >> 8 * ((i + 2) % 4)) & 255);
  43. for (var j = 0; j < 4; j++) {
  44. if (i * 8 + j * 6 > wa.length * 32) {
  45. s.push(p);
  46. } else {
  47. s.push(tab.charAt((t >> 6 * (3 - j)) & 63));
  48. }
  49. }
  50. }
  51. return s.join("");
  52. }
  53. function add(x, y) {
  54. var l = (x & 65535) + (y & 65535);
  55. var m = (x >> 16) + (y >> 16) + (l >> 16);
  56. return (m << 16) | (l & 65535);
  57. }
  58. function r(x, n) {
  59. return (x << n) | (x >>> (32 - n));
  60. }
  61. function f(u, v, w) {
  62. return ((u & v) | (~u & w));
  63. }
  64. function g(u, v, w) {
  65. return ((u & v) | (u & w) | (v & w));
  66. }
  67. function h(u, v, w) {
  68. return (u ^ v ^ w);
  69. }
  70. function fn(i, u, v, w) {
  71. if (i < 20) {
  72. return f(u, v, w);
  73. }
  74. if (i < 40) {
  75. return h(u, v, w);
  76. }
  77. if (i < 60) {
  78. return g(u, v, w);
  79. }
  80. return h(u, v, w);
  81. }
  82. function cnst(i) {
  83. if (i < 20) {
  84. return 1518500249;
  85. }
  86. if (i < 40) {
  87. return 1859775393;
  88. }
  89. if (i < 60) {
  90. return -1894007588;
  91. }
  92. return -899497514;
  93. }
  94. function core(x, len) {
  95. x[len >> 5] |= 128 << (24 - len % 32);
  96. x[((len + 64 >> 9) << 4) + 15] = len;
  97. var w = [];
  98. var a = 1732584193;
  99. var b = -271733879;
  100. var c = -1732584194;
  101. var d = 271733878;
  102. var e = -1009589776;
  103. for (var i = 0; i < x.length; i += 16) {
  104. var olda = a;
  105. var oldb = b;
  106. var oldc = c;
  107. var oldd = d;
  108. var olde = e;
  109. for (var j = 0; j < 80; j++) {
  110. if (j < 16) {
  111. w[j] = x[i + j];
  112. } else {
  113. w[j] = r(w[j - 3] ^ w[j - 8] ^ w[j - 14] ^ w[j - 16], 1);
  114. }
  115. var t = add(add(r(a, 5), fn(j, b, c, d)), add(add(e, w[j]), cnst(j)));
  116. e = d;
  117. d = c;
  118. c = r(b, 30);
  119. b = a;
  120. a = t;
  121. }
  122. a = add(a, olda);
  123. b = add(b, oldb);
  124. c = add(c, oldc);
  125. d = add(d, oldd);
  126. e = add(e, olde);
  127. }
  128. return [a, b, c, d, e];
  129. }
  130. function hmac(data, key) {
  131. var wa = toWord(key);
  132. if (wa.length > 16) {
  133. wa = core(wa, key.length * chrsz);
  134. }
  135. var l = [], r = [];
  136. for (var i = 0; i < 16; i++) {
  137. l[i] = wa[i] ^ 909522486;
  138. r[i] = wa[i] ^ 1549556828;
  139. }
  140. var h = core(l.concat(toWord(data)), 512 + data.length * chrsz);
  141. return core(r.concat(h), 640);
  142. }
  143. this.compute = function (data, outputType) {
  144. var out = outputType || dojo.crypto.outputTypes.Base64;
  145. switch (out) {
  146.   case dojo.crypto.outputTypes.Hex:
  147. return toHex(core(toWord(data), data.length * chrsz));
  148.   case dojo.crypto.outputTypes.String:
  149. return toString(core(toWord(data), data.length * chrsz));
  150.   default:
  151. return toBase64(core(toWord(data), data.length * chrsz));
  152. }
  153. };
  154. this.getHMAC = function (data, key, outputType) {
  155. var out = outputType || dojo.crypto.outputTypes.Base64;
  156. switch (out) {
  157.   case dojo.crypto.outputTypes.Hex:
  158. return toHex(hmac(data, key));
  159.   case dojo.crypto.outputTypes.String:
  160. return toString(hmac(data, key));
  161.   default:
  162. return toBase64(hmac(data, key));
  163. }
  164. };
  165. }();