I've read many articles in this site or other sites (Redirect with POST to application/csv without form, jQuery.post(), PHP and redirects, ... ) but without any valuable solutions. My problem is the following :
- in my site (html5, JQuery), there is a table. A feature of the site is to export the table as a csv file which will be available for download,
This feature is implemented as follow :
2.2 this JS redirect to a php service and pass as arguments the datas. The code is the following :
var url= jmcnet.request.getOrigin()+'/commons/php/dt_csv_export.php' ;
location.href = url+"?action=generate&csv_type=export_task&csv_data=" +encodeURIComponent(csv);
2.3 The php script format the input (csv_data parameter), write a temporay file and returns the content of the temporary file. The code is the following :
$h = @fopen($csv_file_name, 'w'); fputcsv($h, $csv_row, ',', '"'); fclose($h); // export file content to JS header('Content-Encoding: UTF-8'); header('Content-Type: text/ csv; charset =UTF-8'); header('Content-Disposition: attachment; filename=export-table.csv'); header(' Pragma: no-cache'); echo "\xEF\xBB\xBF"; // UTF-8 BOM readfile($csv_file_name);
2.4 The php file delete (unlink) the temporary file and exit,
My problem is that when the table is long, the URL called is not valid and the JS call to Php is down.
So, I imagine the 3 following solutions but no one is evident and all leads to other problems :
- S1 : dont do a GET but a POST in JS. So the size of the csv_data doesn't matter anymore. The problem is that I will have the content of the csv file in JS var after the call succeed and I don't know or find how to redirect to a page which content is in a JS var ? I guess I will lose all header information doing this.
- S2 : compress in JS the csv_data parameter and decompress it in Php. I just don't know how to do that and if it possible ....
- S3 : call the php with a POST. Modify the Php to return the URL of the temporary file, and do a redirect in JS to this temporay URL. The problems are that my Php must generate a file into a dir directly visible on the Internet, the file name must be unique and there is no way to simply delete the file after it has been read by browser (and I hate cron or what else).
I'm sure I'm not the first one to have this problem, so I need your help to see what is the best practice for this problem.