0
我想在下面給出的函數中設置SQL格式的數據庫備份文件的下載文件路徑。每當我嘗試這個功能,將文件下載到我的本地計算機上的下載文件夾,但我想將它下載到指定的目錄我的服務器上,而不是:在CakePHP中設置下載數據庫備份的文件路徑
function admin_database_mysql_dump($tables = '*') {
ini_set('memory_limit', '1024M');
set_time_limit(0);
$return = '';
$modelName = $this->modelClass;
$dataSource = $this->{$modelName}->getDataSource();
$databaseName = $dataSource->getSchemaName();
// Do a short header
$return .= '-- Database: `' . $databaseName . '`' . "\n";
$return .= '-- Generation time: ' . date('D jS M Y H:i:s') . "\n\n\n";
if ($tables == '*') {
$tables = array();
$result = $this->{$modelName}->query('SHOW TABLES');
foreach($result as $resultKey => $resultValue){
$tables[] = current($resultValue['TABLE_NAMES']);
}
} else {
$tables = is_array($tables) ? $tables : explode(',', $tables);
}
// Run through all the tables
foreach ($tables as $table) {
$tableData = $this->{$modelName}->query('SELECT * FROM ' . $table);
$return .= 'DROP TABLE IF EXISTS ' . $table . ';';
$createTableResult = $this->{$modelName}->query('SHOW CREATE TABLE ' . $table);
$createTableEntry = current(current($createTableResult));
$return .= "\n\n" . $createTableEntry['Create Table'] . ";\n\n";
// Output the table data
foreach($tableData as $tableDataIndex => $tableDataDetails) {
$return .= 'INSERT INTO ' . $table . ' VALUES(';
foreach($tableDataDetails[$table] as $dataKey => $dataValue) {
if(is_null($dataValue)){
$escapedDataValue = 'NULL';
}
else {
// Convert the encoding
$escapedDataValue = mb_convert_encoding($dataValue, "UTF-8", "ISO-8859-1");
// Escape any apostrophes using the datasource of the model.
$escapedDataValue = $this->{$modelName}->getDataSource()->value($escapedDataValue);
}
$tableDataDetails[$table][$dataKey] = $escapedDataValue;
}
$return .= implode(',', $tableDataDetails[$table]);
$return .= ");\n";
}
$return .= "\n\n\n";
}
// Set the default file name
$fileName = $databaseName . '-backup-' . date('Y-m-d_H-i-s') . '.sql';
// Serve the file as a download
$this->autoRender = false;
$this->response->type('Content-Type: text/x-sql');
$this->response->download($fileName);
$this->response->body($return);
}
你希望它是在服務器本身? – Abhishek
我只想將下載位置更改爲我的其他目錄而不是下載文件夾(默認) – tarun
從瀏覽器保存文件的位置基於瀏覽器本身 – Abhishek