Skip to main content

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 NameTypeRequiredDescription
datastringYesImage data, RFC 2397 standard inline image data URI, includes protocol header (data:), MIME type (image/gif), encoding method (base64) and actual data
typestringYesResource type, fixed value "image"
tokenstringYesVerification code token, used for subsequent verification API
expires_inintegerYesExpiration 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

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"
}

Request

Responses

Response Headers
    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

    Loading...