需要jquery/javascript中的Sha1加密吗

需要jquery/javascript中的Sha1加密吗,javascript,jquery,sha1,Javascript,Jquery,Sha1,我有php中的sha1加密编码 <?php echo hash('sha1', 'testing'.'abcdb'); ?> 但是,我的需求应该运行xyz.html页面,因此上面的块不起作用 所以,我需要在jquery/javascript中进行sha1加密。通过为sha1加密提供编码来帮助我 这正是必须转换为脚本的原因 “” 只要在谷歌上搜索一下,就会发现: 有两种方法,可以使用AJAX调用PHP页面并检索SHA-1 或者,您可以使用一个JS库,例如CryptoJS sha1

我有php中的sha1加密编码

<?php
echo hash('sha1', 'testing'.'abcdb');
?>

但是,我的需求应该运行xyz.html页面,因此上面的块不起作用

所以,我需要在jquery/javascript中进行sha1加密。通过为sha1加密提供编码来帮助我

这正是必须转换为脚本的原因

“”
只要在谷歌上搜索一下,就会发现:


有两种方法,可以使用AJAX调用PHP页面并检索SHA-1


或者,您可以使用一个JS库,例如CryptoJS

sha1不是一种亵渎。最好把它想象成有损压缩。它不起作用,我必须把“''”转换成scripts@itsme您确实意识到,如果您使用javascript,您的密钥就不会是秘密的,对吗?什么不起作用?你得到了什么?你期待什么?你有错误吗?错误的值?如果您在客户端加密某人,则是错误的。客户端首先不应接收加密密钥。最好的方法是向服务器发出AJAX调用,服务器接收内容(即电子邮件地址),并返回哈希/加密的内容。如果不起作用,我必须将“'''”转换为脚本。我的意思是,将“'''代码放在一个单独的PHP文件中,然后通过AJAX调用这个PHP文件。到原始网站的链接现在没有响应。@AnwarNairi,这就是为什么我们需要SO=)对!我还看到了Locctus.js实现了这个功能,与这个库和phpjs有什么关系吗?现代浏览器支持一个web标准,你可以用它来代替:你会相信操作系统中的一些随机代码来实现任何与加密相关的东西吗?如果没有,最好使用一个经过审核的库或像@Paul建议的sndardized方法。
'<?php echo hash('sha1', 'my-secret-key' . $_REQUEST["email"]); ?>'
function sha1(str) {
  //  discuss at: http://phpjs.org/functions/sha1/
  // original by: Webtoolkit.info (http://www.webtoolkit.info/)
  // improved by: Michael White (http://getsprink.com)
  // improved by: Kevin van Zonneveld (http://kevin.vanzonneveld.net)
  //    input by: Brett Zamir (http://brett-zamir.me)
  //  depends on: utf8_encode
  //   example 1: sha1('Kevin van Zonneveld');
  //   returns 1: '54916d2e62f65b3afa6e192e6a601cdbe5cb5897'

  var rotate_left = function(n, s) {
    var t4 = (n << s) | (n >>> (32 - s));
    return t4;
  };

  /*var lsb_hex = function (val) { // Not in use; needed?
    var str="";
    var i;
    var vh;
    var vl;

    for ( i=0; i<=6; i+=2 ) {
      vh = (val>>>(i*4+4))&0x0f;
      vl = (val>>>(i*4))&0x0f;
      str += vh.toString(16) + vl.toString(16);
    }
    return str;
  };*/

  var cvt_hex = function(val) {
    var str = '';
    var i;
    var v;

    for (i = 7; i >= 0; i--) {
      v = (val >>> (i * 4)) & 0x0f;
      str += v.toString(16);
    }
    return str;
  };

  var blockstart;
  var i, j;
  var W = new Array(80);
  var H0 = 0x67452301;
  var H1 = 0xEFCDAB89;
  var H2 = 0x98BADCFE;
  var H3 = 0x10325476;
  var H4 = 0xC3D2E1F0;
  var A, B, C, D, E;
  var temp;

  str = this.utf8_encode(str);
  var str_len = str.length;

  var word_array = [];
  for (i = 0; i < str_len - 3; i += 4) {
    j = str.charCodeAt(i) << 24 | str.charCodeAt(i + 1) << 16 | str.charCodeAt(i + 2) << 8 | str.charCodeAt(i + 3);
    word_array.push(j);
  }

  switch (str_len % 4) {
    case 0:
      i = 0x080000000;
      break;
    case 1:
      i = str.charCodeAt(str_len - 1) << 24 | 0x0800000;
      break;
    case 2:
      i = str.charCodeAt(str_len - 2) << 24 | str.charCodeAt(str_len - 1) << 16 | 0x08000;
      break;
    case 3:
      i = str.charCodeAt(str_len - 3) << 24 | str.charCodeAt(str_len - 2) << 16 | str.charCodeAt(str_len - 1) <<
        8 | 0x80;
      break;
  }

  word_array.push(i);

  while ((word_array.length % 16) != 14) {
    word_array.push(0);
  }

  word_array.push(str_len >>> 29);
  word_array.push((str_len << 3) & 0x0ffffffff);

  for (blockstart = 0; blockstart < word_array.length; blockstart += 16) {
    for (i = 0; i < 16; i++) {
      W[i] = word_array[blockstart + i];
    }
    for (i = 16; i <= 79; i++) {
      W[i] = rotate_left(W[i - 3] ^ W[i - 8] ^ W[i - 14] ^ W[i - 16], 1);
    }

    A = H0;
    B = H1;
    C = H2;
    D = H3;
    E = H4;

    for (i = 0; i <= 19; i++) {
      temp = (rotate_left(A, 5) + ((B & C) | (~B & D)) + E + W[i] + 0x5A827999) & 0x0ffffffff;
      E = D;
      D = C;
      C = rotate_left(B, 30);
      B = A;
      A = temp;
    }

    for (i = 20; i <= 39; i++) {
      temp = (rotate_left(A, 5) + (B ^ C ^ D) + E + W[i] + 0x6ED9EBA1) & 0x0ffffffff;
      E = D;
      D = C;
      C = rotate_left(B, 30);
      B = A;
      A = temp;
    }

    for (i = 40; i <= 59; i++) {
      temp = (rotate_left(A, 5) + ((B & C) | (B & D) | (C & D)) + E + W[i] + 0x8F1BBCDC) & 0x0ffffffff;
      E = D;
      D = C;
      C = rotate_left(B, 30);
      B = A;
      A = temp;
    }

    for (i = 60; i <= 79; i++) {
      temp = (rotate_left(A, 5) + (B ^ C ^ D) + E + W[i] + 0xCA62C1D6) & 0x0ffffffff;
      E = D;
      D = C;
      C = rotate_left(B, 30);
      B = A;
      A = temp;
    }

    H0 = (H0 + A) & 0x0ffffffff;
    H1 = (H1 + B) & 0x0ffffffff;
    H2 = (H2 + C) & 0x0ffffffff;
    H3 = (H3 + D) & 0x0ffffffff;
    H4 = (H4 + E) & 0x0ffffffff;
  }

  temp = cvt_hex(H0) + cvt_hex(H1) + cvt_hex(H2) + cvt_hex(H3) + cvt_hex(H4);
  return temp.toLowerCase();
}
sha1('testing'+'abcdb');