2017-10-18 73 views
6

我想在我的客戶端使用手指打印,並獲得作爲更大的代碼的一部分這一代碼的持有。隱藏我的哈希數字在javascript

function checksum(str) { 
    var hash = 5382, 
     i = str.length; 

    while (i--) hash = (hash * 33)^str.charCodeAt(i); 

    return hash >>> 0; 
} 

正如你所看到的散列很明顯。你能告訴我如何使用或使用什麼實現,以便我可以隱藏或掩蓋散列= 5382的任何內容。謝謝。

+3

只能混淆它,而不是真正的「隱藏」 – haim770

+0

您可以使用'CryptoJS':https://stackoverflow.com/questions/18279141/javascript-string-encryption-and-decryption –

+0

你需要像[RSA](http://www.ohdave.com/rsa/)這樣的非對稱算法。 – ceving

回答

0

如果您使用base64編碼,但任何人都可以輕鬆解碼。你的散列有多敏感?

str = "The quick brown fox jumps over the lazy dog"; 
b64 = btoa(unescape(encodeURIComponent(str))); 
str = decodeURIComponent(escape(window.atob(b64))); 

輸出將是VGhlIHF1aWNrIGJyb3duIGZveCBqdW1wcyBvdmVyIHRoZSBsYXp5IGRvZw ==

如果你正在使用PHP你只BASE64_ENCODE()和BASE64_DECODE()來處理。例如,你可以使用編碼值隱藏輸入,然後獲取它的val值並使用我給你的最後一行。

Base64 PHP http://php.net/manual/en/function.base64-encode.php and base64 JAVASCRIPT https://developer.mozilla.org/pt-BR/docs/Web/API/WindowBase64/atob。或者你可以加密它的內容然後解密服務器端。下面有一個小類加密/解密數據(PHP):

<?php 
namespace Company\Security; 

/* 
* @description: Simple class to wrap crypt function calls 
* @author: Marco A. Simao 
*/ 

class Crypto { 

/* 
* returns encrypted data with iv appended at the begining of the string 
*/ 
public static function encrypt($data, $key) 
{ 
    $iv = openssl_random_pseudo_bytes(16); 

    $c = openssl_encrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); 

    return $iv . $c; 
} 

/* 
* returns decrypted data. Expects 16 first bytes of data to be iv table. 
*/ 
public static function decrypt($data, $key) 
{ 
    return openssl_decrypt(substr($data, 16), 'AES-128-CBC', $key, OPENSSL_RAW_DATA, substr($data, 0, 16)); 
} 
} 

而且你需要在JavaScript中解密,如:How to use the Web Crypto API to decrypt a file created with OpenSSL?

+0

這看起來不錯。你能告訴我一個它的樣例實現嗎? –

+1

@stackquestions - 請記住這不安全,任何客戶端都可以自己重寫腳本並查看結果。如果你的目標是隱藏從偶然的眼睛粗略檢查的字符串,這很好,但它不會提供任何「真正的」安全。 –

+0

是的,謝謝你指出,我忘了告訴他,但我問它是多麼的敏感:) – Marco