Des reportages comme celui-ci indiquent que le numéro ci-dessus est peut-être apparu comme un bug de programmation.
Aux États-Unis, un homme est sorti dans sa station-service locale pour acheter un paquet de cigarettes - mais il a découvert que sa carte avait débité 23 148 855 308 184 500 dollars.
Cela représente 23 milliards de dollars (14 milliards de livres sterling), soit plusieurs fois la dette nationale américaine. *
En hexadécimal, c'est 523DC2E199EBB4, ce qui ne semble pas terriblement intéressant à première vue.
Quelqu'un a-t-il une idée de quelle erreur de programmation aurait provoqué cela?
magic-numbers
Roddy
la source
la source
Réponses:
Ajoutez les cents au nombre et vous obtenez 2314885530818450000, qui en hexadécimal est 2020 2020 2020 1250.
Voyez-vous le motif? Les six premiers octets ont été remplacés par des espaces (hex 20, déc 32).
la source
Attends une seconde; il se passe quelque chose de louche.
Bien que l'explication remplie d'espace semble certainement bonne, elle peut être (au moins en partie) spécieuse.
VISA a déclaré qu'il y avait «moins de 13 000» clients touchés par le snafu avec les cartes prépayées Visa Buxx. J'ai trouvé des nouvelles sur plusieurs jusqu'à présent. Josh Muszynski dans le New Hampshire, Jason Bryan dans le Tennessee, Ron Seale au Texas, le fils adolescent de Karen Taylor à Bethel et une adolescente, Elizabeth Lewis à Owatonna.
Le fait est que tous ont exactement le même prix : 23.148.855.308.184.500,00 $. Si le problème était le remplissage d'espace, alors comment se fait-il qu'ils aient tous exactement la même charge de $ 0x1250 ($ 46.88)? Deux d'entre eux avaient acheté des cigarettes dans des stations-service, deux autres avaient payé dans des restaurants, Lewis avait acheté des œufs et du lait, le dernier dans une pharmacie. Est-ce que tous ces articles variés ont le même prix? 46,88 $ pour une facture de restaurant semble correct, mais pour un paquet de cigarettes? pour le lait et les œufs‽
L'erreur de remplissage d'espace est logique, sauf qu'elle ne tient pas compte de la constante 0x1250. Pourquoi est-ce que tous se sont retrouvés avec
0x2020 2020 2020 1250
au lieu de0x2020 2020 2020 2020
ou des numéros différents dans le dernier MOT?Hmmm, si seulement 13 000 clients étaient touchés, il se peut que cette charge précise et spécifique ait déclenché l'erreur. Dans ce cas, c'est plus qu'une simple erreur de champ. Si c'était juste le champ de texte qui était interprété comme un entier 64 bits, alors pourquoi d'autres montants ne l'ont-ils pas causé, affectant ainsi tout le monde, pas seulement <13 000. Pourtant, comment se fait-il que 13 000 personnes auraient pu arriver à facturer exactement le même montant au cours de la même semaine?
Ils disent que c'est une "erreur de programmation temporaire", et c'est peut-être le cas, mais pourrait-il s'agir d'un piratage? Dans ce cas, ce serait probablement un nombre magique. En fait, il peut s'agir d'une combinaison des deux: un pirate mettant une charge automatique 0x1250, qui a été combiné avec l'erreur de remplissage d'espace, provoquant la détection d'une ou des deux erreurs.
Le Registre pense que la réponse est en effet l'erreur de remplissage, mais ne précise pas pourquoi elles sont toutes les mêmes, bien qu'un des commentaires mentionne que le nombre peut être arrondi au 100 $ le plus proche (peu probable car les banques et les logiciels bancaires vont explicitement aux longueurs pour assurer la précision).
(Il existe également un rapport d'une erreur similaire antérieure.)
Le projet de loi de Jason Bryant:
Le projet de loi d'Elizabeth Lewis:
Le projet de loi de Ron Seale:
Le projet de loi de Josh Muszynski:
la source
Ce qui se passe lorsque vous effectuez un achat par carte, c'est que le logiciel se met immédiatement en ligne pour vous assurer que vous disposez de fonds suffisants pour l'achat, mais ne met en attente que les fonds pour la transaction. À la fin de la journée de travail, le logiciel rassemble ensuite toutes les transactions passées dans les dernières 24 heures et les soumet à la banque acquéreuse pour traitement.
La soumission à la banque est connue sous le nom de règlement, et elle se fait en envoyant un fichier texte brut dans un format très rigide. (Tout cela a été développé il y a des décennies et le nombre de systèmes qui l'utilisent maintenant le rend difficile à moderniser)
Chaque transaction apparaît dans le fichier sous la forme d'une ligne de texte, dont une partie est la valeur de la transaction. Ce champ doit être composé de 11 caractères numériques (zéro complété à gauche) et contiendra toujours la valeur dans le plus petit dénominateur commun (dans ce cas, les cents). 11 caractères numériques s'adaptent bien aux valeurs dans n'importe quelle devise.
Il semble que le processeur de paiement dans ce cas ait apporté quelques modifications à son logiciel de soumission et remplacé par erreur le remplissage zéro par un remplissage espace. Tout à fait comment cela a été obtenu par a) un fournisseur de services, b) l'acquisition d'une banque et c) un visa sans être récupéré m'échappe. La valeur nette de ce dossier de règlement (13 000 transactions de grande valeur) aurait été astronomique, et peut-être que cela a également été un facteur contributif quelque part.
la source
Si vous supprimez le zéro de fin, cela est validé comme numéro de carte VISA. Je suppose qu'ils ont glissé la carte puis entré manuellement le numéro, pensant que le balayage avait échoué.
la source
Le mystère ultime est toujours d'où vient 12 50. Ce sont les codes ASCII pour Ctrl + R, P. Ce qui se trouve être les frappes secrètes que vous devez taper pour entrer le code de validation pour QuickBooks.
Lien: où saisir le code de validation
Une coïncidence. Je me demande ce qui se passe lorsque vous tapez ces touches au mauvais endroit ...
la source
Si vous déplacez la représentation 64 bits vers la gauche 8 bits vers la gauche (multipliez par 256) Vous obtiendrez un numéro de carte de crédit bien formé et 3 positions vides pour cela 3 numéros supplémentaires sécurisés (tous des zéros pour une raison quelconque). Il n'y a qu'une chance sur 10 qu'un nombre aléatoire donne un nombre CC bien formé.
5926 1069 5889 5232 000
la source
Si vous utilisez le décodeur d'équivalent binaire (1110101110110100) du nombre 23148855308184500, vous obtenez K 鑛, qui est le caractère mandarin pour l'extraction minière et le minerai. Kmine pourrait signifier «mine de connaissances», ou quelque chose comme kmine Holdings Ltd. Peut-être y a-t-il une corrélation entre K (mine ou minerai) et Bank of America ou Visa?
la source