JavaScript 加密方法(Hash算法)

简单罗列JavaScript 中的Hash加密算法

原生的加密方式

escape和unescape

如果是简单的加密我们可以使用JavaScript原生的方法escapeunescape

escape方法不会对 ASCII 字母和数字进行编码,也不会对下面这些 ASCII 标点符号进行编码:* @ - _ + . /。其他所有的字符都会被转义序列替换。


    console.log("output:" + escape("chenjy 1225! "));

    console.log("output:" + unescape(escape("chenjy 1225! ")));

    output:chenjy%201225%21%20

    output:chenjy 1225!
    

Hash算法

Hash算法特点:

  • 很容易可以算出给的数值的散列数值
  • 难以通过已知的散列数值推算原始信息
  • 在不更改散列数值的基础上,无法更改消息内容
  • 对于两条不同消息无法给出相同的散列数值

由于Hash算法的有以上特性所以常用在很多的重要应用例如数字签名,消息认证码。

?

MD5算法

MD5是提供了一种128bit``Hash值的密码散列函数,

算法原理

填充输入信息,使其字节长度对512求余数为448。信息的长度扩展为N*512+448 bit N为整数

添加4个32位的链接变量

  • A=0x01234567
  • B=0x89abcdef
  • C=0xfedcba98
  • D=0x76543210

使其长度为(N+1)*512 bit,然后将每个512bit的组分为1632bit子分组,最后经过一系列的算法生成432bit128bit的散列值。

算法使用

MD5js MD5.js source code


    console.log(hex_md5("chenjy 1225!"));
    //basic-64编码
    console.log(b64_md5("chenjy 1225!"));

    output:6e065c650d8258f73bac5a3cd8f88f47

    output:bgZcZQ2CWPc7rFo82PiPRw

SHA家族

SHA家族是一个密码散列函数家族,分别是SHA-1SHA-224SHA-256SHA-384SHA-512

根据产生信息摘要的长度命名。

  • SHA-1:160bit
  • SHA-224:224bit
  • SHA-256:256bit
  • SHA-384:384bit
  • SHA-512:512bit

算法原理

原理和MD5类似,以SHA-1为例:

SHA-1能根据2-64bit的信息输入计算出160bit的散列值的单向散列函数。

填充数据的时候也是512bit为一组。在原始数据后先添加一个1然后添加0一直填满448bit

然后再添加原始数据长度64bit,共为512bit

同样分为为1632bit子分组,最后经过一系列的算法生成532bit160bit的散列值。

算法使用

SHA-1.js SHA-1.js source code

SHA-256.js SHA-256.js source code

SHA-512.js SHA-512.js source code


    console.log(hex_sha1("chenjy 1225!"));

    console.log(hex_sha256("chenjy 1225!"));

    console.log(hex_sha512("chenjy 1225!"));

    output:a8a3b8b4263f7c12bbb400b6841aca472f53df0a

    output:1b4d37e8177634f191a7742c6d7e3d8aaf556aae583da0944e353001344fe3b0

    output:52622c1d8351011cb8ec1c4c891387d9a221c34e9e7289692070ef6656e98c4025328682cb86bd8577f6ed2b51c61559adb76685356632543db3e9020cc162f2

Blizzard one way hash





据说是我大暴雪很经典的Hash算法。

Blizzard one way hash Blizzard

原文地址:https://www.cnblogs.com/chenjy1225/p/9661337.html

时间: 2024-11-06 10:02:08

JavaScript 加密方法(Hash算法)的相关文章

JAVASCRIPT加密方法,JS加密解密综述(7种)

一:最简单的加密解密 对于JAVASCRIPT函数escape()和unescape()想必是比较了解啦(很多网页加密在用它们),分别是编码和解码字符串,比如例子代码 用escape()函数加密后变为如下格式: alert%28%22%u9ED1%u5BA2%u9632%u7EBF%22%29%3B 如何?还看的懂吗?当然其中的ASCII字符"alert"并没有被加密,如果愿意我们可以写点JAVASCRIPT代码重新把它加密如下: %61%6C%65%72%74%28%22%u9ED1

JS_七种JAVASCRIPT加密/解密方法

