今天在做一个老项目时,遇到一个需求,在javascript将url中的参数加密解密,从网上找发现了这段有用的代码:

  1. <SCRIPT LANGUAGE="JavaScript">
  2. <!-- Begin
  3. function Encrypt(str, pwd) {
  4. if(str=="")return "";
  5. str = escape(str);
  6. if(!pwd || pwd==""){ var pwd="1234"; }
  7. pwd = escape(pwd);
  8. if(pwd == null || pwd.length <= 0) {
  9. alert("Please enter a password with which to encrypt the message.");
  10. return null;
  11. }
  12. var prand = "";
  13. for(var I=0; I<pwd.length; I++) {
  14. prand += pwd.charCodeAt(I).toString();
  15. }
  16. var sPos = Math.floor(prand.length / 5);
  17. var mult = parseInt(prand.charAt(sPos) + prand.charAt(sPos*2) + prand.charAt(sPos*3) + prand.charAt(sPos*4) + prand.charAt(sPos*5));
  18. var incr = Math.ceil(pwd.length / 2);
  19. var modu = Math.pow(2, 31) - 1;
  20. if(mult < 2) {
  21. alert("Algorithm cannot find a suitable hash. Please choose a different password. /nPossible considerations are to choose a more complex or longer password.");
  22. return null;
  23. }
  24. var salt = Math.round(Math.random() * 1000000000) % 100000000;
  25. prand += salt;
  26. while(prand.length > 10) {
  27. prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString();
  28. }
  29. prand = (mult * prand + incr) % modu;
  30. var enc_chr = "";
  31. var enc_str = "";
  32. for(var I=0; I<str.length; I++) {
  33. enc_chr = parseInt(str.charCodeAt(I) ^ Math.floor((prand / modu) * 255));
  34. if(enc_chr < 16) {
  35. enc_str += "0" + enc_chr.toString(16);
  36. }else
  37. enc_str += enc_chr.toString(16);
  38. prand = (mult * prand + incr) % modu;
  39. }
  40. salt = salt.toString(16);
  41. while(salt.length < 8)salt = "0" + salt;
  42. enc_str += salt;
  43. return enc_str;
  44. }
  45. function Decrypt(str, pwd) {
  46. if(str=="")return "";
  47. if(!pwd || pwd==""){ var pwd="1234"; }
  48. pwd = escape(pwd);
  49. if(str == null || str.length < 8) {
  50. alert("A salt value could not be extracted from the encrypted message because it's length is too short. The message cannot be decrypted.");
  51. return;
  52. }
  53. if(pwd == null || pwd.length <= 0) {
  54. alert("Please enter a password with which to decrypt the message.");
  55. return;
  56. }
  57. var prand = "";
  58. for(var I=0; I<pwd.length; I++) {
  59. prand += pwd.charCodeAt(I).toString();
  60. }
  61. var sPos = Math.floor(prand.length / 5);
  62. var mult = parseInt(prand.charAt(sPos) + prand.charAt(sPos*2) + prand.charAt(sPos*3) + prand.charAt(sPos*4) + prand.charAt(sPos*5));
  63. var incr = Math.round(pwd.length / 2);
  64. var modu = Math.pow(2, 31) - 1;
  65. var salt = parseInt(str.substring(str.length - 8, str.length), 16);
  66. str = str.substring(0, str.length - 8);
  67. prand += salt;
  68. while(prand.length > 10) {
  69. prand = (parseInt(prand.substring(0, 10)) + parseInt(prand.substring(10, prand.length))).toString();
  70. }
  71. prand = (mult * prand + incr) % modu;
  72. var enc_chr = "";
  73. var enc_str = "";
  74. for(var I=0; I<str.length; I+=2) {
  75. enc_chr = parseInt(parseInt(str.substring(I, I+2), 16) ^ Math.floor((prand / modu) * 255));
  76. enc_str += String.fromCharCode(enc_chr);
  77. prand = (mult * prand + incr) % modu;
  78. }
  79. return unescape(enc_str);
  80. }
  81. //  End -->
  82. </script>

以后碰到加密解密问题,直接将上述代码写成一个js文件,就搞定。省事了。。。。

