<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>字符串加密 by 林自爽 - 2016/09/12</title>
</head>
<body>
</body>
<script>
  // 字符串加密 by 林自爽 - 2016/09/12
  var x = [
    {'desc':'管理','info':'lin'},
    ...
    {'desc':'iphone锁屏','info':'19'}
  ];

  showData('你原来的内容:',x);
  //编码
  var arr = unicodeArr(x);
  showData('你加密后的内容:',arr);
  //转码
  var str = stringArr(arr);
  showData('你解密后的内容:',str);

  // 显示数据
  function showData(desc,arr){
    var _html = '<div>'+desc+'</div>';
    for(var i in arr){
      _html += '<div>desc:'+arr[i].desc+',info:'+arr[i].info+'<div>'
    }
    document.write(_html);
  }

  // 将字符串数组转成unicode编码的数组
  function unicodeArr(arr){
    var _data = [];
    for(var i in arr){
      var desc = getUnicode(arr[i].desc);
      var info = getUnicode(arr[i].info);
      _data[i] = {
        'desc':desc,
        'info':info
      };
    }
    return _data;
  }

  // 将unicode编码的数组转成字符串数组
  function stringArr(arr){
    var _data = [];
    for(var i in arr){
      var desc = getStringForUnicode(arr[i].desc);
      var info = getStringForUnicode(arr[i].info);
      _data[i] = {
        'desc':desc,
        'info':info
      };
    }
    return _data;
  }

  //单元方法 字符串转unicode
  function getUnicode(str){
    var arr = [];
    for(var i in str){
      arr.push(encrypt(str.charCodeAt(i)));
    }
    return arr;
  }

  //单元方法 unicode转字符串
  function getStringForUnicode(arr){
    var str = '';
    for(var i in arr){
      str += String.fromCharCode(decrypt(arr[i]));
    }
    return str;
  }

  // 加密
  function encrypt(num){
    num += 10086;
    return num;
  }

  // 解密
  function decrypt(num){
    num -= 10086;
    return num;
  }
</script>
</html>

源头是这样的,我把我所有的账号密码都写在了一个文件中,本来是可以用压缩到zip中,然后设个超过20位的密码,再去md5一下,保存这个md5的字符。

但是觉得上面的方法太麻烦了,我需要一个直接在web就能执行,我只要记住几个数字的。

于是,我将账号密码扔到了一个数组中,数组上都是对象。

那怎么加密呢,首先charCodeAt()是可以将任意字符转成unicode编码的,String.fromCharCode()可以将unicode转成字符串。

charCodeAt()转的unicode是数字,既然是数字,那我任意让这个数字+-*/某一个数不就可以咯,解码的时候就反向解回来。

于是就有了以下的代码

为了避免信息泄露我已经将我的数组随便删除了一部分数据。

  

用js加密你的重要信息的更多相关文章

  1. 昆仑游戏[JS加密修改]

    昆仑游戏:http://www.kunlun.com/index.html JS加密修改 BigTools=window.BigTools;//重点 RSAKeyPair=window.RSAKeyP ...

  2. web主题公园版权信息破解:script.js加密文件

    很多人会使用web主题公园网站的免费worldpress主题,但它的主题又都被加了版权信息,故意让人找不到版权信息的修改位置. 你如果去footer.php里面删除版权信息(技术支持:web主题公园) ...

  3. js加密的密文让PHP解密(AES算法)

      JS加密代码如下     <script src="http://crypto-js.googlecode.com/svn/tags/3.0.2/build/rollups/aes ...

  4. RSA加密前端JS加密,后端asp.net解密,报异常

    RSA加密前端JS加密,后端asp.net解密,报异常 参考引用:http://www.ohdave.com/rsa/的JS加密库 前端JS加密代码: function GetChangeStr() ...

  5. RSA前台js加密,后台C#解密

    一.需求: 为了安全,项目中前台登陆用的密码需要加密传到后台,后台c#解密登陆密码. 二.解决方案 采用非对称加密算法RSA来达到目的,前台登陆页面一加载便发送一次ajax请求获取后台产生的公钥,用于 ...

  6. 【不怕坑】之 Node.js加密 C#解密

    本人也不太了解AES加密解密,为了解决Node.js加密,但是无法C#解密的问题,在网上搜了大量的相关文章. 但是多数是Node.js vs Java 或 Java vs C#的双向加密解密代码,但是 ...

  7. JS分段上传文件(File)并使用MD5.js加密文件段用来后台校验

    HTML <form method="POST" name="form1" action="/mupload/upload/" enc ...

  8. NodeJS 实现 客户端 js 加密

    NodeJS 实现 客户端 js 加密 思路: 服务端渲染业务代码js => 前后端约定加密算法 => 业务代码进行签名 => 客户端解密业务代码 => eval 执行 Nod ...

  9. AES加密解密——AES在JavaWeb项目中前台JS加密,后台Java解密的使用

    一:前言 在软件开发中,经常要对数据进行传输,数据在传输的过程中可能被拦截,被监听,所以在传输数据的时候使用数据的原始内容进行传输的话,安全隐患是非常大的.因此就要对需要传输的数据进行在客户端进行加密 ...

随机推荐

  1. lua高阶用法 OO的实现

    //Lua的类的实现,可以派生,可重写方法 local _class={} function class(super) local class_type={} class_type.ctor=fals ...

  2. c# 不同窗体之间传值和调用

    1.子窗体事件刷新父窗体界面值 子窗体定义委托和事件 //声明一个委托 public delegate void DisplayUpdateDelegate(string str); //声明事件 p ...

  3. jquery 键盘回车事件

    <input id="search" placeholder="输入要领用的资产条码" id="scanCode" type=&quo ...

  4. Swift 提示:Initialization of variable was never used consider replacing with assignment to _ or removing it

    Swift 提示:Initialization of variable was never used consider replacing with assignment to _ or removi ...

  5. LeetCode 372

    题目: Your task is to calculate a^b mod 1337 where a is a positive integer and b is an extremely large ...

  6. java -- getOutputStream() has already been called for

    原文:https://my.oschina.net/zhongwenhao/blog/209653 原因:既调用了response.getOutputStream(),又调用了response.get ...

  7. Select查询执行顺序

    链接:http://blog.jobbole.com/55086/ 很多程序员视 SQL 为洪水猛兽.SQL 是一种为数不多的声明性语言,它的运行方式完全不同于我们所熟知的命令行语言.面向对象的程序语 ...

  8. jquery placeholder

    /* * @author ambar * html5 placeholder pollfill * - 使用绝对定位内嵌层 * - 也适用于密码域 * 目标浏览器: IE 6~9, FF 3.5 */ ...

  9. Android入门(四):链接接口组件和程序代码

    编写好layout中的接口组件之后,下一步就是编写控制接口组件的程序代码.上一章,我们使用了三种接口组件,在使用者输入性别和年龄之后点击“健康建议按钮”,程序会读取用户所填入的性别和年龄,然后显示判断 ...

  10. phpunit测试学习 2 分类总结断言涉及哪些方面

    11:27 2015/12/9phpunit测试学习 2,  分类总结断言涉及哪些方面先推荐windows快速打开某处路径下的cmd,进入测试状态:可以在文件夹中,按住Shift+鼠标右键,这时候你就 ...