此小工具是我突发奇想想的一个密码加密算法, 通过对一个小数的幂指数的不断迭代运算, 可以取得完全打乱字符排列的效果, 用户只要略微更改这密码初值,密码模板,计算指数中的任何一个, 所运算的结果都千差万别,毫无规律。

该小工具完全采用原生js编写,方便用户更改代码, 没有应用任何外部资源, 完全可以断网使用。

<!DOCTYPE html>
<html><head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0,maximum-scale=1.0, user-scalable=no" /><title>简单密码生成器</title><style type="text/css">html,body {padding: 0;margin: 0;}.password-create {margin: 5px auto;border: 1px solid gray;box-shadow: rgba(0, 0, 0, .5) 2px 3px 10px;border-radius: 0;width: calc(100% - 10px);box-sizing: border-box;overflow-x: hidden;padding: 10px;min-width: 340px;max-width: 500px;}.password-create-title {color: black;font-size: 18px;font-weight: bold;padding: 5px;margin-bottom: 5px;}.row {width: 100%;height: 55px;margin-bottom: 0;display: flex;justify-content: flex-start;align-items: center;}.input_label {height: 32px;display: flex;justify-content: flex-end;align-items: center;text-align: right;width: 80px;font-size: 16px;}.input-text {height: 32px;display: flex;justify-content: flex-start;align-items: center;padding-left: 5px;margin-left: 5px;width: calc(100% - 160px);font-size: 16px;}.btn {width: 120px;height: 40px;display: inline-flex;justify-content: center;align-items: center;color: white;background: rgb(54, 211, 153);font-size: 16px;cursor: pointer;border: 0px solid rgb(54, 211, 153);outline: none;}.btn:active {opacity: 0.8;}.input-checkbox {width: 20px;height: 20px;}a {text-decoration: none;}.hint-span {color: red;}.msg {color: red;font-size: 20px;font-weight: bold;padding-left: 20px;box-sizing: border-box;}.btn-row {justify-content: flex-end;text-align: right;padding-right: 2%;box-sizing: border-box;margin-top: 10px;}.readme p {margin: 5px 0;padding: 0;font-size: 18px;font-weight: bold;color: #333;}.readme ul {list-style-type: none;padding: 0;margin: 0;}.readme li {padding: 5px;margin: 0;font-size: 16px;color: #666;line-height: 26px;}.readme .demo-img {width: 100%;}.input-select {position: relative;margin-left: 5px;width: calc(100% - 160px);font-size: 16px;box-sizing: border-box;}.input-select input {height: 36px;display: flex;justify-content: flex-start;align-items: center;width: 100%;font-size: 16px;padding-left: 10px;box-sizing: border-box;}.input-select input:focus+.select-wrap {display: block;}.input-select:focus .select-wrap {display: block;}.input-select .select-wrap {display: none;box-sizing: border-box;position: absolute;width: 100%;z-index: 1;top: 100%;left: 0;padding: 5px;background-color: white;box-shadow: rgba(0, 0, 0, .5) 2px 3px 10px;}.input-select .select-wrap .select-option {height: 32px;display: flex;justify-content: flex-start;align-items: center;font-size: 16px;color: #333;padding: 5px 10px;cursor: pointer;user-select: none;border-bottom: 1px dashed #eee;}.input-select .select-wrap .select-option:active {opacity: 0.8;background-color: #f2f2f2;}</style>
</head><body><div class="password-create"><div class="password-create-title">密码生成器</div><div id="msg" class="row msg"></div><div class="row"><label for="seedValue" class="input_label"><span class="hint-span">*</span>密码初值:</label><div class="input-select" tabindex="0"><input type="text" id="seedValueInput" value="" placeholder="请输入密码初始值" /></div><a href="javascript:;" id="clearSeedValueBtn">&nbsp;&nbsp;清空</a></div><div class="row"><label for="pwdTpl" class="input_label"><span class="hint-span">*</span>密码模板:</label><div class="input-select" tabindex="0"><input type="text" id="pwdTplInput" value="" list="pwdTplDataList" placeholder="请输入密码生成模板" /><div class="select-wrap" id="pwdTplDataList"></div></div><a href="javascript:;" id="clearPwdTplBtn">&nbsp;&nbsp;清空</a></div><div class="row"><label for="createPowInput" class="input_label"><span class="hint-span">*</span>计算指数:</label><div class="input-select" tabindex="0"><input type="text" id="createPowInput" value="" placeholder="计算指数为小于10的8-15位小数" /><div class="select-wrap" id="createPowList"></div></div><a href="javascript:;" id="clearCreatePowBtn">&nbsp;&nbsp;清空</a></div><div class="row btn-row"><input type="button" id="createBtn" class="btn" value="生成密码" /></div><div class="readme"><p>下载地址: &nbsp;&nbsp;<a style="font-size: 16px;" href="./pwd.html"download='pwd.html'>点此下载该工具</a></p><p>使用说明: </p><ul><li>1. 密码初值: 用于生成密码的种子, 可以看做为明密, 可以为任何字符, 可以包含汉字, 长度限制30个字符</li><li>2. 密码模板: 用于生成密码的模板, 最终生成的密码格式, 包含数字, 大写字母, 小写字母和特殊字符, 长度限制30个字符</li><li>3. 计算指数: 用于密码计算的指数, 该数字为一个小于10的8-15位小数, 最好为一个无理数的计算结果取前15位</li><li>4. 把这个文件保存自己的手机或电脑上, 首次使用时一定要自己修改这个文件的模板数据, 不要用这个默认的示例</li><li><img class="demo-img"src="" /></li></ul></div></div><script type="text/javascript">"use strict";let PasswordUtil = function () {// 此处的配置一定要自行修改, 不要用这个默认的配置let pwdConfig = {numberMap: "1234567890",// 所有的数字uppercaseMap: "abcdefghijklmnopqrstuvwxyz",// 所有的小写字母lowercaseMap: "ABCDEFGHIJKLMNOPQRSTUVWXYZ",// 所有的大写字母specialCharacterMap: "~!@#$%^&*()_+-=|/\<>,.;:[]{}",// 所有的特殊字符randomPow: Math.PI + 1, // 打乱排序的计算指数, 一个杂乱无章的小数 如: 3.141592653589793, 小数位数最多为15位createPow: Math.E + 2, // 生成密码计算指数, 一个杂乱无章的小数 如: 2.718281828459045, 小数位数最多为15位}try {charMapRandom()} catch (e) {console.error(e)}function getRandomChar(s, randomIndex) {let ch = "";if (pwdConfig.numberMap.indexOf(s) > -1) {ch = "" + pwdConfig.numberMap[randomIndex % pwdConfig.numberMap.length];} else if (pwdConfig.uppercaseMap.indexOf(s) > -1) {ch = pwdConfig.uppercaseMap[randomIndex % pwdConfig.uppercaseMap.length];} else if (pwdConfig.lowercaseMap.indexOf(s) > -1) {ch = pwdConfig.lowercaseMap[randomIndex % pwdConfig.lowercaseMap.length];} else if (pwdConfig.specialCharacterMap.indexOf(s) > -1) {ch = pwdConfig.specialCharacterMap[randomIndex % pwdConfig.specialCharacterMap.length];}return ch;}function getCharWeight(s) {let weight = 1;if (pwdConfig.numberMap.indexOf(s) > -1) {weight = 2;} else if (pwdConfig.uppercaseMap.indexOf(s) > -1) {weight = 3;} else if (pwdConfig.lowercaseMap.indexOf(s) > -1) {weight = 4;} else if (pwdConfig.specialCharacterMap.indexOf(s) > -1) {weight = 5;}return weight;}// 打乱字符顺序function charMapRandom() {randowMap("numberMap")randowMap("uppercaseMap")randowMap("lowercaseMap")randowMap("specialCharacterMap")function randowMap(filedName) {let charArr = pwdConfig[filedName].split("")let len = charArr.lengthlet precision = 12for (let i = 0; i < len; i++) {let randomNum = Math.pow(i + 1, pwdConfig.randomPow).toFixed(precision)let randomNumArr = randomNum.split(".")[1].split("").reverse()let randomIndex = parseInt(randomNumArr[0] + randomNumArr[precision / 2] + randomNumArr[precision - 1])let toIndex = randomIndex % lenlet temp = charArr[toIndex]charArr[toIndex] = charArr[i]charArr[i] = temp}pwdConfig[filedName] = charArr.join("")}}// 生成密码function createPwd(seedStr, pwdTpl, createPow) {let seedArr = seedStr.split("")let pwdTplArr = pwdTpl.split("")createPow = createPow || pwdConfig.createPowlet seedCodeArr = [];seedArr.forEach(function (ch, index) {seedCodeArr.push(ch.charCodeAt());});let seedSum = 0;seedCodeArr.forEach(function (item, index) {seedSum += item * 1 + index;});let pwd = ""let pwdTplLen = pwdTplArr.lengthlet seedLen = seedArr.lengthlet precision = 12let charWeightSum = pwdTplLenfor (let i = 0; i < pwdTplLen; i++) {let type = pwdTplArr[i];charWeightSum += getCharWeight(type);let randomNum = Math.pow((seedSum + charWeightSum) / (3 * i + 1), pwdConfig.createPow).toFixed(precision);let randomNumArr = randomNum.split(".")[1].split("").reverse();let randomIndex = parseInt(randomNumArr[0] + randomNumArr[precision / 2] + randomNumArr[precision - 1]);pwd += getRandomChar(type, randomIndex);}return pwd;}return {pwdConfig,createPwd,};}();setTimeout(() => {appInit()}, 0)function appInit() {// 密码模板选项数据let allPwdTplDataOptions = ["123456","12345678","aaa123456","aa#123456","Aaa123456","Aaa#123456","Aaa#12345678"]// 计算指数选项数据let allCreatePowOptions = [3.141592653589793,2.718281828459045,1.414213562373095,1.732050807568877,2.645751311064591,]let seedValueInputEl = document.getElementById("seedValueInput")let clearSeedValueBtnEl = document.getElementById("clearSeedValueBtn")let pwdTplInputEl = document.getElementById("pwdTplInput")let clearPwdTplBtnEl = document.getElementById("clearPwdTplBtn")let createPowInputEl = document.getElementById("createPowInput")let clearCreatePowBtnEl = document.getElementById("clearCreatePowBtn")let createBtn = document.getElementById("createBtn")let pwdTplInputSelect = createSelect("pwdTplInput", "pwdTplDataList")let createPowSelect = createSelect("createPowInput", "createPowList")pwdTplInputSelect.setData(allPwdTplDataOptions, false)createPowSelect.setData(allCreatePowOptions, true)// 清空输入框clearSeedValueBtnEl.addEventListener("click", function (e) {seedValueInputEl.value = ""}, false)clearPwdTplBtnEl.addEventListener("click", function (e) {pwdTplInputEl.value = ""}, false)clearCreatePowBtnEl.addEventListener("click", function (e) {createPowInputEl.value = ""}, false)// 点击生成密码createBtn.addEventListener("click", function (e) {let seedValue = seedValueInputEl.value.trim()let pwdTpl = pwdTplInputEl.value.trim()let createPow = createPowInputEl.valueif (!seedValue) {printMsg("请输入密码初始值")return false;}if (!pwdTpl) {printMsg("请输入密码生成模板")return false;}if (!checkInputValue(pwdTpl)) {printMsg("密码生成模板不能包含非法字符")return false;}if (seedValue.length > 30) {printMsg("密码初始值不能超过30个字符!")return false;}if (pwdTpl.length > 30) {printMsg("密码模板不能超过30个字符!")return false;}if (!myUtil.isNumeric(createPow)) {printMsg("请输入计算指数!")return false;}let createPowDotIndex = createPow.indexOf(".")if (createPowDotIndex == -1 || createPow * 1 > 10) {printMsg("计算指数必须为小于10的小数!")return false;}let createPowDecimal = createPow.substring(createPowDotIndex + 1)if (createPowDecimal.length > 15 || createPowDecimal.length < 8) {printMsg("计算指数小数位数必须为8-15位!")return false;}PasswordUtil.pwdConfig.createPow = createPow * 1let pwdStr = PasswordUtil.createPwd(seedValue, pwdTpl)printMsg(`<span style="color:#36d49a">${pwdStr}</span>`)}, false)function printMsg(htmlMsg) {let msgEl = document.getElementById("msg")if (msgEl) {msgEl.innerHTML = htmlMsg}}function checkInputValue(value) {let valueArr = value.split("")let allStr = PasswordUtil.pwdConfig.numberMap + PasswordUtil.pwdConfig.uppercaseMap +PasswordUtil.pwdConfig.lowercaseMap + PasswordUtil.pwdConfig.specialCharacterMap;for (let i = 0; i < valueArr.length; i++) {if (allStr.indexOf(valueArr[i]) == -1) {return false}}return true}function refreshDataList(id, dataList) {let html = "";dataList.forEach(function (val) {html += '<option value="' + val + '" />';});let dataListEl = document.getElementById(id);if (dataListEl) {dataListEl.innerHTML = html;}}function createSelect(inputId, inputListId) {let inputEl = document.getElementById(inputId)let inputListEl = document.getElementById(inputListId)let allDataList = []let showDataList = []inputEl.addEventListener("input", function (e) {refreshData()})inputEl.addEventListener("focus", function (e) {refreshData()})inputListEl.addEventListener("click", function (e) {if (e.target.classList.contains("select-option")) {let item = e.target.dataset.iteminputEl.value = iteminputListEl.parentNode.blur()}})function refreshData() {let inputValue = inputEl.value.trim()let showDataList = allDataList// 过滤选项// if (inputValue) {//     showDataList = allDataList.filter((item) => {//        return (item + "").indexOf(inputValue) > -1//     })// }let html = "";showDataList.forEach(function (item, index) {html += `<div data-index="${index}" data-item="${item}" class="select-option">${item}</div>`;});if (showDataList.length == 0) {html += `<div data-index="-1" data-item="" class="select-option">暂无符合条件的数据</div>`;}inputListEl.innerHTML = html;}function setData(dataList, isInit) {allDataList = dataListif (isInit && !inputEl.value && dataList.length > 0) {inputEl.value = allDataList[0]}refreshData()}return {setData}}};</script><script type="text/javascript">"use strict";window.myUtil = (function () {function isType(val) {return Object.prototype.toString.call(val).slice(8, -1);}function isObject(val) {return isType(val) === 'Object';}function isArray(val) {return isType(val) === 'Array';}function isFunction(val) {return isType(val) === 'Function';}function isNumeric(val) {return (!Number.isNaN(parseFloat(val))) && Number.isFinite(Number(val));}let sessionStorage = window.sessionStorage;let localStorage = window.localStorage;function saveDataToLocal(saveName, obj, isSessionStorage = true, expireTime) {if (obj === null) {if (isSessionStorage) {sessionStorage.removeItem(saveName)} else {localStorage.removeItem(saveName)}return;}if (obj && (isObject(obj) || isArray(obj))) {if (isSessionStorage) {sessionStorage.setItem(saveName, JSON.stringify(obj))} else {localStorage.setItem(saveName, JSON.stringify(obj))}} else {if (isSessionStorage) {sessionStorage.setItem(saveName, obj)} else {localStorage.setItem(saveName, obj)}}//存过期时间if (expireTime) {let expireTimeObjStr = JSON.stringify({time: new Date().getTime(),expireTime: expireTime});if (isSessionStorage) {sessionStorage.setItem(saveName + "ExpireTime", expireTimeObjStr)} else {localStorage.setItem(saveName + "ExpireTime", expireTimeObjStr)}}}function readDataFromLocal(readName, isSessionStorage = true) {let dataStr = null;let data = null;if (isSessionStorage) {dataStr = sessionStorage.getItem(readName);} else {dataStr = localStorage.getItem(readName);}if (dataStr && typeof dataStr == 'string') {//如果过期直接返回nulllet expireTimeObj = readDataFromLocal(readName + "ExpireTime", isSessionStorage);if (expireTimeObj) {if ((new Date().getTime() - expireTimeObj.time) >= expireTimeObj.expireTime) {saveDataToLocal(readName, null, isSessionStorage);return null;}}let first = dataStr.charAt(0);//如果是数组或对象if (first === '{' || first === '[') {data = JSON.parse(dataStr);} else {//尝试保持原始数据类型try {data = JSON.parse(dataStr);;} catch (e) {data = dataStr;}}} else {data = dataStr;}return data;}return {isType,isObject,isNumeric,saveDataToLocal,readDataFromLocal}})()</script>
</body></html>

demo地址: 简单密码生成器

github源码:  GitHub - chengxg/simple-create-password: 简单的密码生成器

  • 1. 密码初值: 用于生成密码的种子, 可以看做为明密, 可以为任何字符, 可以包含汉字, 长度限制30个字符
  • 2. 密码模板: 用于生成密码的模板, 最终生成的密码格式, 包含数字, 大写字母, 小写字母和特殊字符, 长度限制30个字符
  • 3. 计算指数: 用于密码计算的指数, 该数字为一个小于10的8-15位小数, 最好为一个无理数的计算结果取前15位

js密码生成器小工具相关推荐

  1. 分享JS压缩混淆小工具

    JS压缩混淆工具 一.功能介绍 编写了一个JS压缩混淆小工具. 选择目录文件夹,指定当前目录下需要压缩的JS文件, 合并(复选框): 勾选 表示把当面目录下的所有JS文件合并压缩混淆成一个独立的 al ...

  2. Excel文件密码破解小工具

    下载地址:http://write.blog.csdn.net/postedit 软件综述 Excel文件解密辅助小工具软件截图 Excel文件解密辅助小工具软件简介 excel密码破解工具是一款针对 ...

  3. 分享一下自己用的SQLite数据库密码操作小工具(含源码)

    SQLite(http://www.hwaci.com/sw/sqlite/download.html)的优势以及wxsqlite(http://wxcode.sourceforge.net/comp ...

  4. JS 倒计时展示小工具

    废话开篇:JS 通过操控标签的隐藏与显示来实现倒计时展示小工具 一.实现效果 1.默认展示数字 2.数字倒计时 3.数字倒计时展示虚位 4.数字倒计时不展示虚位 5.小数 6.负数 7.小数倒计时 每 ...

  5. 发条js调试工具_小工具大帮手,利用 @open-node/antman 实现 node.js 进程线上调试,无须重启...

    @open-node/antman 窥探进程内部,让 Node.js 生产环境线上调试成为可能 解决了什么问题? 日常在开发服务端代码,很多是服务类型的,比如基于http的api,或者一些任务脚本,需 ...

  6. js 创建书签小工具并实现自动表单填写

    1.最近学校布置网课视频,贼心不改,就找了一个自动刷题软件就处理好了,本来是一件完美的事情,可是作为学计算机的同学,我是不允许有什么神奇的事情发上,必须研究研究怎么实现的 2.虽然只是有了一小点了解, ...

  7. 饿了么同事拼单,单人价格计算JS 拼单小工具

    经常和同事拼单点外卖 直接写了一个计算工具方便使用 //浏览器F12 粘贴运行,自行修改变量 //每份订单的价格 let array = [17,16,18,16] //配送费 let p = 5.5 ...

  8. 记录一个使用MD5加密密码的小工具类

    2019独角兽企业重金招聘Python工程师标准>>> package com.zaizai.safty.utils; import java.security.MessageDig ...

  9. ToolsOhの密码生成器(KT:java、zxcvbn、passay)

    ❑ToolsOh!の[密码生成器]工具的功能 所在位置:ToolsOh/生活工具/密码生成器 主要技术:java.zxcvbn.passay 1.功能简介 随机生成可靠.随机且唯一的密码 2.输入.输 ...

最新文章

  1. NeHe教程Qt实现——lesson16
  2. CodeForces - 1350B Orac and Models(dp)
  3. 水晶报表-简单数据类型(Crystal 语法)
  4. VMworld 2010旧金山胜利闭幕
  5. Javascript学习笔记一 之 数据类型
  6. windows7快捷键
  7. 查python的软件_Python制作天气查询软件【python实战必学】
  8. AcWing 829. 模拟队列
  9. linux启用dcb步骤,Linux DCB体系——简短概述
  10. 【sklearn第十九讲】高斯混合模型
  11. OpenStack混合云的集成问题如何克服?
  12. Android Gradle动态打32位或者64位的包
  13. 郭天祥 10天搞定单片机 (3)数码管+中断
  14. Glide 入门到精通之四——图片缩放和调整大小
  15. Binder通信机制原理解析
  16. 小豆苗服务器维护,小豆苗问题排查方法新版ppt课件
  17. java 合并两个List并去掉重复项
  18. 如何查看SCI期刊影响因子
  19. 第十三章、IO流_File类与递归/基本流/增强流/属性集与打印流__黑马Java第57期个人学习笔记_个人笔记
  20. 零基础学Arcgis(十三)专题地图的编制

热门文章

  1. 拜登留学新政:美国读博直接拿绿卡,增加H1B签证限额!但未来留美门槛反而变高了?...
  2. pd.concat()和pd.merge()
  3. 【2D多目标跟踪】Quasi-Dense Similarity Learning for Multiple Object Tracking阅读笔记
  4. 解决 Navigating to current location (/userslist) is not allowed问题。
  5. [论文阅读笔记31]UER: An Open-Source Toolkit for Pre-training Models
  6. Python学习-通过斗鱼api获取弹幕
  7. linux生成xorg,生成xorg.conf文件
  8. window屏幕录制
  9. 发展智慧城市,需要重点解决哪三大问题?
  10. 树莓派强制更改root密码