很久沒寫博客了,因為最近在用react+express做一個自己的工具型網站(其實就是奪寶島搶拍器) 然後因為經常要改動,而且又要放到伺服器上進行測試。總是要webpack,然後手動把文件上傳上去,不勝其煩,索性搜索了下,直接寫個能檢測文件變化並自動進行上傳的腳本好了。 首先,我們使用npm 安裝兩 ...
很久沒寫博客了,因為最近在用react+express做一個自己的工具型網站(其實就是奪寶島搶拍器)
然後因為經常要改動,而且又要放到伺服器上進行測試。總是要webpack,然後手動把文件上傳上去,不勝其煩,索性搜索了下,直接寫個能檢測文件變化並自動進行上傳的腳本好了。
首先,我們使用npm 安裝兩個別人封裝好的模塊。
npm install ssh2-sftp-client
npm install gaze
第一個模塊的作用是sftp上傳文件,
第二個模塊的作用就是監聽文件變化了。當然,你也可以採用node自帶fs模塊。
這兩個模塊的用法在這裡:ssh2-sftp-client gaze
安裝好了以後,第一步就是監聽文件的變化了,由於我的文件已經使用webpack構建好了,所以後面只是文件變化,不會有文件增加,所以這裡只需要使用changed就可以了,其他的用法請參考上面的鏈接,都大同小異
gaze(['你的文件路徑/*.*','還可以使用數組的方式監聽多個文件夾/app.js'], function(err, watcher) { let watched = this.watched(); //監聽文件的變化 this.on('changed', (filepath) => { //romotePath是我文件的遠程位置 let romotePath = '/root' + filepath.substr(15); //put為上傳文件的函數,下麵會講 put(filepath,romotePath); console.log(filepath + ' was changed'); }); });
然後就開始寫我們的上傳文件的函數
function put(localPath,romotePath){ let sftp = new Client(); sftp.connect({ host: '你的伺服器地址', port: '埠,沒改過的話是22', username: '連接的用戶名', password: '密碼' }).then(() => { return sftp.put(localPath,romotePath); }).then(() =>{ console.log("上傳完成"); }).catch((err) => { console.log(err, 'catch error'); }); }
上面的代碼其實可以把connect部分提取出來作為一個全局變數的。這樣就不用每次都connect一下了。
好了,別忘了在我們的文件開始的地方可是要引入模塊的。
let Client = require('ssh2-sftp-client');
let gaze = require('gaze');
接下來我們來實驗一下。來到我們的文件夾webpack一下
果然可以看到已經修改並且上傳完成了。上傳需要時間,請耐心等待。
來到我們的伺服器,果然最近的修改時間已經變成現在了。
從此以後我終於不用一個個上傳了。每次要修改直接。打開一個視窗開啟這個腳本,就可以愉快的編碼了。