Bucket a key
API · /abtest-api
API de répartition A/B
Tests A/B déterministes et attribution de fonctionnalités — sans base de données, sans état stocké. Le point de terminaison bucket hache une clé (un identifiant utilisateur, une session ou un appareil) dans un bucket stable de 0 à N-1 qui ne change jamais pour cette clé, et peut décider si la clé se trouve dans un déploiement progressif en pourcentage ; comme la décision est monotone, augmenter le pourcentage ne fait qu'ajouter des utilisateurs, donc une montée en charge progressive est persistante et personne ne revient en arrière. Le point de terminaison variant attribue l'une des plusieurs variantes pondérées — une simple répartition contrôle/traitement ou tout test multivarié — de manière cohérente pour la même clé, en respectant les poids personnalisés. Mélanger un nom d'expérience maintient les expériences indépendantes, et comme les mêmes entrées produisent toujours la même réponse, votre client et serveur (et toute fonction périphérique) s'accordent sur l'attribution sans aucune coordination ni recherche. Le hachage est FNV-1a avec un mélange avalanche, donnant des buckets uniformes et stables à travers les langages et les machines. Il s'exécute entièrement localement, donc il est instantané, déterministe et privé. Idéal pour les fonctionnalités et les déploiements progressifs, les expériences A/B et multivariées, les versions canary, les groupes de contrôle et les interrupteurs, et la répartition UI cohérente sur le web et le mobile. Calcul local pur — pas de clé, pas de service tiers, instantané. En direct, rien de stocké. 3 points de terminaison. Cela attribue les expériences de manière déterministe ; pour tester si un résultat est statistiquement significatif, utilisez une API de statistiques.
Santé API
en bonne santé- Temps de disponibilité
- 100.00%
- Sondes serveur · 24h
- Latence moyenne
- 78 ms
- Sondes serveur · 24h
- Abonnées
- 3,216
- active
- Total des appels
- 57
- les 7 derniers jours
Tarifs
Choisissez un niveau: facturé mensuellement, annulez à tout moment.
Free
Gratuite
- 3,035 appels / mois
- 2 requêtes / seconde
- Plafond ferme (429 au-dessus du quota, pas de dépassement)
- 3 035 appels/mois
- 2 req/s
- Bucket + variante
- Pas de carte de crédit
Starter
€4.55 /mois
- 12,550 appels / mois
- 8 requêtes / seconde
- Plafond ferme (429 au-dessus du quota, pas de dépassement)
- 12,55k appels/mois
- 8 req/s
- Déploiements persistants + pondérations
- Assistance par e-mail
Pro
€24.45 /mois
- 176,500 appels / mois
- 20 requêtes / seconde
- Plafond ferme (429 au-dessus du quota, pas de dépassement)
- 176,5k appels/mois
- 20 req/s
- Pipelines de feature flags / expériences
- Support prioritaire
Mega
€62.45 /mois
- 925,000 appels / mois
- 50 requêtes / seconde
- Plafond ferme (429 au-dessus du quota, pas de dépassement)
- 925k appels/mois
- 50 req/sec
- Échelle de plateforme
- SLA dédié
Construit par
Connexes APIs
Autres APIs avec des balises qui se chevauchent.
API du Paradoxe des Anniversaires
Mathématiques du paradoxe des anniversaires et de la probabilité de collision sous forme d'API, calculées localement et de manière déterministe. Le point de terminaison de probabilité calcule la chance qu'au moins deux personnes sur n partagent un anniversaire parmi d jours également probables, P = 1 − Π(1 − i/d), évalué dans l'espace logarithmique pour plus de précision — le résultat célèbre selon lequel seulement 23 personnes donnent environ 50,7 % de chance, 50 personnes environ 97 % et 70 personnes environ 99,9 %. Le point de terminaison personnes-nécessaires l'inverse : la plus petite taille de groupe pour atteindre une probabilité cible (23 pour 50 %, 57 pour 99 %), avec l'approximation √(2·d·ln(1/(1−p))). Le point de terminaison de collision généralise la limite d'anniversaire à n'importe quel espace — passez un nombre de seaux ou une taille de hachage en bits — et renvoie la probabilité de collision P ≈ 1 − e^(−n²/2d), la règle derrière les collisions de hachage et les estimations d'unicité UUID, où une chance de 50 % nécessite environ 1,177·√d éléments. Les jours et les seaux par défaut sont 365. Tout est calculé localement et de manière déterministe, donc c'est instantané et privé. Idéal pour l'éducation aux probabilités, la sécurité, la cryptographie, le hachage, l'ingénierie des données et les développeurs d'applications statistiques, les outils de risque de collision et de problème d'anniversaire, et le matériel pédagogique. Calcul local pur — pas de clé, pas de service tiers, instantané. En direct, rien n'est stocké. 3 points de terminaison. Ceci est la probabilité d'anniversaire/collision ; pour les distributions complètes, utilisez une API de probabilité.
api.oanor.com/birthdayparadox-api
API de somme de contrôle
Sommes de contrôle non cryptographiques rapides en tant qu'API. Calculez CRC-32 — le contrôle d'intégrité utilisé par ZIP, gzip, PNG et Ethernet — et Adler-32 — la somme de contrôle utilisée par zlib — sur du texte UTF-8, une entrée hexadécimale ou base64, renvoyée en hexadécimal et sous forme d'entiers 32 bits signés et non signés. Idéal pour la vérification de l'intégrité des fichiers et des messages, les clés de cache et les ETags, la détection de modifications et la déduplication, lorsque vous souhaitez une empreinte rapide plutôt qu'un hachage sécurisé. Calcul local pur — pas de clé, pas de service tiers, instantané ; envoyez des données binaires via le codage hexadécimal ou base64 (jusqu'à 4 Mo). En direct, rien n'est stocké. 4 points de terminaison. Explicitement PAS pour la sécurité — pour les condensés cryptographiques (MD5, SHA-256, HMAC), utilisez plutôt une API de hachage.
api.oanor.com/checksum-api
Programming Languages API
The language definitions GitHub uses to recognise code (the open-source Linguist data) as an API — a clean reference for syntax highlighting, file-type detection, repository dashboards and developer tooling. For each of 800+ languages the API returns its type (programming, markup, data or prose), its brand colour (the hex GitHub paints it), the file extensions associated with it, common aliases, the GitHub language id and the editor (ace) mode. Look a language up by name or alias (golang resolves to Go), reverse-look-up which language(s) own a file extension (.py → Python; .h → C, C++, Objective-C), list the languages of a type, search, or list them all. Distinct from languages-api (ISO 639 human languages) — this is the programming-language reference. Served from memory — always fast.
api.oanor.com/proglang-api
API des types MIME
La base de données canonique des types MIME / media-type (le mime-db jshttp utilisé par Express et la plupart de l'écosystème Node : IANA + Apache + nginx), servie depuis la mémoire — sans clé. Résoudre un type media en ses extensions de fichier, jeu de caractères et compressibilité ; recherche inversée du ou des types media pour une extension de fichier (ex. png → image/png) ; et rechercher ou lister les types par source. Plus de 2 600 types media, dont plus de 1 000 avec extensions de fichier. JSON léger et prévisible. Idéal pour la validation de téléchargements, la résolution de Content-Type, la détection de type de fichier, les gestionnaires de téléchargement et les outils de développement.
api.oanor.com/mimetypes-api
Questions fréquentes
Réponses rapides sur les tarifs, quotas et l'intégration.
Comment obtenir une clé API pour API de répartition A/B ?
Quelle est la limite de débit de API de répartition A/B ?
Combien coûte API de répartition A/B ?
Puis-je résilier mon abonnement à tout moment ?
API de répartition A/B est-il conforme au RGPD ?
Choisissez un point de terminaison dans la liste de gauche pour voir ses détails et essayez-le.
Extraits de code
Inscrivez-vous pour obtenir une clé API, puis appelez n'importe quel chemin sous votre slug.
curl https://api.oanor.com/abtest-api/SOME_PATH \
-H "x-oanor-key: oanor_test_..."
const res = await fetch("https://api.oanor.com/abtest-api/SOME_PATH", {
headers: { "x-oanor-key": "oanor_test_..." }
});
const data = await res.json();
$ch = curl_init("https://api.oanor.com/abtest-api/SOME_PATH");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, ["x-oanor-key: oanor_test_..."]);
$response = curl_exec($ch);
import requests
r = requests.get(
"https://api.oanor.com/abtest-api/SOME_PATH",
headers={"x-oanor-key": "oanor_test_..."},
)
print(r.json())
Notes
Connectez-vous pour évaluer.
Aucun avis pour l'instant.
Discussion
Pose tes questions, partage des astuces, obtiens des réponses du fournisseur et d'autres devs. Public — tout le monde peut lire.
Connecte-toi pour écrire ou répondre.
ConnexionNouvelle discussion
·
-
Réponse du fournisseur
🔒 Discussion verrouillée — plus de nouvelles réponses.
-
·
- Aucune discussion — lance la première.
Support
Support privé 1:1 avec le fournisseur — facturation, intégration, compte. Seulement toi et l'équipe du fournisseur voyez ces fils.
Connecte-toi pour ouvrir un ticket de support.
ConnexionOuvrir un nouveau ticket
Décris ce dont tu as besoin. L'équipe reçoit un email et répond sur la page du ticket.
-
·
Urgente - Aucun ticket pour cette API.