Rumah pembangunan bahagian belakang masalah PHP Apakah yang perlu saya lakukan jika aksara bercelaru muncul semasa membuat pertanyaan dalam PHP?

Apakah yang perlu saya lakukan jika aksara bercelaru muncul semasa membuat pertanyaan dalam PHP?

Apr 11, 2023 am 10:31 AM

PHP ialah bahasa pengaturcaraan yang digunakan secara meluas yang biasa digunakan untuk pembangunan web. Apabila menggunakan PHP untuk melakukan pertanyaan pangkalan data, kadangkala akan terdapat masalah dengan memproses aksara yang bercelaru. Masalah ini biasanya berlaku apabila berurusan dengan aksara Cina.

Pengekodan aksara yang disimpan dalam pangkalan data mungkin berbeza daripada pengekodan aksara halaman web, yang boleh menyebabkan aksara bercelaru apabila membuat pertanyaan. Walaupun isu ini kelihatan mudah, ia boleh memberi kesan negatif pada prestasi dan keselamatan tapak web anda.

Berikut ialah beberapa kaedah untuk menyelesaikan masalah aksara bercelaru apabila membuat pertanyaan dalam PHP.

  1. Tetapkan pengekodan aksara pangkalan data kepada UTF-8

UTF-8 ialah pengekodan aksara yang menyokong semua aksara Unikod. Jika pangkalan data menggunakan pengekodan UTF-8, tidak akan ada aksara bercelaru semasa membuat pertanyaan. Oleh itu, menetapkan pengekodan aksara pangkalan data kepada UTF-8 ialah satu cara untuk menyelesaikan masalah bercelaru.

Anda boleh menggunakan kod berikut untuk menetapkan pengekodan aksara pangkalan data MySQL kepada UTF-8:

$conn = mysqli_connect($servername, $username, $password, $dbname);
mysqli_set_charset($conn, "utf8");
Salin selepas log masuk

Di mana $servername ialah nama pelayan pangkalan data, $username ialah nama pengguna pangkalan data , dan $password ialah kata laluan Pangkalan Data, $dbname ialah nama pangkalan data. Fungsi mysqli_set_charset() digunakan untuk menetapkan set aksara.

  1. Tetapkan pengekodan aksara sebelum membuat pertanyaan

Menetapkan pengekodan aksara yang betul sebelum membuat pertanyaan juga boleh menyelesaikan masalah aksara yang bercelaru. Anda boleh menggunakan kod PHP berikut untuk menetapkan pengekodan aksara:

$conn = mysqli_connect($servername, $username, $password, $dbname);
mysqli_query($conn, "SET NAMES 'utf8'");
Salin selepas log masuk

di mana $servername, $username, $password dan $dbname ialah nama pelayan pangkalan data, nama pengguna, kata laluan dan nama pangkalan data masing-masing. Fungsi mysqli_query() menetapkan pengekodan aksara kepada UTF-8.

  1. Gunakan fungsi PHP iconv() untuk penukaran pengekodan aksara

Fungsi iconv() PHP boleh menukar satu pengekodan aksara kepada pengekodan aksara yang lain. Anda boleh menggunakan fungsi iconv() untuk menukar hasil pertanyaan daripada set aksara pangkalan data kepada set aksara halaman web. Berikut ialah contoh:

$conn = mysqli_connect($servername, $username, $password, $dbname);
mysqli_set_charset($conn, "utf8");
$result = mysqli_query($conn, "SELECT * FROM `user`");
while ($row = mysqli_fetch_array($result)) {
    $name = iconv("UTF-8", "GB2312//IGNORE", $row['name']);
    echo $name . "<br />";
}
Salin selepas log masuk

Dalam contoh ini, medan nama dalam hasil pertanyaan ditukar daripada pengekodan UTF-8 kepada pengekodan GB2312. Gunakan parameter //IGNORE untuk mengabaikan aksara yang tidak boleh ditukar.

  1. Gunakan fungsi PHP mb_convert_encoding() untuk penukaran pengekodan aksara

Fungsi PHP mb_convert_encoding() juga boleh menukar pengekodan aksara kepada pengekodan lain. Berikut ialah contoh:

$conn = mysqli_connect($servername, $username, $password, $dbname);
mysqli_set_charset($conn, "utf8");
$result = mysqli_query($conn, "SELECT * FROM `user`");
while ($row = mysqli_fetch_array($result)) {
    $name = mb_convert_encoding($row['name'], "GBK", "UTF-8");
    echo $name . "<br />";
}
Salin selepas log masuk

Dalam contoh ini, medan nama dalam hasil pertanyaan ditukar daripada pengekodan UTF-8 kepada pengekodan GBK.

Ringkasan

Kaedah di atas boleh menyelesaikan masalah aksara bercelaru apabila membuat pertanyaan dalam PHP. Apabila menggunakan PHP untuk pertanyaan pangkalan data, adalah disyorkan untuk menetapkan pengekodan aksara pangkalan data kepada UTF-8 dan menetapkan pengekodan aksara yang betul sebelum membuat pertanyaan. Jika anda masih mempunyai aksara yang bercelaru, anda boleh menggunakan fungsi PHP iconv() atau fungsi PHP mb_convert_encoding() untuk menukar pengekodan aksara.

Atas ialah kandungan terperinci Apakah yang perlu saya lakukan jika aksara bercelaru muncul semasa membuat pertanyaan dalam PHP?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah amalan terbaik untuk deduplikasi tatasusunan php Apakah amalan terbaik untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:41 PM

Apakah amalan terbaik untuk deduplikasi tatasusunan php

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama? Mar 03, 2025 pm 04:51 PM

Bolehkah PHP Array Deduplication memanfaatkan keunikan nama utama?

Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Apakah piawaian pengekodan PHP terkini dan amalan terbaik? Mar 10, 2025 pm 06:16 PM

Apakah piawaian pengekodan PHP terkini dan amalan terbaik?

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi? Mar 03, 2025 pm 04:47 PM

Adakah Deduplication Array PHP perlu dipertimbangkan untuk kerugian prestasi?

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php Mar 03, 2025 pm 04:50 PM

Apakah teknik pengoptimuman untuk deduplikasi tatasusunan php

Bagaimana saya bekerja dengan sambungan php dan pecl? Bagaimana saya bekerja dengan sambungan php dan pecl? Mar 10, 2025 pm 06:12 PM

Bagaimana saya bekerja dengan sambungan php dan pecl?

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP? Mar 10, 2025 pm 06:15 PM

Bagaimana untuk melaksanakan beratur mesej (RabbitMQ, Redis) dalam PHP?

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP? Mar 10, 2025 pm 06:12 PM

Bagaimana menggunakan refleksi untuk menganalisis dan memanipulasi kod PHP?

See all articles