- 資訊首頁(yè) > 開(kāi)發(fā)技術(shù) > web開(kāi)發(fā) > JavaScript >
- 利用Node.js創(chuàng )建一個(gè)密碼生成器的全步驟
1.1 創(chuàng )建項目
$ npm init
1.2 安裝依賴(lài)
$ npm i commander chalk clipboardy
1.3 創(chuàng )建入口文件index.js
舉個(gè)🌰:來(lái)了解process.argv
// index.js console.log(process.argv)
終端執行命令
$ node index
在終端可以看到
process.argv 屬性返回數組,其中包含啟動(dòng) Node.js 進(jìn)程時(shí)傳入的命令行參數。 第一個(gè)元素將是 process.execPath。 第二個(gè)元素將是正在執行的 JavaScript 文件的路徑。 其余元素將是任何其他命令行參數.
執行命令
$ node index generate
第三個(gè)參數:generate
// index.js const program = require('commander'); program.version('1.0.0').description('Simple password generator').parse()
終端執行命令:可以看到passgen的描述
繼續執行命令:可以看到passgen的版本
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的密碼長(cháng)度命令
終端執行命令:
program.option('-l --length <number>', 'length of password', '8').parse() console.log(program.opts())
終端執行命: 不設置密碼長(cháng)度,可以看到使用的是默認值-8
終端執行命令: 設置密碼長(cháng)度為10
program.option('-l --length <number>', 'length of password', '8') .option('-s --save', 'save password to password.txt').parse()
.option('-nn --no-number', 'remove numbers').parse()
終端執行命: 默認情況下有數字
終端執行命: 設置清除數字密碼
.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)
創(chuàng )建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
終端執行命令:查看密碼生成情況
// index.js const chalk = require('chalk'); log(chalk.blue('Generated Password: ') + chalk.bold(generatedPassword))
終端執行命令:可以看到顏色有變化
// 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)
創(chuàng )建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文件,并且密碼已經(jīng)保存成功
// package.json "preferGlobal": true, "bin":"./index.js",
終端執行命令:
npm link命令:將npm 模塊鏈接到對應的運行項目中去,方便對本地模塊進(jìn)行調試和測試
//index.js #!/usr/bin/env node //首行添加
終端執行命令:
總結:大功告成✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️✌️
參考鏈接:…
到此這篇關(guān)于利用Node.js創(chuàng )建一個(gè)密碼生成器的文章就介紹到這了,更多相關(guān)Node.js密碼生成器內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng )、來(lái)自本網(wǎng)站內容采集于網(wǎng)絡(luò )互聯(lián)網(wǎng)轉載等其它媒體和分享為主,內容觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如侵犯了原作者的版權,請告知一經(jīng)查實(shí),將立刻刪除涉嫌侵權內容,聯(lián)系我們QQ:712375056,同時(shí)歡迎投稿傳遞力量。
Copyright ? 2009-2022 56dr.com. All Rights Reserved. 特網(wǎng)科技 特網(wǎng)云 版權所有 特網(wǎng)科技 粵ICP備16109289號
域名注冊服務(wù)機構:阿里云計算有限公司(萬(wàn)網(wǎng)) 域名服務(wù)機構:煙臺帝思普網(wǎng)絡(luò )科技有限公司(DNSPod) CDN服務(wù):阿里云計算有限公司 百度云 中國互聯(lián)網(wǎng)舉報中心 增值電信業(yè)務(wù)經(jīng)營(yíng)許可證B2
建議您使用Chrome、Firefox、Edge、IE10及以上版本和360等主流瀏覽器瀏覽本網(wǎng)站