


Bagaimana untuk menyelesaikan kod kacau Cina semasa memuat turun Excel dalam PHP
Semasa pembangunan, selalunya perlu menggunakan PHP untuk menjana fail Excel dan menyediakannya untuk dimuat turun oleh pengguna. Walau bagaimanapun, banyak kali kita akan menghadapi masalah, iaitu, aksara bercelaru muncul apabila mengeluarkan bahasa Cina. Di bawah ini kami akan memperkenalkan punca dan penyelesaian aksara Cina yang kacau.
1. Analisis sebab
Kejadian aksara Cina yang kacau adalah disebabkan oleh set aksara yang tidak konsisten bagi fail. Apabila kami mengeluarkan fail Excel yang dijana oleh PHP kepada penyemak imbas, kami perlu menentukan set aksara keluaran dan set aksara fail Excel mestilah konsisten dengan set aksara keluaran, jika tidak, aksara bercelaru akan muncul.
2. Penyelesaian
- Tetapan set aksara fail PHP
Dalam fail PHP, kita perlu menetapkan set aksara fail. Biasanya set aksara UTF-8 digunakan lebih banyak. Anda boleh menambah kod berikut pada kod PHP:
header("Content-Type:text/html;charset=utf-8");
- Tetapan set aksara bagi fail Excel
Apabila menjana fail Excel, kita perlu menetapkan aksara set fail kepada Sama seperti set aksara output. Anda boleh menetapkan set aksara fail Excel dengan memanggil kaedah yang disediakan oleh perpustakaan PHPExcel Kod sampel adalah seperti berikut:
<?php require_once 'PHPExcel.php'; //新建一个PHPExcel对象 $objPHPExcel = new PHPExcel(); //设置文件属性 $objPHPExcel->getProperties() ->setCreator("Maarten Balliauw") ->setLastModifiedBy("Maarten Balliauw") ->setTitle("PHPExcel Test Document") ->setSubject("PHPExcel Test Document") ->setDescription("Test document for PHPExcel, generated using PHP classes.") ->setKeywords("office PHPExcel php") ->setCategory("Test result file"); //设置当前的sheet $objPHPExcel->setActiveSheetIndex(0); //向Excel中写入数据 $objPHPExcel->getActiveSheet()->setCellValue('A1', 'Hello'); $objPHPExcel->getActiveSheet()->setCellValue('B1', 'World!'); $objPHPExcel->getActiveSheet()->setCellValue('C1', '中文测试'); //设置Excel的字符集 $objPHPExcel->getActiveSheet() ->setTitle('PHPExcel Test Document') ->getComment('C1') ->setAuthor('PHPExcel') ->setText('Test document for PHPExcel, generated using PHP classes.') ->getText()->getFont() ->setColor(new PHPExcel_Style_Color(PHPExcel_Style_Color::COLOR_BLUE)) ->setBold(true) ->setSize(14) ->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE); //设置Excel的输出格式 header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename="test.xls"'); header('Cache-Control: max-age=0'); //将Excel文件输出到浏览器 $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output');
Dalam kod di atas, kami menetapkan fail Excel dengan memanggil kaedah. disediakan oleh objek PHPExcel untuk menetapkan sifat fail, kemudian tetapkan helaian semasa sebagai yang pertama dengan memanggil kaedah setActiveSheetIndex yang disediakan oleh objek PHPExcel, dan tulis data ke Excel dengan memanggil kaedah setCellValue. Seterusnya, kami mendapatkan helaian semasa dengan memanggil kaedah getActiveSheet, kemudian memanggil kaedah setTitle untuk menetapkan Tajuk fail, dan dapatkan ulasan sel semasa dengan memanggil kaedah getComment, dan gunakan kaedah setText untuk menetapkan nilai atribut untuk Harta fon ulasan dan set set aksara Excel. Akhir sekali, fail Excel dikeluarkan kepada penyemak imbas dengan memanggil kaedah pengepala.
Perkara di atas ialah penyelesaian kepada masalah aksara bercelaru bahasa Cina apabila memuat turun fail Excel dengan PHP Dengan menetapkan set aksara fail, kesan aksara bercelaru boleh dielakkan.
Atas ialah kandungan terperinci Bagaimana untuk menyelesaikan kod kacau Cina semasa memuat turun Excel dalam PHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Kompilasi JIT Php 8 meningkatkan prestasi dengan menyusun kod yang sering dilaksanakan ke dalam kod mesin, memberi manfaat kepada aplikasi dengan pengiraan berat dan mengurangkan masa pelaksanaan.

Artikel ini membincangkan mendapatkan muat naik fail PHP untuk mengelakkan kelemahan seperti suntikan kod. Ia memberi tumpuan kepada pengesahan jenis fail, penyimpanan selamat, dan pengendalian ralat untuk meningkatkan keselamatan aplikasi.

Artikel ini membincangkan kelemahan OWASP 10 dalam strategi PHP dan mitigasi. Isu -isu utama termasuk suntikan, pengesahan yang rosak, dan XSS, dengan alat yang disyorkan untuk memantau dan mendapatkan aplikasi PHP.

Artikel ini membincangkan penyulitan simetri dan asimetrik dalam PHP, membandingkan kesesuaian, prestasi, dan perbezaan keselamatan mereka. Penyulitan simetri lebih cepat dan sesuai untuk data pukal, manakala asimetrik digunakan untuk pertukaran utama yang selamat.

Artikel ini membincangkan pelaksanaan pengesahan dan kebenaran yang mantap dalam PHP untuk mencegah akses yang tidak dibenarkan, memperincikan amalan terbaik dan mengesyorkan alat peningkatan keselamatan.

Artikel membincangkan mendapatkan data dari pangkalan data menggunakan PHP, meliputi langkah, langkah keselamatan, teknik pengoptimuman, dan kesilapan umum dengan penyelesaian.

Artikel ini membincangkan strategi untuk melaksanakan kadar API yang mengehadkan PHP, termasuk algoritma seperti baldi token dan baldi bocor, dan menggunakan perpustakaan seperti simfoni/kadar-limiter. Ia juga meliputi pemantauan, had kadar penyesuaian secara dinamik, dan tangan

Artikel ini membincangkan strategi untuk mencegah serangan CSRF di PHP, termasuk menggunakan token CSRF, kuki tapak yang sama, dan pengurusan sesi yang betul.
