Ursachen für verstümmelte Zeichen:
Wenn die Codierung der JSP-Seite nicht mit der Codierung der MySQL-Datenbank übereinstimmt, treten häufig verstümmelte Zeichen auf. Beispielsweise verwendet die JSP-Seite die UTF-8-Kodierung, während die MySQL-Datenbank die GBK-Kodierung verwendet.
Falscher Datenbankzeichensatz: Der von der MySQL-Datenbank verwendete Standardzeichensatz ist der lateinische Zeichensatz (latin1), nicht der UTF-8-Zeichensatz, der Chinesisch unterstützt. Wenn Sie chinesische Zeichen in eine MySQL-Datenbank einfügen oder einlesen, werden Sie wahrscheinlich auf verstümmelte Zeichen stoßen.
Falsche Datenbankverbindungskodierungsmethode: Wenn JDBC eine Verbindung zu MySQL herstellt, müssen Sie die Verbindungskodierungsmethode festlegen. Wenn die Einstellung falsch ist, führt dies auch zu Problemen mit verstümmeltem Code.
Lösung:
Legen Sie die Seitenkodierungsmethode fest: Fügen Sie stellen Sie sicher, dass die Kodierungsmethode der JSP-Seite mit der Kodierungsmethode der MySQL-Datenbank übereinstimmt.
Um den Zeichensatz der MySQL-Datenbank auf UTF-8 festzulegen, müssen Sie die my.cnf-Datei von MySQL ändern. Fügen Sie die folgenden Codezeilen unter [mysqld] hinzu:
[mysqld]
character-set-server=utf8
collation-server=utf8_general_ci
Hinweis: Stellen Sie sicher, dass Sie die vorhandenen Zeichensatzelemente von MySQL auf UTF-8 ändern , anstatt den obigen Code direkt hinzuzufügen.
Legen Sie die Codierungsmethode für die Datenbankverbindung fest: Wenn JDBC eine Verbindung zu MySQL herstellt, müssen Sie die Verbindungscodierungsmethode festlegen, um sicherzustellen, dass die Codierungsmethoden der JSP-Seite und der MySQL-Datenbank konsistent sind. Sie können es beispielsweise festlegen, indem Sie den Parameter charset=UTF-8 zur JDBC-URL hinzufügen
jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=UTF-8
Das obige ist der detaillierte Inhalt vonSo lösen Sie verstümmelten JSP-MySQL-Code. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!