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 相关文章推荐
十分钟打造AutoComplete自动完成效果代码
Dec 26 Javascript
javascript语言结构小记(一)
Sep 10 Javascript
js中单引号与双引号冲突问题解决方法
Oct 04 Javascript
由简入繁实现Jquery树状结构的方法(推荐)
Jun 10 Javascript
JS+HTML5实现的前端购物车功能插件实例【附demo源码下载】
Oct 17 Javascript
JavaScript中访问id对象 属性的方式访问属性(实例代码)
Oct 28 Javascript
vue.js之vue-cli脚手架的搭建详解
May 05 Javascript
JavaScript编写棋盘覆盖代码详解
Aug 28 Javascript
JavaScript实现打印星型金字塔功能实例分析
Sep 27 Javascript
详解webpack 热更新优化
Sep 13 Javascript
JavaScript实现表单注册、表单验证、运算符功能
Oct 15 Javascript
angular8.5集成TinyMce5的使用和详细配置(推荐)
Nov 16 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
PHP面向对象分析设计的61条军规小结
2010/07/17 PHP
php调用dll的实例操作动画与代码分享
2012/08/14 PHP
PHP连接数据库实现注册页面的增删改查操作
2016/03/27 PHP
thinkphp在php7环境下提示Cannot use ‘String’ as class name as it is reserved的解决方法
2016/09/30 PHP
php中加密解密DES类的简单使用方法示例
2020/03/26 PHP
jQuery 点击图片跳转上一张或下一张功能的实现代码
2010/03/12 Javascript
js给dropdownlist添加选项的小例子
2013/03/04 Javascript
JS.elementGetStyle(element, style)应用示例
2013/09/24 Javascript
ie8下修改input的type属性报错的解决方法
2014/09/16 Javascript
get(0).tagName获得作用标签示例代码
2014/10/08 Javascript
angular.element方法汇总
2015/01/07 Javascript
JS实现新浪微博效果带遮罩层的弹出框代码
2015/10/12 Javascript
纯js模仿windows系统日历
2017/02/04 Javascript
详解微信小程序Radio选中样式切换
2017/07/06 Javascript
详解Vue路由History mode模式中页面无法渲染的原因及解决
2017/09/28 Javascript
js实时监控文本框输入字数的实例代码
2018/01/18 Javascript
vue.js+element-ui动态配置菜单的实例
2018/09/07 Javascript
快速了解Node中的Stream流是什么
2019/02/13 Javascript
简单介绍Python中的try和finally和with方法
2015/05/05 Python
详解Python中的序列化与反序列化的使用
2015/06/30 Python
python运行时间的几种方法
2016/06/17 Python
Python3.6中Twisted模块安装的问题与解决
2019/04/15 Python
django框架面向对象ORM模型继承用法实例分析
2019/07/29 Python
Python之——生成动态路由轨迹图的实例
2019/11/22 Python
python操作docx写入内容,并控制文本的字体颜色
2020/02/13 Python
python 操作mysql数据中fetchone()和fetchall()方式
2020/05/15 Python
阿联酋最好的手机、电子产品和家用电器网上商店:Eros Digital Home
2020/08/09 全球购物
某公司面试题
2012/03/05 面试题
Unix/Linux开发面试题
2016/08/16 面试题
金融专业个人的自我评价
2013/10/18 职场文书
30岁生日感言
2014/01/25 职场文书
《雨点》教学反思
2014/02/12 职场文书
建筑管理专业求职信
2014/07/28 职场文书
2014国庆黄金周超市促销活动方案
2014/09/21 职场文书
2015小学教师年度考核工作总结
2015/05/12 职场文书
《雀魂PONG☆》4月1日播出 PV角色设定情报
2022/03/20 日漫