Auf einer Gaming-Webseite wurde beobachtet, dass bei einer Benutzeraktivitätsabfrage bei der Seitenaktualisierung doppelte Datensätze in die Datenbank eingefügt wurden.
$insert_user_activity = mysql_query("INSERT INTO game_activity (user_id,user_full_name,game_id,game_name) values ('$user_id','$full_name','$browser_id','$game_title')");
Der Schuldige hinter diesem Problem liegt in der Logik des Front-Controllers. Die Seite mit der Abfrage wird fälschlicherweise bei allen Anfragen aufgerufen, auch bei ungültigen (z. B. nicht vorhandenen Ressourcen). Dieses Verhalten führt dazu, dass die Abfrage mehrmals ausgeführt wird, was zu doppelten Einfügungen führt.
Um das Problem zu beheben, ändern Sie die Logik des Front-Controllers. Verhindern Sie, dass die Anwendung bei ungültigen Anforderungen ausgeführt wird. Durch diese Änderung werden die falschen Einfügungen beseitigt, die andernfalls die Datenbank beim Start der Website belasten könnten.
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3