一段有用的javascript加密解密的更多相关文章

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

    原文地址:http://wenku.baidu.com/view/9048edee9e31433239689357.html 本文一共介绍了七种javascript加密方法: 在做网页时(其实是网页木 ...

  2. JavaScript加密解密7种方法

    注:本文纯转贴,供学习使用 本文一共介绍了七种javascript加密方法: 在做网页时(其实是网页木马呵呵),最让人烦恼的是自己辛辛苦苦写出来的客户端IE运行的javascript代码常常被别人轻易 ...

  3. 通用RSA加密 - PHP+Java+Javascript加密解密

    php端生成 公钥私钥 1.openssl genrsa -out rsa_private_key.pem 1024    私钥 2.openssl rsa -in rsa_private_key.p ...

  4. 30段有用的javascript代码

    1. 如何区分IE及非IE浏览器 if(!+[1,]){ console.log("这是IE浏览器"): } else{ console.log("这不是IE浏览器&qu ...

  5. JavaScript加密解密压缩工具

    <script> a=62; function encode() { var code = document.getElementById('code').value; code = co ...

  6. 兼容javascript和C#的RSA加密解密算法,对web提交的数据进行加密传输

    Web应用中往往涉及到敏感的数据,由于HTTP协议以明文的形式与服务器进行交互,因此可以通过截获请求的数据包进行分析来盗取有用的信息.虽然https可以对传输的数据进行加密,但是必须要申请证书(一般都 ...

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

    一:最简单的加密解密 对于JAVASCRIPT函数escape()和unescape()想必是比较了解啦(很多网页加密在用它们),分别是编码和解码字符串,比如例子代码 用escape()函数加密后变为 ...

  8. C#, Java, PHP, Python和Javascript几种语言的AES加密解密实现[转载]

    原文:http://outofmemory.cn/code-snippet/35524/AES-with-javascript-java-csharp-python-or-php c#里面的AES加密 ...

  9. Javascript实现base64的加密解密【转】

    场景 这几天使用PHP向前端传值的时候,遇到一个问题,要将代码传过去赋值.如果使用urlencode()和urldecode()函数,就会出现js无法解码的情况,因为php和js的相关函数算法不一致. ...

随机推荐

  1. Unix环境高级编程(二)文件和目录

    本章主要介绍的是文件结构及目录.重点是通过stat函数获取文件的结构信息,然后是文件目录及其遍历.学完本章后,编写了一个输出给的目录下的文件信息的程序. 首先是包含在<sys/stat.h> ...

  2. 计算机科学基础知识(一)The Memory Hierarchy

    一.前言 最近一个问题经常萦绕在我的脑海:一个学习电子工程的机械师如何称为优秀的程序员?(注:本文作者本科学习机械设计,研究生转到电子工程系学习,毕业后却选择了系统程序员这样的职业).经过思考,我认为 ...

  3. Unity3D中组件事件函数的运行顺序

    事件函数的运行顺序 Unity 脚本中有很多按预设顺序以脚本身份执行的事件函数. 其执行顺序例如以下: 载入第一个场景 启动场景时调用这些函数(为场景中的每一个对象调用一次). Awake: 始终在调 ...

  4. SQL Server 异常处理机制(Begin try Begin Catch) 摘录

    begin try --SQL end try begin catch --sql (处理出错动作) end catch 我们将可能会出错的sql 写在begin try...end try 之间,若 ...

  5. C语言 函数参数不确定时 需要用到va_start和va_end函数

    1.在C中,当我们无法列出传递函数的所有实参的类型和数目时,可以用省略号指定参数表 void foo(...);void foo(parm_list,...); 这种方式和我们以前认识的不大一样,但我 ...

  6. js左侧三级菜单导航实例代码

    在左侧三级菜单导航想必大家都见到过吧,它的实现过程也并不复杂,下面有个不错的示例,感兴趣的朋友可以了解下 实例代码:   <!DOCTYPE html PUBLIC "-//W3C// ...

  7. RhinoMock异常ExpectationViolationException以及解决

    ExpectationViolationException 异常的原因是没有按照mock的顺序调用方法. mock b mock a //expectation call a call b call ...

  8. ny737 石子合并(一) 总结合并石子问题

    描述: 在一个圆形操场的四周摆放着n 堆石子.现要将石子有次序地合并成一堆. 规定每次只能选相邻的2 堆石子合并成新的一堆,并将新的一堆石子数记为该次合并的得分. 试设计一个算法,计算出将n堆石子合并 ...

  9. Oracle PLSQL Demo - 18.02.管道function[查询零散的字段组成list管道返回] [字段必须对上]

    --PACKAGE CREATE OR REPLACE PACKAGE test_141215 is TYPE type_ref IS record( ENAME ), SAL )); TYPE t_ ...

  10. Zuul:构建高可用网关之多维度限流

    对请求的目标URL进行限流(例如:某个URL每分钟只允许调用多少次) 对客户端的访问IP进行限流(例如:某个IP每分钟只允许请求多少次) 对某些特定用户或者用户组进行限流(例如:非VIP用户限制每分钟 ...