利用Node.js創建一個密碼生成器的全步驟
一、 準備工作
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密碼生成器內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- node.js中PC端微信小程序包解密的處理思路
- Vue-CLI3.x 自動部署項目至服務器的方法步驟
- 如何寫Node.JS版本小遊戲
- node執行cmd或shell命令使用介紹
- node.js+postman實現模擬HTTP服務器與客戶端交互