mirror of
https://github.com/denoland/deno.git
synced 2024-12-24 08:09:08 -05:00
d0970daacd
Co-authored-by: Bartek Iwańczuk <biwanczuk@gmail.com> |
||
---|---|---|
.. | ||
_fnv | ||
_sha3 | ||
testdata | ||
fnv.ts | ||
fnv_test.ts | ||
md5.ts | ||
md5_test.ts | ||
README.md | ||
sha1.ts | ||
sha1_test.ts | ||
sha3.ts | ||
sha3_test.ts | ||
sha256.ts | ||
sha256_test.ts | ||
sha512.ts | ||
sha512_test.ts |
std/hash
MD5
Uses:
import { Md5 } from "https://deno.land/std/hash/md5.ts";
const md5 = new Md5();
const md5Instance = md5.update("中文"); // return instance of `Md5`
console.log(md5Instance instanceof Md5); // true
console.log(md5Instance.toString()); // a7bac2239fcdcb3a067903d8077c4a07
Calling update
method, It will update internal state based on the input
provided. Once you call md5Instance.toString()
, it will return the
hash string
. You can provide format as hash
or base64
. The default format
is hex
.
sample:
console.log(md5Instance.toString("base64")); // MNgWOD+FHGO3Fff/HDCY2w==
SHA1
Uses:
Creating sha1
hash is simple. You can use Sha1
class instance and update the
digest. Calling hex
method will return the sha1 in hex value. You can also use
toString
method.
import { Sha1 } from "https://deno.land/std/hash/sha1.ts";
const sha1 = new Sha1().update("中文");
console.log(sha1.hex()); // 7be2d2d20c106eee0836c9bc2b939890a78e8fb3
console.log(sha1.toString()); // same as above
Sha256 and HmacSha256
Uses:
Creating Sha256
hash is simple. You can use Sha256
class instance and update
the digest. Calling the hex
method will return the sha256 in hex
value. You
can also use the toString
method.
Note: For HmacSha256
, you can pass the secret key
while creating an
instance of the object.
import { Sha256, HmacSha256 } from "https://deno.land/std/hash/sha256.ts";
const sha256 = new Sha256().update("中文");
console.log(sha256.hex());
console.log(sha256.toString()); // Same as above
const key = "Hi There";
const hmac = new HmacSha256(key).update("中文");
console.log(hmac.hex());
console.log(hmac.toString()); // Same as above