本文一共介绍了七种JAVASCRIPT加密方法. 一:最简单的加密解密 二:转义字符的妙用 三:使用Microsoft出品的脚本编码器Script Encoder来进行编码 (自创简单解码) 四:任意添加NUL空字符(十六进制00H) (自创) 五:无用内容混乱以及换行空格TAB大法 六:自写解密函数法 七:错误的利用 在做网页时(其实是网页木马呵呵),最让人烦恼的是自己辛辛苦苦写出来的客户端IE运行的JAVASCRIPT代码常常被别人轻易的拷贝,实在让自己的心里有点不是滋味,要知道自己写点东西

JavaScript加密解密7种方法总结分析

原文地址:http://wenku.baidu.com/view/9048edee9e31433239689357.html 本文一共介绍了七种javascript加密方法: 在做网页时(其实是网页木马呵呵),最让人烦恼的是自己辛辛苦苦写出来的客户端IE运行的javascript代码常常被别人轻易的拷贝,实在让自己的心里有点不是滋味,要知道自己写点东西也挺累的......^*^ 但我们也应该清楚地认识到因为javascript代码是在IE中解释执行,要想绝对的保密是不可能的,我们要做的就是尽可能

逐步实现hash算法(基于BKDRhash函数)

哈希(Hash)算法,即散列函数.它是一种单向密码体制,即它是一个从明文到密文的不可逆的映射,只有加密过程,没有解密过程.同时,哈希函数可以将任意长度的输入经过变化以后得到固定长度的输出.hash算法一般用于快速查找和加密. hash算法可以使用的哈希函数种类很多,处理冲突的方法也有开放定址.再哈希.链地址.公共溢出区等. 因此,在编写代码之前,首先需要根据所要处理的数据,选择合适的hash函数和冲突处理办法.开放定址需要空闲存储单元,所需要的表比实际容量大,而且容易产生二次聚集发生新冲突.链地

webqq 获得好友列表hash算法 获得最新hash的方法

webqq获得好友列表的hash算法,大约每个月中旬会变动一次.知道怎么获得他就可以了. js文件路径 http://web.qstatic.com/webqqpic/pubapps/0/50/eqq.all.js 加密算法为 P=function(b,i),有时候是 P=function(b,j) 直接打开这个文件后搜索P=function,有两个参数的就是. 把函数体拷贝下来后百度 js格式化工具,把内容放进去,格式化一下. 下面是2014年6月17日时的hash函数: P=function

常见hash算法的原理(转)

常见hash算法的原理 散列表,它是基于快速存取的角度设计的,也是一种典型的“空间换时间”的做法.顾名思义,该数据结构可以理解为一个线性表,但是其中的元素不是紧密排列的,而是可能存在空隙. 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度.这个映射函数叫做散列函数,存放记录的数组叫做散列表. 比如我们存储70个元素,但我们可能为这70个元素申请了100个元素的空间.7

iOS 几种加密方法

iOS常见的几种加密方法 普通加密方法是讲密码进行加密后保存到用户偏好设置中 钥匙串是以明文形式保存,但是不知道存放的具体位置 1.base64加密 base64 编码是现代密码学的基础 基本原理: 原本是 8个bit 一组表示数据,改为 6个bit一组表示数据,不足的部分补零,每 两个0 用 一个 = 表示 用base64 编码之后,数据长度会变大,增加了大约 1/3 左右.(8-6)/6可进行反向解密 Xcode7.0 之后出现的 编码有个非常显著的特点,末尾有个 = 号 将文件进行加密 /

常见hash算法的原理

转自:http://blog.csdn.net/zxycode007/article/details/6999984 散列表,它是基于快速存取的角度设计的,也是一种典型的“空间换时间”的做法.顾名思义,该数据结构可以理解为一个线性表,但是其中的元素不是紧密排列的,而是可能存在空隙. 散列表(Hash table,也叫哈希表),是根据关键码值(Key value)而直接进行访问的数据结构.也就是说,它通过把关键码值映射到表中一个位置来访问记录,以加快查找的速度.这个映射函数叫做散列函数,存放记录的

Hash算法总结

1. Hash是什么,它的作用 先举个例子.我们每个活在世上的人,为了能够参与各种社会活动,都需要一个用于识别自己的标志.也许你觉得名字或是身份证就足以代表你这个人,但是这种代表性非常脆弱,因为重名的人很多,身份证也可以伪造.最可靠的办法是把一个人的所有基因序列记录下来用来代表这个人,但显然,这样做并不实际.而指纹看上去是一种不错的选择,虽然一些专业组织仍然可以模拟某个人的指纹,但这种代价实在太高了. 而对于在互联网世界里传送的文件来说,如何标志一个文件的身份同样重要.比如说我们下载一个文件,文