1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
<?php /* vim: set expandtab sw=4 ts=4 sts=4: */ /** * Provides download to a given field defined in parameters. * * @package PhpMyAdmin */
/** * Common functions. */ // we don't want the usual PMA_Response-generated HTML above the column's data define('PMA_BYPASS_GET_INSTANCE', 1); require_once 'libraries/common.inc.php'; require_once 'libraries/mime.lib.php';
/** * Sets globals from $_GET */ $get_params = array( 'where_clause', 'transform_key' );
foreach ($get_params as $one_get_param) { if (isset($_GET[$one_get_param])) { $GLOBALS[$one_get_param] = $_GET[$one_get_param]; } }
/* Check parameters */ PMA_Util::checkParameters( array('db', 'table', 'where_clause', 'transform_key') );
/* Select database */ if (!PMA_DBI_select_db($db)) { PMA_Util::mysqlDie( sprintf(__('\'%s\' database does not exist.'), htmlspecialchars($db)), '', '' ); }
/* Check if table exists */ if (!PMA_DBI_get_columns($db, $table)) { PMA_Util::mysqlDie(__('Invalid table name')); }
/* Grab data */ $sql = 'SELECT ' . PMA_Util::backquote($transform_key) . ' FROM ' . PMA_Util::backquote($table) . ' WHERE ' . $where_clause . ';'; $result = PMA_DBI_fetch_value($sql);
/* Check return code */ if ($result === false) { PMA_Util::mysqlDie(__('MySQL returned an empty result set (i.e. zero rows).'), $sql); }
/* Avoid corrupting data */ @ini_set('url_rewriter.tags', '');
PMA_downloadHeader( $table . '-' . $transform_key . '.bin', PMA_detectMIME($result), strlen($result) ); echo $result; ?>
|