jQuery を使用してボタンのクリックを認識し、ファイルへの呼び出しを開始します。
window.location.href = "url";
このファイルはデータベースにクエリを実行し、結果を返し、それを CSV ファイルに書き込みます。次のヘッダーが設定されています。
header('Content-Type: text/csv;');
header('Content-Disposition: attachment; filename=data.csv');
これは、コンソール ログに次のエラーを返す Chrome を除くすべてのブラウザーで機能します。
奇妙なことに、ファイルを直接呼び出すと、すべてのブラウザーで機能します。
コード:
$fp = fopen('php://output', 'w');
header('Content-Type: text/csv;');
header('Content-Disposition: attachment; filename=data.csv');
header("Expires: 0");
header("Cache-control: private");
//Field Headers
$ncols = oci_num_fields($stid);
$headers_row = array();
for ($i = 1; $i <= $ncols; ++$i) {
$headers_row[] = oci_field_name($stid, $i);
}
while ($row = oci_fetch_array($stid, OCI_NUM+OCI_RETURN_NULLS)) {
if(!empty($row)){
if(!empty($headers_row)){
fputcsv($fp, $headers_row);
$headers_row = '';
}
fputcsv($fp, $row);
}
}
fclose($fp);
oci_close($conn);
誰でもアイデアはありますか?