chengsc
2024-07-23 f575652587d4160ab42e75acb2bc26b4f60fb7c3
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
<?php
$page = isset($_POST['page']) ? $_POST['page'] : 1;
$rp = isset($_POST['rp']) ? $_POST['rp'] : 10;
$sortname = isset($_POST['sortname']) ? $_POST['sortname'] : 'name';
$sortorder = isset($_POST['sortorder']) ? $_POST['sortorder'] : 'desc';
$query = isset($_POST['query']) ? $_POST['query'] : false;
$qtype = isset($_POST['qtype']) ? $_POST['qtype'] : false;
 
/* -- To use the SQL, remove this block
$usingSQL = true;
function runSQL($rsql) {
 
    $db['default']['hostname'] = "localhost";
    $db['default']['username'] = '';
    $db['default']['password'] = "";
    $db['default']['database'] = "";
 
    $db['live']['hostname'] = 'localhost';
    $db['live']['username'] = '';
    $db['live']['password'] = '';
    $db['live']['database'] = '';
 
    $active_group = 'default';
 
    $base_url = "http://".$_SERVER['HTTP_HOST'];
    $base_url .= str_replace(basename($_SERVER['SCRIPT_NAME']),"",$_SERVER['SCRIPT_NAME']);
 
    $connect = mysql_connect($db[$active_group]['hostname'],$db[$active_group]['username'],$db[$active_group]['password']) or die ("Error: could not connect to database");
    $db = mysql_select_db($db[$active_group]['database']);
 
    $result = mysql_query($rsql) or die ('test');
    return $result;
    mysql_close($connect);
}
 
function countRec($fname,$tname) {
    $sql = "SELECT count($fname) FROM $tname ";
    $result = runSQL($sql);
    while ($row = mysql_fetch_array($result)) {
        return $row[0];
    }
}
$page = $_POST['page'];
$rp = $_POST['rp'];
$sortname = $_POST['sortname'];
$sortorder = $_POST['sortorder'];
 
if (!$sortname) $sortname = 'name';
if (!$sortorder) $sortorder = 'desc';
 
$sort = "ORDER BY $sortname $sortorder";
 
if (!$page) $page = 1;
if (!$rp) $rp = 10;
 
$start = (($page-1) * $rp);
 
$limit = "LIMIT $start, $rp";
$where = "";
if ($query) $where = " WHERE $qtype LIKE '%".mysql_real_escape_string($query)."%' ";
 
$sql = "SELECT iso,name,printable_name,iso3,numcode FROM country $where $sort $limit";
$result = runSQL($sql);
 
$total = countRec('iso','country');
$rows = array();
while ($row = mysql_fetch_array($result)) {
    $rows[] = $row;
}
*/
if(!isset($usingSQL)){
    include dirname(__FILE__).'/countryArray.inc.php';
    if($qtype && $query){
        $query = strtolower(trim($query));
        foreach($rows AS $key => $row){
            if(strpos(strtolower($row[$qtype]),$query) === false){
                unset($rows[$key]);
            }
        }
    }
    //Make PHP handle the sorting
    $sortArray = array();
    foreach($rows AS $key => $row){
        $sortArray[$key] = $row[$sortname];
    }
    $sortMethod = SORT_ASC;
    if($sortorder == 'desc'){
        $sortMethod = SORT_DESC;
    }
    array_multisort($sortArray, $sortMethod, $rows);
    $total = count($rows);
    $rows = array_slice($rows,($page-1)*$rp,$rp);
}
 
header("Content-type: text/xml");
$xml = "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n";
$xml .= "<rows>";
$xml .= "<page>$page</page>";
$xml .= "<total>$total</total>";
foreach($rows AS $row){
    $xml .= "<row id='".$row['iso']."'>";
    $xml .= "<cell><![CDATA[".$row['iso']."]]></cell>";
    $xml .= "<cell><![CDATA[".utf8_encode($row['name'])."]]></cell>";
    //$xml .= "<cell><![CDATA[".print_r($_POST,true)."]]></cell>";
    $xml .= "<cell><![CDATA[".utf8_encode($row['printable_name'])."]]></cell>";
    $xml .= "<cell><![CDATA[".utf8_encode($row['iso3'])."]]></cell>";
    $xml .= "<cell><![CDATA[".utf8_encode($row['numcode'])."]]></cell>";
    $xml .= "</row>";
}
 
$xml .= "</rows>";
echo $xml;