赞
踩
此小工具是我突发奇想想的一个密码加密算法, 通过对一个小数的幂指数的不断迭代运算, 可以取得完全打乱字符排列的效果, 用户只要略微更改这密码初值,密码模板,计算指数中的任何一个, 所运算的结果都千差万别,毫无规律。
该小工具完全采用原生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"> 清空</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"> 清空</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"> 清空</a>
- </div>
- <div class="row btn-row">
- <input type="button" id="createBtn" class="btn" value="生成密码" />
- </div>
- <div class="readme">
- <p>下载地址: <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.length
- let precision = 12
- for (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 % len
- let 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.createPow
-
- let 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.length
- let seedLen = seedArr.length
- let precision = 12
- let charWeightSum = pwdTplLen
- for (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.value
- if (!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 * 1
- let 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.item
- inputEl.value = item
- inputListEl.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 = dataList
- if (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') {
- //如果过期直接返回null
- let 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: 简单的密码生成器
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。