This is an npm package captcha-canvas helps you to make custom captcha of all types. The package uses canvas
to create captcha imagas. See installation section to know how to install.
Install canvas before captcha-canvas installation. As canvas is the peer dependencies.
- Highly customisable you can customise every single value use to make this package.
- 95% OCR fails to read this captcha image and throw Error.
- Use class constructor method so you can generate as many frames as many you want by using same values.
- No bundled dependenceris. You need to install them to use the package.
- Support of background images is also possible.
- Captcha adapt all the external options very easily.
Here is a quick example on how to use the module. But a well written documentation is available to understand all the mothods and customisation available for your project.
const { CaptchaGenerator } = require('captcha-canvas'); //require package here
const fs = require('fs'); //require fs module for saving image in a file
const options = {height: 200, width: 600}; //options for captcha image
const captcha = new CaptchaGenerator(options); //getting captcha constructor
captcha.text; //returns text of the captcha image.
const buffer = await captcha.generate(); //returns buffer of the captcha image
fs.writeFileSync('image.png', buffer); //will create image.png file of the captcha
You can use many methods like setCaptcha and setTrace to customize there appearance and values.
I am working on a simple guide for this npm package you can check it out here.
Open an issue if you need help regarding this module or want to report any bug.
-
Star the github repo of the project. More stars motivate me to work on this project.
-
Open an issue to recommend some new features or report bug regarding this module.
-
For now, you don't have anyway to fund this project but maybe in future I update this.
We always recommend you to use the most latest version for more methods and better performance.
If you are at v1.x.y and I launched a new version 2.0.0 do not update it. Because it is major change which may (basically always) break your present code or the output is not as expected.
If you are at same major change version but a new patch/minor changed version is available install without any fear. Usually minor change comes with some new methods, and patch release comes with bug fixes/updated readme.
Thanks goes to these wonderful people (emoji key):
Shashank 📆 |
TheDeadCraftPT 🐛 |
IchiiDev 🐛 |
Ikramullah 📖 💻 |
ryanhex53 💻 |
This project follows the all-contributors specification. Contributions of any kind welcome!