Comments (1)
Not works in next13.
So I make a service for fetch captcha.
import { StatusCodes } from 'http-status-codes'
export interface SvgCaptchaCreateProps {
data: string
text: string
}
export interface SvgCaptchaOption {
width?: number
height?: number
fontSize?: number
mathMin?: number
mathMax?: number
noise?: number
color?: boolean
background?: string
}
export class SvgCaptcha {
private static REMOTE_URL = 'https://svg-captcha.inn-studio.com'
public static create = async ({
width = 200,
height = 50,
fontSize = 50,
mathMin = 10,
mathMax = 99,
noise = 5,
color = true,
background = '',
}: SvgCaptchaOption): Promise<SvgCaptchaCreateProps | null> => {
const params = new URLSearchParams({
width: String(width),
height: String(height),
fontSize: String(fontSize),
mathMin: String(mathMin),
mathMax: String(mathMax),
noise: String(noise),
color: color ? '1' : '0',
background,
}).toString()
try {
const res = await fetch(`${this.REMOTE_URL}?${params}`, {
cache: 'no-cache',
})
if (res.status !== StatusCodes.OK) {
return null
}
const data = await res.json()
if (data?.svg && data?.text) {
return {
data: data.svg,
text: data.text,
}
}
return null
} catch (err) {
console.log(err)
return null
}
}
}
from svg-captcha.
Related Issues (20)
- Help with Instructions HOT 1
- Math Expression result are not between min and max config options HOT 1
- 如何自定义text? HOT 1
- 什么时候支持一下躁点? HOT 1
- could this project support compiling in angular?
- README Implementation is vulnerable to "replay"-style attack
- How to use with nextjs? HOT 5
- index.d.ts doesn't expose function const createCaptcha = function (text, options) ...
- how to implement this in typescript?? it causes some error
- High contrast text color to background color?
- This program has been cracked, please fix it HOT 4
- Svg file HOT 1
- Single path to improve security HOT 1
- What's going on with the versions? Nothing works on v3? HOT 4
- suggestion, the font path should config,if you use ../fonts/balaa.ttf, we can't pack all js to one file HOT 5
- node index.js find the error:"ENOENT: no such file or directory, open 'E:\umore\dailywork\BackSystem\fonts\Comismsh.ttf'" HOT 10
- to be real per the captcha ideal and goal HOT 6
- 建议增加一个选项来控制当验证码是随机字符串的时候 是否区分大小写 HOT 1
- 使用的字体库存在内存泄露问题 HOT 1
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from svg-captcha.