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

时间:2015-08-05 06:12:53

标签: php jquery ajax serialization import-from-excel

序列化表单数据

//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下载。 也有人可以请问我在这里做错了什么?

1 个答案:

答案 0 :(得分:0)

我认为你只需改变这一行:

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

到此:

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