js加密解密字符串可自定义密码因子


Posted in Javascript onMay 13, 2014
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>字符串加密</title> 
</head> 
<body> 
<SCRIPT LANGUAGE="JavaScript"> 
<!-- Begin 
function encrypt(str, pwd) { 
if(pwd == null || pwd.length <= 0) { 
alert("Please enter a password with which to encrypt the message."); 
return null; 
} 
var prand = ""; 
for(var i=0; i<pwd.length; i++) { 
prand += pwd.charCodeAt(i).toString(); 
} 
var sPos = Math.floor(prand.length / 5); 
var mult = parseInt(prand.charAt(sPos) + prand.charAt(sPos*2) + prand.charAt(sPos*3) + prand.charAt(sPos*4) + prand.charAt(sPos*5)); 
var incr = Math.ceil(pwd.length / 2); 
var modu = Math.pow(2, 31) - 1; 
if(mult < 2) { 
alert("Algorithm cannot find a suitable hash. Please choose a different password. \nPossible considerations are to choose a more complex or longer password."); 
return null; 
} 
var salt = Math.round(Math.random() * 1000000000) % 100000000; 
prand += salt; 
while(prand.length > 10) { 
prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString(); 
} 
prand = (mult * prand + incr) % modu; 
var enc_chr = ""; 
var enc_str = ""; 
for(var i=0; i<str.length; i++) { 
enc_chr = parseInt(str.charCodeAt(i) ^ Math.floor((prand / modu) * 255)); 
if(enc_chr < 16) { 
enc_str += "0" + enc_chr.toString(16); 
} else enc_str += enc_chr.toString(16); 
prand = (mult * prand + incr) % modu; 
} 
salt = salt.toString(16); 
while(salt.length < 8)salt = "0" + salt; 
enc_str += salt; 
return enc_str; 
} function decrypt(str, pwd) { 
if(str == null || str.length < 8) { 
alert("A salt value could not be extracted from the encrypted message because it's length is too short. The message cannot be decrypted."); 
return; 
} 
if(pwd == null || pwd.length <= 0) { 
alert("Please enter a password with which to decrypt the message."); 
return; 
} 
var prand = ""; 
for(var i=0; i<pwd.length; i++) { 
prand += pwd.charCodeAt(i).toString(); 
} 
var sPos = Math.floor(prand.length / 5); 
var mult = parseInt(prand.charAt(sPos) + prand.charAt(sPos*2) + prand.charAt(sPos*3) + prand.charAt(sPos*4) + prand.charAt(sPos*5)); 
var incr = Math.round(pwd.length / 2); 
var modu = Math.pow(2, 31) - 1; 
var salt = parseInt(str.substring(str.length - 8, str.length), 16); 
str = str.substring(0, str.length - 8); 
prand += salt; 
while(prand.length > 10) { 
prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString(); 
} 
prand = (mult * prand + incr) % modu; 
var enc_chr = ""; 
var enc_str = ""; 
for(var i=0; i<str.length; i+=2) { 
enc_chr = parseInt(parseInt(str.substring(i, i+2), 16) ^ Math.floor((prand / modu) * 255)); 
enc_str += String.fromCharCode(enc_chr); 
prand = (mult * prand + incr) % modu; 
} 
return enc_str; 
} 
// End --> 
</script> 
<form name="box"><center> 
<table cellpadding=0 cellspacing=0 border=0><tr><td colspan=3> 
<textarea cols=40 rows=5 wrap=virtual name=ipt>Welcome to baidu.com</textarea> 
</td></tr> 
<tr height=50><td valign="top"> 
<input type="button" onclick="document.box.opt.value= encrypt(document.box.ipt.value, document.box.pwd.value);" value="加密"> 
</td><td align="center" valign="center"> 
<input type="text" name="pwd" value="password"> 
</td><td align="right" valign="bottom"> 
<input type="button" onclick="document.box.ipt.value= decrypt(document.box.opt.value, document.box.pwd.value);" value="解密"> 
</td></tr> 
<tr><td colspan=3> 
<textarea cols=40 rows=5 wrap=virtual name=opt></textarea> 
</td></tr></table> 
</center> 
</form> 
</body> 
</html>

