FaucetPay Captcha Image Solving
Solve FaucetPay captcha challenges including slider puzzles and icon click captchas. FaucetPay uses these captcha types to protect faucet claims and user actions.
FaucetPay, a popular cryptocurrency microwallet and faucet platform, uses two types of image-based captcha challenges: Slider (drag puzzle piece to correct position) and Icons (click icons in the correct order). Our service automatically solves both types, returning precise coordinates for seamless automation.
Captcha Type
"type": "FAUCETPAY_IMAGE"
Supported Question Types
| Question Type | Description | Response Format |
|---|---|---|
slider |
Slide puzzle piece to correct position | [x_offset, 0] - Pixel offset for slider |
icons |
Click icons in specified order | [[x1,y1], [x2,y2], ...] - Click coordinates |
Pricing
| Service | Price per Solve | Average Time |
|---|---|---|
| FaucetPay Slider | $0.0015 | ~3 seconds |
| FaucetPay Icons | $0.0015 | ~5 seconds |
Slider Captcha Request
Request Parameters
| Parameter | Type | Required | Description |
|---|---|---|---|
captcha.type |
string | required | Must be "FAUCETPAY_IMAGE" |
captcha.payload.questionType |
string | required | Must be "slider" |
captcha.payload.images |
array | required | Array of 2 base64 images: [background, piece] |
Slider Request Example
const response = await fetch('https://solver-api.mydisct.com/createTask', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'apikey': 'YOUR_API_KEY'
},
body: JSON.stringify({
auth: {
token: 'YOUR_API_KEY',
appId: 0
},
context: {
source: 'api',
version: '1.0.0'
},
captcha: {
type: 'FAUCETPAY_IMAGE',
metadata: {
siteUrl: 'https://faucetpay.io'
},
payload: {
questionType: 'slider',
images: [
'...', // Background image
'...' // Slider piece
]
}
}
})
});
const data = await response.json();
console.log(data);
Slider Response (Completed)
{
"success": true,
"service": "MyDisct Solver",
"message": "Captcha solved successfully",
"task": {
"id": "MyDisctSolver_1234567890",
"status": "completed",
"result": {
"answers": [142, 0],
"timestamp": "2025-01-01T12:00:00.000Z"
}
}
}
The answers array contains [x_offset, 0] where:
• 142 - Number of pixels to move the slider horizontally
• 0 - Y offset (always 0 for horizontal sliders)
Icons Captcha Request
Request Parameters
| Parameter | Type | Required | Description |
|---|---|---|---|
captcha.type |
string | required | Must be "FAUCETPAY_IMAGE" |
captcha.payload.questionType |
string | required | Must be "icons" |
captcha.payload.images |
array | required | Array with 1 base64 image (body/main image) |
captcha.payload.question |
string | required | Order of icons to click (e.g., "calendar,buy,star") |
The question parameter must contain the order of icons to click, separated by commas.
This is typically displayed on the FaucetPay page as "Click: calendar, buy, star" or similar.
Extract the icon names and pass them in order.
Icons Request Example
const response = await fetch('https://solver-api.mydisct.com/createTask', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'apikey': 'YOUR_API_KEY'
},
body: JSON.stringify({
auth: {
token: 'YOUR_API_KEY',
appId: 0
},
context: {
source: 'api',
version: '1.0.0'
},
captcha: {
type: 'FAUCETPAY_IMAGE',
metadata: {
siteUrl: 'https://faucetpay.io'
},
payload: {
questionType: 'icons',
question: 'calendar,buy,star', // Order of icons to click
images: [
'...' // Main image with icons
]
}
}
})
});
const data = await response.json();
console.log(data);
Icons Response (Completed)
{
"success": true,
"service": "MyDisct Solver",
"message": "Captcha solved successfully",
"task": {
"id": "MyDisctSolver_1234567890",
"status": "completed",
"result": {
"answers": [[45, 120], [180, 85], [290, 150]],
"timestamp": "2025-01-01T12:00:00.000Z"
}
}
}
The answers array contains click coordinates in order:
• [45, 120] - First click (calendar icon) at x=45, y=120
• [180, 85] - Second click (buy icon) at x=180, y=85
• [290, 150] - Third click (star icon) at x=290, y=150
Python Example
import requests
import time
import base64
def solve_faucetpay_slider(background_image, piece_image, api_key):
"""
Solve FaucetPay slider captcha
Args:
background_image: Path to background image or base64 string
piece_image: Path to slider piece image or base64 string
api_key: Your API key
Returns:
int: Pixel offset for slider movement
"""
def to_base64(image):
if image.startswith('data:image'):
return image
with open(image, 'rb') as f:
encoded = base64.b64encode(f.read()).decode()
return f'data:image/png;base64,{encoded}'
images = [to_base64(background_image), to_base64(piece_image)]
# Create task
create_response = requests.post(
'https://solver-api.mydisct.com/createTask',
headers={'Content-Type': 'application/json', 'apikey': api_key},
json={
'auth': {'token': api_key, 'appId': 0},
'context': {'source': 'api', 'version': '1.0.0'},
'captcha': {
'type': 'FAUCETPAY_IMAGE',
'metadata': {'siteUrl': 'https://faucetpay.io'},
'payload': {
'questionType': 'slider',
'images': images
}
}
}
)
create_data = create_response.json()
if not create_data['success']:
raise Exception(f"Task creation failed: {create_data.get('error', {}).get('message')}")
task_id = create_data['task']['id']
print(f"Task created: {task_id}")
# Poll for result
while True:
time.sleep(3)
result_response = requests.get(
f'https://solver-api.mydisct.com/getTaskResult?taskId={task_id}',
headers={'apikey': api_key}
)
result_data = result_response.json()
if result_data['task']['status'] == 'completed':
offset = result_data['task']['result']['answers'][0]
print(f"Slider solved! Move {offset} pixels")
return offset
elif result_data['task']['status'] == 'failed':
raise Exception('Captcha solving failed')
print("Processing...")
def solve_faucetpay_icons(body_image, icon_order, api_key):
"""
Solve FaucetPay icons captcha
Args:
body_image: Path to main image or base64 string
icon_order: Comma-separated icon names (e.g., "calendar,buy,star")
api_key: Your API key
Returns:
list: Click coordinates [[x1,y1], [x2,y2], ...]
"""
def to_base64(image):
if image.startswith('data:image'):
return image
with open(image, 'rb') as f:
encoded = base64.b64encode(f.read()).decode()
return f'data:image/png;base64,{encoded}'
# Create task
create_response = requests.post(
'https://solver-api.mydisct.com/createTask',
headers={'Content-Type': 'application/json', 'apikey': api_key},
json={
'auth': {'token': api_key, 'appId': 0},
'context': {'source': 'api', 'version': '1.0.0'},
'captcha': {
'type': 'FAUCETPAY_IMAGE',
'metadata': {'siteUrl': 'https://faucetpay.io'},
'payload': {
'questionType': 'icons',
'question': icon_order,
'images': [to_base64(body_image)]
}
}
}
)
create_data = create_response.json()
if not create_data['success']:
raise Exception(f"Task creation failed: {create_data.get('error', {}).get('message')}")
task_id = create_data['task']['id']
print(f"Task created: {task_id}")
# Poll for result
while True:
time.sleep(3)
result_response = requests.get(
f'https://solver-api.mydisct.com/getTaskResult?taskId={task_id}',
headers={'apikey': api_key}
)
result_data = result_response.json()
if result_data['task']['status'] == 'completed':
coords = result_data['task']['result']['answers']
print(f"Icons solved! Click coordinates: {coords}")
return coords
elif result_data['task']['status'] == 'failed':
raise Exception('Captcha solving failed')
print("Processing...")
# Usage examples
try:
# Slider example
offset = solve_faucetpay_slider('background.png', 'piece.png', 'YOUR_API_KEY')
print(f"Move slider {offset} pixels to the right")
# Icons example
coords = solve_faucetpay_icons('captcha.png', 'calendar,buy,star', 'YOUR_API_KEY')
for i, (x, y) in enumerate(coords):
print(f"Click {i+1}: x={x}, y={y}")
except Exception as e:
print(f"Error: {e}")
Implementation Guide
Step 1: Extract FaucetPay Captcha
// Extract FaucetPay captcha images
function extractFaucetPayCaptcha() {
const captchaContainer = document.querySelector('.captcha-container') ||
document.querySelector('[class*="captcha"]');
if (!captchaContainer) {
console.error('Captcha container not found');
return null;
}
const isSlider = captchaContainer.querySelector('.slider-piece') !== null;
const isIcons = captchaContainer.querySelector('.icon-grid') !== null;
function imageToBase64(img) {
const canvas = document.createElement('canvas');
const ctx = canvas.getContext('2d');
canvas.width = img.naturalWidth;
canvas.height = img.naturalHeight;
ctx.drawImage(img, 0, 0);
return canvas.toDataURL('image/png');
}
if (isSlider) {
const background = captchaContainer.querySelector('.slider-background img');
const piece = captchaContainer.querySelector('.slider-piece img');
return {
questionType: 'slider',
images: [imageToBase64(background), imageToBase64(piece)]
};
}
if (isIcons) {
const bodyImage = captchaContainer.querySelector('.icon-grid img');
const taskText = captchaContainer.querySelector('.captcha-task')?.textContent;
const iconOrder = taskText?.replace(/Click:|click:/gi, '').trim();
return {
questionType: 'icons',
question: iconOrder,
images: [imageToBase64(bodyImage)]
};
}
return null;
}
const captchaData = extractFaucetPayCaptcha();
console.log('Extracted:', captchaData);
Step 2: Apply Solution
// Apply slider solution
function applySliderSolution(offset) {
const slider = document.querySelector('.slider-handle');
const track = document.querySelector('.slider-track');
if (!slider || !track) return;
const startX = slider.getBoundingClientRect().left;
const endX = startX + offset;
slider.dispatchEvent(new MouseEvent('mousedown', { clientX: startX, bubbles: true }));
document.dispatchEvent(new MouseEvent('mousemove', { clientX: endX, bubbles: true }));
document.dispatchEvent(new MouseEvent('mouseup', { clientX: endX, bubbles: true }));
}
function applyIconsSolution(coordinates) {
const container = document.querySelector('.icon-grid');
const rect = container.getBoundingClientRect();
coordinates.forEach(([x, y], index) => {
setTimeout(() => {
const clickX = rect.left + x;
const clickY = rect.top + y;
container.dispatchEvent(new MouseEvent('click', {
clientX: clickX,
clientY: clickY,
bubbles: true
}));
}, index * 200); // 200ms delay between clicks
});
}
Best Practices
- Image Quality: Use original resolution images for best accuracy
- Question Format: For icons, extract the exact icon names from the page
- Base64 Format: Include the data URI prefix (data:image/png;base64,...)
- Polling Interval: Poll every 3 seconds for optimal response time
- Error Handling: Implement retry logic for failed requests
- Timeout: Set a maximum timeout of 2 minutes for polling
Common Issues
Solution: Ensure you're sending exactly 2 images for slider type: the background image first, then the slider piece image.
Solution: For icons type, you must provide the question parameter
with the order of icons to click (e.g., "calendar,buy,star").
Solution: FaucetPay may update their captcha implementation. Ensure you're extracting images correctly and applying coordinates relative to the captcha container.