Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

captcha-ge

Package Overview
Dependencies
Maintainers
1
Versions
9
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

captcha-ge

  • 1.0.9
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

Captcha-Generator

Captcha-Generator

captcha-ge is a Node.js library for generating CAPTCHA (Completely Automated Public Turing test to tell Computers and Humans Apart) images. It provides both a JavaScript API and a Command-Line Interface (CLI) for easy integration into web applications.

Image 1
Image 2
Image 3
Image 4
Image 5
Image 6
Image 7
Image 8
Image 9
Image 10
Image 11
Image 12

Installation

To use captcha-ge in your Node.js project, follow these steps:

  1. Install Node.js:

    • Make sure Node.js is installed on your machine. You can download it from nodejs.org.
  2. Install Captcha-Generator:

    • Install Captcha-Generator using npm:
      npm install captcha-ge
      #or
      npm install -g captcha-ge
      

Usage

Using CaptchaGenerator Class (JavaScript API):

You can use the CaptchaGenerator class to programmatically create CAPTCHA images in your JavaScript code:

import CaptchaGenerator from 'captcha-ge';

// Create an instance of CaptchaGenerator with options
const captchaGenerator = new CaptchaGenerator({
  characters: 'ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789',
});

// Generate CAPTCHA image and save it to a file
captchaGenerator.generateImageCaptcha().then((imageBuffer) => {
  // Save the image to a file (e.g., captcha.png)
  fs.writeFileSync('captcha.png', imageBuffer);
  console.log('CAPTCHA image created successfully.');
}).catch((error) => {
  console.error('Error creating CAPTCHA:', error);
});

Retrieving Text with getText():

The CaptchaGenerator class also provides a method getText() to retrieve formatted text from the generated CAPTCHA:

// Generate CAPTCHA text
const captchaText = captchaGenerator.getText();

console.log('Original Text:', captchaText.original);
console.log('Reversed Text:', captchaText.reversed);
console.log('Original UpperCase Text:', captchaText.originalUpperCase);
console.log('Original LowerCase Text:', captchaText.originalLowerCase);
console.log('Reversed UpperCase Text:', captchaText.reversedUpperCase);
console.log('Reversed LowerCase Text:', captchaText.reversedLowerCase);
console.log('Text Length:', captchaText.length);

// ==== OUTPUT ====
// Original Text: OU57A4
// Reversed Text: 4A75UO
// Original UpperCase Text: OU57A4
// Original LowerCase Text: ou57a4
// Reversed UpperCase Text: 4A75UO
// Reversed LowerCase Text: 4a75uo
// Text Length: 6

cli


npm install -g captcha-ge

captcha-ge ./path/to/save/captcha.png

# OUTPUT
# CAPTCHA created successfully: C:\Users\hp\captcha.png
# CAPTCHA text:  {
#   length: 6,
#   original: 'HSQZQB',
#   reversed: 'BQZQSH',
#   originalUpperCase: 'HSQZQB',
#   originalLowerCase: 'hsqzqb',
#   reversedUpperCase: 'BQZQSH',
#   reversedLowerCase: 'bqzqsh'
# }

Customization

You can customize the CAPTCHA generation by providing options to the CaptchaGenerator constructor, such as characters

Examples

Integration with Express:

Here's an example of how to integrate Captcha-Generator with Express for generating CAPTCHA images on an HTTP endpoint:

import express from 'express';
import CaptchaGenerator from 'captcha-ge';

const app = express();

// Middleware to generate and serve CAPTCHA image
app.get('/captcha', (req, res) => {
  const captchaGenerator = new CaptchaGenerator();
  captchaGenerator.generateImageCaptcha().then((imageBuffer) => {
    res.set({ 'Content-Type': 'image/png' });
    res.send(imageBuffer);
  }).catch((error) => {
    console.error('Error generating CAPTCHA:', error);
    res.status(500).send('Error generating CAPTCHA');
  });
});

app.listen(3000, () => {
  console.log('Server is running on http://localhost:3000');
});
Integration with Telegram Bot:

You can integrate Captcha-Generator with a Telegram bot to send CAPTCHA images in a chat:

import TelegramBot from 'node-telegram-bot-api';
import CaptchaGenerator from 'captcha-ge';

const botToken = 'YOUR_TELEGRAM_BOT_TOKEN';
const bot = new TelegramBot(botToken, { polling: true });

bot.onText(/\/captcha/, async (msg) => {
  const chatId = msg.chat.id;
  const captchaGenerator = new CaptchaGenerator();
  const imageBuffer = await captchaGenerator.generateImageCaptcha();

  bot.sendPhoto(chatId, imageBuffer, { caption: 'Please solve this CAPTCHA:' })
    .catch((error) => {
      console.error('Error sending CAPTCHA:', error);
      bot.sendMessage(chatId, 'Failed to send CAPTCHA. Please try again later.');
    });
});

Dependencies

Captcha-Generator relies on the canvas library for image generation. Make sure to install all dependencies (node-canvas and its dependencies) for your environment.

Keywords

FAQs

Package last updated on 20 May 2024

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc