Get Image Verification Code
POST/auth/v1/captcha/data
API Description
Get image verification code API, returns RFC 2397 standard inline image data URI for human-machine verification in login, registration and other scenarios.
Input Requirements
Request Parameters
- No parameters required, call directly
Prerequisites
- No special prerequisites
- Recommend calling when user login fails too many times
- Can be used in sensitive operations such as registration, password recovery
Output Description
Successful Response
data: Image data (required, RFC 2397 standard inline image data URI, format )type: Resource type (required, fixed value "image")token: Verification code token (required, used for subsequent verification API)expires_in: Expiration time (required, in seconds, default 300 seconds)
Request Example
Get Image Verification Code Request Example
POST /auth/v1/captcha/data
Content-Type: application/json
{}
Response Example
Successful Response Example
{
"data": "",
"type": "image",
"token": "aC_raGNycHQOSR7w0V7U0Ble-edJud_-AJofUvLFga8v59WsZVRI_RUBxC9Tk5eUoBNrdPhqA0M_ZkT0V0le909Z7YmWHVT4Yead026_",
"expires_in": 300
}
Field Description
Response Parameters
| Field Name | Type | Required | Description |
|---|---|---|---|
| data | string | Yes | Image data, RFC 2397 standard inline image data URI, includes protocol header (data:), MIME type (image/gif), encoding method (base64) and actual data |
| type | string | Yes | Resource type, fixed value "image" |
| token | string | Yes | Verification code token, used for subsequent verification API |
| expires_in | integer | Yes | Expiration time, in seconds, default 300 seconds |
Usage Flow
1. Get Verification Code Image
- Frontend calls this API to get verification code data
- Assign data field directly to img tag's src attribute
- Save token properly for subsequent verification
- Implement refresh verification code function
2. User Inputs Verification Code
- User recognizes verification code content in image
- Inputs verification code in input box
3. Submit Verification Code Verification
- Call Verify Image Verification Code API
- Pass token and user input verification code
- Get captcha_token
4. Business API Authorization
- Attach request header in business requests requiring verification code protection
- Request header format:
x-captcha-token: xxx
Key Characteristics
Image Format
- Conforms to RFC 2397 standard Data URI
- Uses GIF format
- Base64 encoding
- Can be used directly in HTML
Security
- Verification code token valid for 300 seconds
- New verification code generated each time
- Verification code becomes invalid after use
- Supports anti-brute-force mechanism
Usage Scenarios
Login Protection
- Require verification code when user login fails too many times
- Prevent brute-force password cracking
- Protect account security
Registration Protection
- Prevent batch registration
- Prevent malicious registration
- Protect system resources
Sensitive Operation Protection
- Password recovery
- Password modification
- Binding information modification
- Account deletion
Notes
Frontend Implementation
- Assign data field directly to img tag's src attribute
- Save token properly for subsequent verification
- Implement refresh verification code function
- Need to get new code after expiration
Security Recommendations
- Verification code should be generated on server-side
- Verification code content should be random and unpredictable
- Limit acquisition frequency for same IP
- Record verification code acquisition logs
Common Errors
- Server error: Retry acquisition
- Network timeout: Check network connection
- Rate limit: Wait and retry
Error Response Example
{
"error": "rate_limit_exceeded",
"error_code": 4029,
"error_description": "Verification code acquisition frequency too high, please try again later"
}
Related APIs
- Verify Image Verification Code - Verify user input verification code
- User Login - Login API
- User Registration - Registration API
Request
Responses
- 200
Response Headers
- application/json
- Schema
- Example (from schema)
- Example
Schema
data Image Data (string)required
RFC 2397 standard inline image data URI, including the following parts: protocol header: data: MIME type: image/gif encoding method: base64 actual data: Base64 encoded binary data conforming to RFC 4648
type Type (string)required
Enumerated value of resource type: "image" for image resources. Other values are reserved for future expansion.
token Token (string)required
The token to be passed to the verification code verification API
expires_in Expiration Time (integer)required
Token expiration time, default 300 seconds
{
"data": "string",
"type": "string",
"token": "string",
"expires_in": 0
}
{
"data": "",
"type": "image",
"token": "aC_raGNycHQOSR7w0V7U0Ble-edJud_-AJofUvLFga8v59WsZVRI_RUBxC9Tk5eUoBNrdPhqA0M_ZkT0V0le909Z7YmWHVT4Yead026_",
"expires_in": 300
}
Loading...