• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

利用Node.js创建一个密码生成器的全步骤

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

一、 准备工作

1.1 创建项目

$ npm init 

1.2 安装依赖

$ npm i commander chalk clipboardy

1.3 创建入口文件index.js

举个🌰:来了解process.argv

// index.js
console.log(process.argv)

终端执行命令

$ node index

在终端可以看到

process.argv 属性返回数组,其中包含启动 Node.js 进程时传入的命令行参数。 第一个元素将是 process.execPath。 第二个元素将是正在执行的 JavaScript 文件的路径。 其余元素将是任何其他命令行参数.

执行命令

$ node index generate

第三个参数:generate

二、 编写命令行

2.1 添加版本和描述

// index.js
const program = require('commander');
program.version('1.0.0').description('Simple password generator').parse()

终端执行命令:可以看到passgen的描述

继续执行命令:可以看到passgen的版本

2.2 配置密码长度命令

const program = require('commander');

program.version('1.0.0').description('Simple password generator')
program.option('-l --length <number>', 'length of password').parse()
console.log(program.opts())

终端执行命令:可以看到passgen的密码长度命令

终端执行命令:

2.2 密码长度添加默认值:8

program.option('-l --length <number>', 'length of password', '8').parse()
console.log(program.opts())

终端执行命: 不设置密码长度,可以看到使用的是默认值-8

终端执行命令: 设置密码长度为10

2.3 配置保存密码命令

program.option('-l --length <number>', 'length of password', '8')
.option('-s --save', 'save password to password.txt').parse()

2.4 配置密码格式: 没有数字

.option('-nn --no-number', 'remove numbers').parse()

终端执行命: 默认情况下有数字

终端执行命: 设置清除数字密码

2.5 配置密码格式: 没有符号

.option('-ns --no-symbols', 'remove symbols').parse()

终端执行命: 默认情况下有符号

终端执行命: 设置清除数字密码

三、 解析命令行-创建密码

// index.js
const program = require('commander');
const createPassword = require('./utils/createPassword')
const log = console.log

program.version('1.0.0').description('Simple password generator')
program
.option('-l --length <number>', 'length of password', '8')
.option('-s --save', 'save password to password.txt')
.option('-nn --no-numbers', 'remove numbers')
.option('-ns --no-symbols', 'remove symbols').parse()

const {length, save, numbers, symbols} = program.opts()

// Get generated password
const generatedPassword = createPassword(length, numbers, symbols)

// Output generated password

log(generatedPassword)

创建utils/createPassword.js

// createPassword.js
const alpha = 'qwertyuiopasdfghjklzxcvbnm'
const numbers = '0123456789'
const symbols= '!@#$%^&*_-=+'


const createPassword = (length = 8, hasNumbers = true, hasSymbols = true) => {
    let chars = alpha
    hasNumbers ? (chars += numbers): ''
    hasSymbols ? (chars += symbols): ''
    return generatePassword(length, chars)
}

const generatePassword = (length, chars) => {
    let password = ''
    for(let i = 0; i < length; i++){
        password+= chars.charAt(Math.floor(Math.random()*chars.length))
    }
    return password
}
module.exports = createPassword

终端执行命令:查看密码生成情况

3.1 添加color

// index.js
const chalk = require('chalk');
log(chalk.blue('Generated Password: ') + chalk.bold(generatedPassword))

终端执行命令:可以看到颜色有变化

3.2 添加剪贴板

// index.js
const clipboardy = require('clipboardy');
// Copy to clipboardy
clipboardy.writeSync(generatedPassword)
log(chalk.yellow('Password copied to clipboardy!'))

四、 保存密码到对应的文件

// index.js
const savePassword = require('./utils/savePassword')
// Save to file
if (save) savePassword(generatedPassword)

创建utils/savePassword.js

const fs = require('fs')
const path = require('path')
const os = require('os')
const chalk = require('chalk')

const savePassword = (password) =>{
    fs.open(path.join(__dirname, '../', 'passwords.txt'), 'a', '666', (e, id) => {
        fs.write(id, password + os.EOL, null, 'utf-8', ()=>{
            fs.close(id, ()=>{
                console.log(chalk.green('Password saved to passwords.txt'))
            })
        })
    })
}

module.exports = savePassword

终端执行命令: 可以看到项目中生成passwords.txt文件,并且密码已经保存成功

五、将本地npm模块配置成全局passgen

// package.json
  "preferGlobal": true,
  "bin":"./index.js",

终端执行命令:

npm link命令:将npm 模块链接到对应的运行项目中去,方便对本地模块进行调试和测试

//index.js
#!/usr/bin/env node //首行添加

终端执行命令:

总结:大功告成✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️

参考链接:nodejs.cn/api/process

总结

到此这篇关于利用Node.js创建一个密码生成器的文章就介绍到这了,更多相关Node.js密码生成器内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
vue+iview的菜单与页签的联动方式发布时间:2022-02-05
下一篇:
如何利用node实现静态文件缓存详解发布时间:2022-02-05
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap