PHP - 序列化表单数据并启动 Excel 下载

PHP - Serialize form data and initiate Excel download

序列化表单数据

//start excel download
$("#btn_excel").click(function(){

        var str = $("#my-form").serialize();
        window.location.href = SITE_URL+"somecontroller/someAction?form_data="+str;
    });
//end excel download

查询字符串生成

start_date=1-Jul-15&end_date=1-Aug-15&id=11&description=My+Description&project_name_selected=Amazon+AWS

为了获取输出,我在下面使用了但是这不起作用

parse_str($_GET['form_data'], $output);
print_r($output);

输出

Array
(
    [form_data] => start_date=1-Jul-15
    [end_date] => 1-Aug-15
    [id] => 11
    [description] => My Description
    [project_name_selected] => Amazon+AWS
)

如您所见,查询字符串已损坏,无法正确获取数据。

已在下面尝试过,但这行不通,因为我需要通过 Ajax 启动下载;作为正常的 Ajax 响应,响应将完全消失在以太中。

$.post(SITE_URL+"somecontroller/someAction",str, function( data ) {
});

我直接将浏览器指向资源,它会自动检测到它是要下载的文件,并开始下载。

我应该如何传递序列化表单数据并获取输出以启动 Excel 下载。 还有谁能解释一下我在这里做错了什么吗?

我认为你只需要更改这一行:

window.location.href = SITE_URL+"somecontroller/someAction?form_data="+str;

对此:

window.location.href = SITE_URL+"somecontroller/someAction?"+str;