代码copy之后直接打开即可
Javascript 相关文章推荐
javascript 导出数据到Excel(处理table中的元素)
Dec 18 Javascript
jQuery 添加/移除CSS类实现代码
Feb 11 Javascript
js实现将选中值累加到文本框的方法
Aug 12 Javascript
浅析AngularJS Filter用法
Dec 28 Javascript
AngularJS模板加载用法详解
Nov 04 Javascript
Angular1.x复杂指令实例详解
Mar 01 Javascript
深入对Vue.js $watch方法的理解
Mar 20 Javascript
Angular.js去除页面中显示的空行方法示例
Mar 30 Javascript
谈谈React中的Render Props模式
Dec 06 Javascript
JS中的防抖与节流及作用详解
Apr 01 Javascript
vue实现按需加载组件及异步组件功能
May 27 Javascript
JavaScript获取某一天所在的星期
Sep 05 Javascript
JavaScript用Number方法实现string转int
May 13 #Javascript
javascript中expression的用法整理
May 13 #Javascript
JS函数重载的解决方案
May 13 #Javascript
一个JS函数搞定网页标题(title)闪动效果
May 13 #Javascript
JS获得浏览器版本和操作系统版本的例子
May 13 #Javascript
当滚动条滚动到页面底部自动加载增加内容的js代码
May 13 #Javascript
js语法学习之判断一个对象是否为数组
May 13 #Javascript
You might like
程序员编程十条戒律
2009/07/09 PHP
php调用方法mssql_fetch_row、mssql_fetch_array、mssql_fetch_assoc和mssql_fetch_objcect读取数据的区别
2012/08/08 PHP
利用中国天气预报接口实现简单天气预报
2014/01/20 PHP
php格式化日期实例分析
2014/11/12 PHP
学习php设计模式 php实现单例模式(singleton)
2015/12/07 PHP
[企业公众号]升级到[企业微信]之后发送消息失败的解决方法
2017/06/30 PHP
php curl简单采集图片生成base64编码(并附curl函数参数说明)
2019/02/15 PHP
斜45度寻路实现函数
2009/08/20 Javascript
jquery offset函数应用实例
2012/11/14 Javascript
js-FCC算法-No repeats please字符串的全排列(详解)
2017/05/02 Javascript
vue项目部署上线遇到的问题及解决方法
2018/06/10 Javascript
详解Angularjs 自定义指令中的数据绑定
2018/07/19 Javascript
vue中使用echarts制作圆环图的实例代码
2018/07/27 Javascript
mpvue中使用flyjs全局拦截的实现代码
2018/09/13 Javascript
web页面和微信小程序页面实现瀑布流效果
2018/09/26 Javascript
JavaScript中的一些实用小技巧总结
2019/04/07 Javascript
浅谈Vue中render中的h箭头函数
2019/11/07 Javascript
jquery实现进度条状态展示
2020/03/26 jQuery
[01:04:05]VG vs Newbee 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
使用python搭建Django应用程序步骤及版本冲突问题解决
2013/11/19 Python
python定时检查某个进程是否已经关闭的方法
2015/05/20 Python
python使用reportlab实现图片转换成pdf的方法
2015/05/22 Python
解决Python中字符串和数字拼接报错的方法
2016/10/23 Python
Python多线程实现同步的四种方式
2017/05/02 Python
python如何制作英文字典
2019/06/25 Python
Django model 中设置联合约束和联合索引的方法
2019/08/06 Python
Python实现微信中找回好友、群聊用户撤回的消息功能示例
2019/08/23 Python
使用遗传算法求二元函数的最小值
2020/02/11 Python
Python 实现简单的客户端认证
2020/07/29 Python
Web前端绘制0.5像素的几种方法
2017/08/11 HTML / CSS
英国文具、办公用品和科技商店:Ryman
2018/09/27 全球购物
一套中级Java程序员笔试题
2015/01/14 面试题
护士毕业自我鉴定
2014/02/07 职场文书
教师自我剖析材料
2014/09/29 职场文书
2015年社区中秋节活动总结
2015/03/23 职场文书
html css3不拉伸图片显示效果
2021/06/07 HTML / CSS