用node作web開發不少均可能碰到須要驗證碼的地方,以前在github上搜索,有一些好比node-captcha等的類庫,都須要依賴第三方的圖形處理庫或者軟件,像我以前安裝cario這個圖形庫時,真是費了好大一番勁,可是其實咱們只用到了這些圖形庫的一點點小功能,好比圖片的尺寸修改裁剪,或者生產驗證碼。node
先介紹一下CImg這個c++的圖形庫吧,CImg是一個跨平臺的C++的圖像處理庫,提供了加載、處理、顯示、保存等一系列功能,最吸引人的地方是整個圖形庫就一個CImg.h這個文件,因此很是的便攜綠色環保,帶到哪裏均可以進行編譯使用,不用安裝一大推依賴。因而我就想利用這個CImg圖形庫作一個簡單的demo,就從實現驗證碼這個功能入手,固然能夠徹底利用這個庫來作裁剪圖片等其餘功能。linux
ccap模塊是基於CImg圖形庫的封裝,讓它能夠供node使用,因爲CImg圖形庫的便攜性,因此ccap模塊能夠徹底不依賴其餘任何第三方圖形庫或者軟件而獨立工做,也就說若是隻是想要生成簡單的驗證碼,只要require這個ccap模塊便可。c++
一、安裝:
通用方法:npm install ccap
或者經過github下載,地址:https://github.com/DoubleSpout/ccap
注:安裝過程可能會出現錯誤,請根據錯誤提示安裝相應依賴包git
二、性能:
在2cpu的linux 64位服務器上生成驗證碼速度能夠達到1200次/秒,測試生成的圖片是BMP的,jpeg的圖片驗證碼生成速度大約在600次/秒github
三、聲明方法:web
var ccap = require('ccap'); var captcha1 = ccap(); var captcha2 = ccap(width, height, offset); var captcha3 = ccap({ width:256,//set width,default is 256
能夠經過上述代碼實例化一個ccap類。 一、不傳任何參數,所有使用默認的參數進行生成驗證碼 二、只傳遞寬,高,偏移進行實例化,調整圖片的大小,和圖片中文字的間隔 三、傳遞一個對象,除了寬,高和偏移,還傳遞了圖片質量以及生成隨機數的方法,ccap模塊會根據自定義函數return的字符串做爲圖片驗證碼的內容,默認是0-9,A-Z的6位隨即字符串。npm
理論上能夠生產不少不一樣的ccap的實例,並且他們之間互相沒有影響,因此即便是經過cluster開啓多進程的node同時生產驗證碼也不存在互相鎖止的影響。數組
對於圖片質量只對jpeg圖片有效,若是沒有安裝任何jpeg的lib庫的話,只能使用bmp未壓縮圖形了,體積比較大,可是生成速度比較快。服務器
四、使用方法,get():app
height:60,//set height,default is 60 offset:40,//set text spacing,default is 40 quality:100,//set pic quality,default is 50 generate:function(){//Custom the function to generate captcha text //generate captcha text here return text;//return the captcha text } });
實例化ccap類以後,會獲得captcha對象,這個對象只有一個對外方法,get(),這個方法每次調用都會返回驗證碼buffer和對應的text字符串內容,保存在數組裏,相似這樣的結構:
["captcha text","picture buffer"]
五、一個簡單的web例子:
var http = require('http'); var ccap = require('ccap')();//Instantiated ccap class http.createServer(function (request, response) { if(request.url == '/favicon.ico')return response.end('');//Intercept request favicon.ico var ary = ccap.get(); var txt = ary[0]; var buf = ary[1]; response.end(buf); console.log(txt); }).listen(8124); console.log('Server running at http://127.0.0.1:8124/');
注:有些代碼參數可根據本身的環境自行修改