Heim >Backend-Entwicklung >PHP-Tutorial >Normalisieren von ausgefallenem Text in normalen Text in Laravel
Artikel stammt von https://medium.com/@hafiqiqmal93/normalizing-fancy-text-to-normal-text-in-laravel-7d9ed56d5a78
Texteingaben von Benutzern sind überhaupt nicht interessant. Mit der Einführung von Unicode in Smartphones haben Benutzer nun den Luxus (und manchmal auch die Laune), Text in verschiedenen Stilen und Formaten einzugeben. Von Emojis bis hin zu diakritischen Zeichen, von Ligaturen bis hin zu Zeichen voller Breite kann die Bandbreite an „ausgefallenem Text“ äußerst verwirrend oder für das System schwer verständlich sein. Obwohl sie optisch ansprechend sind, stellen diese Textvariationen eine erhebliche Herausforderung für das System dar, insbesondere im Hinblick auf Datenkonsistenz, Durchsuchbarkeit und Benutzererfahrung.
Hier sind Beispiele für ausgefallenen Text:-
???????? ???? ? ??? ?????????? ????? ?? ??? ????? ??? ?? ?????????? ?? ??????? ???? ?????? ??? ??? ???? ????? ??? ? ?? ???? ?? ????? ??? ??????? ?? ???? ???? ?? ??? ?? ????? ??? ???????? ?????? ????? ?????, ?? ???? ??????? ???? ????..????? ?? ??? ????. ??? ?????? ???? ?? ???? ????? ?????????
Sieht aus wie Kursivschrift, ist aber nicht kursiv. Es gehört eigentlich zu den mathematischen alphanumerischen Symbolen.
Nun, ein ganz offensichtliches Problem ist, dass PHP deformierte UTF-8-Zeichen beim Empfang nicht JSON-kodieren kann. Bei der modernen Art der Webentwicklung, bei der APIs und Frontend-Frameworks JSON zum Transport von Daten verwenden, ist dies ein Problem. Bei falscher Behandlung führen solche deformierten Zeichen zu Datenbeschädigung, Abstürzen oder verärgerten Benutzern.
Unser Ziel ist einfach: Wir haben die Lösung entwickelt, die jeden ausgefallenen Text in normal lesbaren Text umwandelt.
Normalisierungsformen sind für das Verständnis des Normalisierungsprozesses von entscheidender Bedeutung. Sie gehen auf unterschiedliche sprachliche und technische Bedürfnisse ein. Beispielsweise kombiniert die NFC-Form Zeichen in ihre zusammengesetzten Formen, während NFD das Gegenteil tut und zusammengesetzte Zeichen in ihre Bestandteile zerlegt. NFKC- und NFKD-Formulare gehen noch einen Schritt weiter und berücksichtigen Kompatibilitätszeichen – das Falten von Variationen von Zeichen in eine kanonische Form. Diese Formulare stellen sicher, dass Textvergleich, Suche und Speicherung konsistent und zuverlässig sind.
Das bereitgestellte Code-Snippet ist ein hervorragendes Beispiel für den PHP-Ansatz zur einfachen und effizienten Lösung komplexer Probleme. Lassen Sie uns diese Lösung analysieren, ihre Komponenten verstehen und sehen, wie sie sich nahtlos integriert :-
public static function normalizeText($text): ?string { if (!$text) { return null; } $intl = [ \Normalizer::FORM_C, \Normalizer::FORM_D, \Normalizer::NFD, \Normalizer::FORM_KC, \Normalizer::NFKC, \Normalizer::FORM_KC_CF, \Normalizer::FORM_KD, \Normalizer::NFKD, \Normalizer::NFC, \Normalizer::NFKC_CF, ]; foreach ($intl as $form) { if (!\Normalizer::isNormalized($text, $form)) { return \Normalizer::normalize($text, $form); } } return $text; }
Die Verwendung ist einfach:-
$normalText = Utils::normalizeText($YOUR_FANCY_STRING)
Sie können sich in der Hilfsfunktion registrieren, um die Verwendung zu vereinfachen. Zum Beispiel:-
if ( ! function_exists('normalize_text')) { function normalize_text(string $text): string { return Utils::normalizeText($text) } } // USAGE $normalText = normalize_text($YOUR_FANCY_STRING)
Im Kern nutzt diese Funktion die **Normalizer**-Klasse von PHP – einen Teil der Internationalization (intl)-Erweiterung –, um die Normalisierung anzugehen. Die **Normalizer**-Klasse bietet mehrere Normalisierungsformen, die jeweils auf unterschiedliche Normalisierungsanforderungen zugeschnitten sind. Diese Funktion durchläuft diese Formulare und prüft mithilfe der Funktion **isNormalized**, ob der Text bereits in einem bestimmten Formular normalisiert ist. Wenn nicht, normalisiert es den Text in dieser Form und gibt die normalisierte Zeichenfolge zurück.
Während ausgefallener Text die Benutzereingabe optisch ansprechender machen kann, stellt er erhebliche Herausforderungen für die Datenverarbeitung und Systeminteroperabilität dar. Mit der Übernahme der Normalizer-Klasse von PHP und der Implementierung von Normalisierungsformen können Entwickler diese Herausforderungen jedoch meistern und sicherstellen, dass ihre Anwendungen auch bei unterschiedlichen Texteingaben Datenkonsistenz und -zuverlässigkeit bewahren.
Haben Sie Erfahrungen oder Herausforderungen im Zusammenhang mit dem Umgang mit ausgefallenen Texten in Ihren Projekten? Wie gehen Sie derzeit mit solchen Problemen um und finden Sie die Normalizer-Klasse von PHP in Ihrem Workflow nützlich? Lassen Sie uns das Gespräch fortsetzen und unsere Erkenntnisse austauschen, um uns gegenseitig bei der Bewältigung der Komplexität der modernen Webentwicklung zu helfen. ??
Das obige ist der detaillierte Inhalt vonNormalisieren von ausgefallenem Text in normalen Text in Laravel. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!