javascript - 单击按钮下载 Excel (phpExcel)
问题描述
我仅在收到 $ _POST 参数时才尝试使用 phpExcel 库下载 Excel。
目前我有一个名为 my-information.php 的文件,其中有一个表格和一个执行此功能的按钮:
async function download_excel() {
let myHeaders = new Headers();
myHeaders.append("Cookie", "___asdadsadwqfqefqefqeeqasadsadsadasdsadas");
var formdata = new FormData();
formdata.append("generate_xlsx", 1);
let requestOptions = {
method: 'GET',
headers: myHeaders,
body: formdata,
redirect: 'follow'
};
await fetch("<?= plugin_dir_url(__FILE__) ?>my-file-generator.php", requestOptions)
.then(response => response.text())
.then(result => console.log(result))
.catch(err => console.log(err))
}
在我的 my-file-generator.php 文件中,我有以下代码:
if (isset($_POST) && isset($_POST['generate_xlsx'])) {
require_once '../../../../../wp-blog-header.php';
require_once plugin_dir_path(__FILE__) . 'PHPExcel.php';
require_once plugin_dir_path(__FILE__) . 'PHPExcel/Writer/Excel2007.php';
$data = generate_data_for_xslx();
// Create new PHPExcel object
$objPHPExcel = new PHPExcel();
$objPHPExcel->getProperties()->setTitle(esc_html__('Test xlsx document', 'woocommerce'));
$objPHPExcel->getProperties()->setSubject(esc_html__('Test xlsx document', 'woocommerce'));
$objPHPExcel->getProperties()->setDescription(esc_html__('Test export users document for XLSX, generated using PHP classes.', 'woocommerce'));
$objPHPExcel->getActiveSheet()->SetCellValue('A1', esc_html__('User Login', 'woocommerce'));
$cell_counter = 1;
$objPHPExcel->setActiveSheetIndex(0);
for ($i = 0; $i < count($data); $i++) {
$cell_counter++;
$objPHPExcel->getActiveSheet()->SetCellValue('A' . $cell_counter, $data[$i]['user_login']);
}
// Rename sheet
$objPHPExcel->getActiveSheet()->setTitle(esc_html__('Users', 'woocommerce'));
$objWriter = new PHPExcel_Writer_Excel2007($objPHPExcel);
header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
header('Content-Type: application/vnd.ms-excel');
header('Content-Disposition: attachment;filename="usuarios.xlsx"');
header('Cache-Control: max-age=0');
// Save Excel file
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
ob_end_clean();
$objWriter->save('php://output');
exit();
}
这样文件不会运行,也不会下载 Excel 文档。但是,如果我复制条件内的代码并将其粘贴到 my-information.php 文件中,它会在打开页面时完美执行。
我尝试在 my-information.php 文件中添加完整的条件并获取相同的文件,但它也不起作用,控制台给了我这个错误。显然问题是使用 $ _POST 参数来做到这一点:
XHR POST https://example.com/wp-content/plugins/generateReporte/src/includes/my-file-generator.php [HTTP/1.1 404 Not Found 7578ms]
PK��������z%jQG�D�X�����������[Content_Types].xml��MN�0����"��%nY ��vAa �(�0����ؖg�w{&i���@�nbE�{��y��d۸l
m��������X�(���)�����F���;@1�_������c)j�x/%����E��y�
�QĿi!��K��y3��J�<���Z�1��0?Y��L%zV
c��Ib7�������a/l٥P1:��q�r���j���j0A������u�"��"����(� �����W�M��)Tj�({ܲ�>���O���,X٭���>B��~����Ӥ6�J=�oBZ����t��X4���Cg�,���Qg��mr�L����ٯc�e��t�� Z�?����hPv��±���u�j���R������}�Cv����PK��������z%jQ��78����K�������_rels/.rels���j�0���{
�{���1F�^ʠ�2���l�$���-}�y�����Î��O��v�y��;�؋Ӱ.JP���^������Y�ű�3G�Ww�g�)���>��qQC���D���b!�]�i$L��3�����2n����o�T��:Z
�h����[��4�ი��]���yN�,ە��>�>��j
-'
V�)�#��EF�^6��n���8q"K��H��>_�ׄ����eƏ�<⇄�Ud�v��
T�PK��������z%jQ�$�V������������xl/_rels/workbook.xml.rels���j�0�D��
��ZvZJ)�s)�\[�����LlIh7m��U�H�����Ĭؙ�H���8�OL����*J��M����|4��g���[=��
&$��w�7�4��r}$�M<)p��EJ2�GME���M�Ҩ9��ɨ�^w(We�$�����O��
我只需要在单击按钮时使文件生成和下载,我尝试了很多方法都无法做到,请您帮帮我。
解决方案
有了这条线:
if (isset($_POST) && isset($_POST['generate_xlsx'])) {
您只是在检查该字段是否存在。要检查它是否已被单击,请尝试将其替换为以下内容:
if ( isset( $_POST['generate_xlsx'] ) && $_POST['generate_xlsx'] == 'yes' ) {
推荐阅读
- html - Href链接问题
- mysql - 来自 mysql 数据库的数据透视表 MySQL
- javascript - Javascript 使用“多个”属性附加输入
- microsoft-dynamics - Dynamics 365 Online 与本地解决方案导出
- assembly - 二元炸弹实验室第 9 阶段 - 卡住了
- bash - 在 shell 脚本中使用 sed 向文件中添加一行
- sap-cloud-platform - SCP Neo 部署 - java.lang.IllegalStateException: org.apache.catalina.LifecycleException: 无法启动组件
- git - 如何访问并提交到 github 上的远程分支
- vb.net - DataAdapter 不使用填充方法打开连接本身
- ios - AWS Cognito 用户组未显示