Быстрый поиск
Введите фрагмент названия статьи для поиска
Работа с недокументированными API WHM и cPanel
20.10.2008 | Категория: Web-мастеру и не только | Автор: ManHunter
cPanel является одной из самых популярных коммерческих панелей управления аккаунтами на серверах виртуального хостинга. Все действия выполняются обычно через web-интерфейс, но для использования в ваших проектах авторами предоставляется API. К сожалению вообще никакой вменяемой документации разработчикам не предоставляется. Эту позорную отмазку на официальном сайте назвать технической документацией трудно, поэтому при разработке очередного проекта пришлось создавать собственный класс для работы с cPanel. Попутно удалось реализовать несколько недокументированных функций и расширить функционал уже имеющихся.Code (PHP) : Убрать нумерацию
- <?
- // -------------------------------------------------------------
- // Класс для работы с WHM/cPanel через API
- // (C) ManHunter / PCL
- // http://www.manhunter.ru
- // -------------------------------------------------------------
- class cpanel_class {
- var $cpanelaccterr;
- var $host;
- var $user;
- var $accesshash;
- var $usessl;
- // -------------------------------------------------------------
- // Изменить пароль на аккаунте
- // Для выполнения нужна авторизация только с рутовым доступом
- // $chuser - аккаунт на сервере
- // $password - новый пароль
- // -------------------------------------------------------------
- function chgpassword ($chuser, $password) {
- if ($this->user!="root") {
- $this->cpanelaccterr="Root privileges required";
- return;
- }
- $result = $this->whmreq("/scripts/passwd?user=${chuser}&password=${password}&password2=${password}");
- $result=eregi_replace("[\n]{1,}","\n",strip_tags($result));
- if ($this->cpanelaccterr != "") { return; }
- if (strpos($result,"could not be changed")!==false) {
- $this->cpanelaccterr=$result;
- return;
- }
- return $result;
- }
- // -------------------------------------------------------------
- // Заблокировать аккаунт
- // $suspenduser - аккаунт на сервере
- // $reason - причина блокировки, сделано на перспективу,
- // фактически параметр панелью игнорируется
- // -------------------------------------------------------------
- function suspend ($suspenduser, $reason="") {
- $reason=str_replace(" ","+",$reason);
- $result = $this->whmreq("/scripts/remote_suspend?user=${suspenduser}&reason=${reason}");
- if ($this->cpanelaccterr != "") { return; }
- if (strpos($result,"Access Denied")!==false) {
- $this->cpanelaccterr=$result;
- return;
- }
- return $result;
- }
- // -------------------------------------------------------------
- // Разблокировать аккаунт
- // $unsuspenduser - аккаунт на сервере
- // -------------------------------------------------------------
- function unsuspend ($unsuspenduser) {
- $result = $this->whmreq("/scripts/remote_unsuspend?user=${unsuspenduser}");
- if ($this->cpanelaccterr != "") { return; }
- if (strpos($result,"Access Denied")!==false) {
- $this->cpanelaccterr=$result;
- return;
- }
- return $result;
- }
- // -------------------------------------------------------------
- // Удалить аккаунт
- // $killuser - аккаунт на сервере
- // -------------------------------------------------------------
- function killacct ($killuser) {
- $result = $this->whmreq("/scripts/killacct?user=${killuser}&nohtml=1");
- if ($this->cpanelaccterr != "") { return; }
- return $result;
- }
- // -------------------------------------------------------------
- // Показать версию WHM/cPanel
- // -------------------------------------------------------------
- function showversion () {
- $result = $this->whmreq("/scripts2/showversion");
- if ($this->cpanelaccterr != "") { return; }
- return $result;
- }
- // -------------------------------------------------------------
- // Перевести аккаунт на новый тарифный план
- // $upuser - аккаунт на сервере
- // $acctplan - новый тарифный план
- // -------------------------------------------------------------
- function update ($upuser, $acctplan) {
- $acctplan=str_replace(" ","+",$acctplan);
- $result = $this->whmreq("/scripts2/upacct?user=${upuser}&pkg=${acctplan}");
- if ($this->cpanelaccterr != "") { return; }
- return $result;
- }
- // -------------------------------------------------------------
- // Открыть новый аккаунт
- // $acctdomain - домен
- // $acctuser - логин для аккаунта
- // $acctpass - пароль для аккаунта
- // $acctplan - тарифный план
- // $accemail - контактный email аккаунта
- // $acccpmod - стиль cPanel по умолчанию
- // -------------------------------------------------------------
- function createacct ($acctdomain, $acctuser, $acctpass, $acctplan, $accemail,
- $acccpmod="bluelagoon") {
- if (!eregi("^[-a-z0-9\.]{4,}$",$acctdomain)) {
- $this->cpanelaccterr="Invalid domain name";
- return;
- }
- $acctplan=str_replace(" ","+",$acctplan);
- $accemail=str_replace("@","%40",$accemail);
- $result = $this->whmreq("/scripts/wwwacct?remote=1&nohtml=1&username=${acctuser}&password=${acctpass}&domain=${acctdomain}&plan=${acctplan}&contactemail=${accemail}&cpmod=${acccpmod}");
- if ($this->cpanelaccterr != "") { return; }
- return $result;
- }
- // -------------------------------------------------------------
- // Показать список имеющихся на сервере аккаунтов
- // -------------------------------------------------------------
- function listaccts () {
- $result = $this->whmreq("/scripts2/listaccts?nohtml=1&viewall=1");
- if ($this->cpanelaccterr != "") { return; }
- $page = split("\n",$result);
- foreach ($page as $line) {
- list($acct,$contents) = split("=", $line);
- if ($acct != "") {
- $allc = split(",", $contents);
- $accts[$acct] = $allc;
- }
- }
- return($accts);
- }
- // -------------------------------------------------------------
- // Показать список заведенных на сервере тарифных планов
- // -------------------------------------------------------------
- function listpkgs () {
- $result = $this->whmreq("/scripts/remote_listpkg");
- if ($this->cpanelaccterr != "") { return; }
- $page = split("\n",$result);
- foreach ($page as $line) {
- list($pkg,$contents) = split("=", $line);
- if ($pkg != "") {
- $allc = split(",", $contents);
- $pkgs[$pkg] = $allc;
- }
- }
- return($pkgs);
- }
- // -------------------------------------------------------------
- // Запрос к WHM/cPanel. Используется только для работы внутри
- // класса, извне вызываться не должен
- // -------------------------------------------------------------
- function whmreq ($request) {
- $cleanaccesshash = preg_replace("'(\r|\n)'","",$this->accesshash);
- $authstr = $this->user . ":" . $cleanaccesshash;
- $this->cpanelaccterr = "";
- if (function_exists("curl_init")) {
- $ch = curl_init();
- if ($this->usessl) {
- curl_setopt($ch, CURLOPT_SSL_VERIFYPEER,0);
- curl_setopt($ch, CURLOPT_SSL_VERIFYHOST,0);
- curl_setopt($ch, CURLOPT_URL, "https://".$this->host.":2087" . $request);
- }
- else {
- curl_setopt($ch, CURLOPT_URL, "http://".$this->host.":2086" . $request);
- }
- curl_setopt($ch, CURLOPT_HEADER, 0);
- curl_setopt($ch, CURLOPT_RETURNTRANSFER,1);
- $curlheaders[0] = "Authorization: WHM $authstr";
- curl_setopt($ch,CURLOPT_HTTPHEADER,$curlheaders);
- $data=curl_exec ($ch);
- curl_close ($ch);
- }
- elseif (function_exists("socket_create")) {
- if ($this->usessl) {
- $this->cpanelaccterr = "SSL Support requires curl";
- return;
- }
- $service_port = 2086;
- $address = gethostbyname($this->host);
- $socket = socket_create (AF_INET, SOCK_STREAM, 0);
- if ($socket < 0) {
- $this->cpanelaccterr = "socket_create() failed";
- return;
- }
- $result = socket_connect ($socket, $address, $service_port);
- if ($result < 0) {
- $this->cpanelaccterr = "socket_connect() failed";
- return;
- }
- $in = "GET $request HTTP/1.0\n";
- socket_write($socket,$in,strlen($in));
- $in = "Connection: close\n";
- socket_write($socket,$in,strlen($in));
- $in = "Authorization: WHM $authstr\n\n\n";
- socket_write($socket,$in,strlen($in));
- $inheader = 1;
- while(($buf = socket_read($socket, 512)) != false) {
- if (!$inheader) {
- $data .= $buf;
- }
- if (preg_match("'\r\n\r\n$'s", $buf)) {
- $inheader = 0;
- }
- if (preg_match("'\n\n$'s", $buf)) {
- $inheader = 0;
- }
- if (preg_match("'\r\n$'s", $buf)) {
- $inheader = 0;
- }
- }
- }
- else {
- $this->cpanelaccterr = "php not compiled with --enable-sockets OR curl";
- return;
- }
- return $data;
- }
- }
- ?>
Читать статью целиком »
Просмотров: 7810 | Комментариев: 9
Проверка похожести двух слов
11.10.2008 | Категория: Web-мастеру и не только | Автор: ManHunter
Точное сравнение двух символьных строк, даже регистронезависимое, выполнить нетрудно. А как быть, если в одной их них встречаются символы другого алфавита, похожие по написанию? Так, буква "E" в русской и английской раскладке имеет одинаковое написание, или вместо русской "Н(н)" можно написать английскую "H(h)". Этим могут воспользоваться всякие ублюдки, например оставить сообщение на форуме якобы от администрации, зарегистрировав ник, внешне похожий на ник одного из админов. Для проверки похожести двух строк я использую следующую функцию:Code (PHP) : Убрать нумерацию
- // -----------------------------------------------------
- // Функция проверки похожести двух слов
- // Параметры: $name1 и $name2 - слова для проверки
- // $register = TRUE - проверка регистронезависима
- // = FALSE - проверка с учетом регистра
- // На выходе: TRUE - слова похожи, FALSE - отличаются
- // -----------------------------------------------------
- function chk_similarity($word1, $word2, $register=false) {
- // Очистить слова от служебных символов
- $word1=eregi_replace("[^0-9a-zа-я]","",$word1);
- $word2=eregi_replace("[^0-9a-zа-я]","",$word2);
- // Возврат FALSE если длина слов различается
- // или хотя бы одно из них пустое
- if ((strlen($word1)!==strlen($word2)) || strlen($word1)*strlen($word2)==0) {
- return false;
- }
- // Заполнить таблицу соответствий
- $pattern1="";
- $pattern2=Array();
- $pattern1.="aа";
- $pattern2[]="[аa]";
- $pattern2[]="[аa]";
- $pattern1.="AА";
- $pattern2[]="[АA]";
- $pattern2[]="[АA]";
- $pattern1.="BВ";
- $pattern2[]="[BВ]";
- $pattern2[]="[BВ]";
- $pattern1.="bь";
- $pattern2[]="[bь]";
- $pattern2[]="[bь]";
- $pattern1.="cс";
- $pattern2[]="[cс]";
- $pattern2[]="[cс]";
- $pattern1.="CС";
- $pattern2[]="[CС]";
- $pattern2[]="[CС]";
- $pattern1.="eе";
- $pattern2[]="[eе]";
- $pattern2[]="[eе]";
- $pattern1.="EЕ";
- $pattern2[]="[EЕ]";
- $pattern2[]="[EЕ]";
- $pattern1.="HН";
- $pattern2[]="[HН]";
- $pattern2[]="[HН]";
- $pattern1.="iI1l";
- $pattern2[]="[iI1l]";
- $pattern2[]="[iI1l]";
- $pattern2[]="[iI1l]";
- $pattern2[]="[iI1l]";
- $pattern1.="kк";
- $pattern2[]="[kк]";
- $pattern2[]="[kк]";
- $pattern1.="KК";
- $pattern2[]="[KК]";
- $pattern2[]="[KК]";
- $pattern1.="MМ";
- $pattern2[]="[MМ]";
- $pattern2[]="[MМ]";
- $pattern1.="nп";
- $pattern2[]="[nп]";
- $pattern2[]="[nп]";
- $pattern1.="oо0";
- $pattern2[]="[oо0]";
- $pattern2[]="[oо0]";
- $pattern2[]="[oо0]";
- $pattern1.="OО0";
- $pattern2[]="[OО0]";
- $pattern2[]="[OО0]";
- $pattern2[]="[OО0]";
- $pattern1.="pр";
- $pattern2[]="[pр]";
- $pattern2[]="[pр]";
- $pattern1.="PР";
- $pattern2[]="[PР]";
- $pattern2[]="[PР]";
- $pattern1.="rг";
- $pattern2[]="[rг]";
- $pattern2[]="[rг]";
- $pattern1.="TТ";
- $pattern2[]="[TТ]";
- $pattern2[]="[TТ]";
- $pattern1.="uи";
- $pattern2[]="[uи]";
- $pattern2[]="[uи]";
- $pattern1.="xх";
- $pattern2[]="[xх]";
- $pattern2[]="[xх]";
- $pattern1.="XХ";
- $pattern2[]="[XХ]";
- $pattern2[]="[XХ]";
- $pattern1.="yу";
- $pattern2[]="[yу]";
- $pattern2[]="[yу]";
- $pattern1.="YУ";
- $pattern2[]="[YУ]";
- $pattern2[]="[YУ]";
- $pattern1.="З3";
- $pattern2[]="[З3]";
- $pattern2[]="[З3]";
- $pattern1.="ч4";
- $pattern2[]="[ч4]";
- $pattern2[]="[ч4]";
- $pattern1.="Ч4";
- $pattern2[]="[Ч4]";
- $pattern2[]="[Ч4]";
- // Составить регулярное выражение для проверки
- $tmp="^";
- for ($i=0; $i<strlen($word1); $i++) {
- $letter=$word1[$i];
- $pos=strpos($pattern1,$letter);
- if ($pos===false) {
- $tmp.=$letter;
- }
- else {
- $tmp.=$pattern2[$pos];
- }
- }
- $tmp.="$";
- // Возврат TRUE - слова похожи или равны
- // FALSE - слова отличаются
- return($register?eregi($tmp,$word2):ereg($tmp,$word2));
- }
Читать статью целиком »
Просмотров: 4886 | Комментариев: 14
Защита PHP-скриптов от анализа и модификации
06.10.2008 | Категория: Web-мастеру и не только | Автор: ManHunter
Все программные продукты для защиты PHP-скриптов подразделяются на две категории: требующие установки на сервер дополнительных модулей и работающие с обычной конфигурацией web-серверов. Первые более надежны в плане безопасности, так как переводят PHP-скрипты из текстового вида в специальный байт-код, но требуют доступа к серверу с правами администратора. Вторые могут работать практически на всех хостингах с поддержкой PHP, в том числе и бесплатных, но не представляют большой сложности для взлома. В отдельную подгруппу можно выделить обфускаторы исходного кода, не использующие шифрование или сжатие.Защиты на уровне сервера:
Zend Encoder / Zend SafeGuard Suite - наиболее популярная коммерческая защита, модули для поддержки Zend обычно установлены на всех платных хостингах. Zend предоставляет привязку скриптов к доменам и ip, установку времени триальной работы скриптов и мощную обфускацию. Поддерживаются все операционные системы. В публичном доступе имеется несколько вариантов утилит для снятия Zend'а, все они представляют собой модифицированный PHP 4-й и 5-й версии. Старые версии Zend'а снимаются без проблем, в последних возникают сложности из-за обфускации исходного кода.
NuSphere NuCoder. Новая, активно развивающаяся коммерческая защита. На уровне собственных API предоставляет взаимодействие с защищаемыми скриптами, поддерживаются операционные системы Windows и Linux. Вследствие малой распространенности не устанавливается на обычных виртуальных хостингах, но вполне может быть установлена пользователями на выделенных серверах. Публичных декодеров нет.
SourceGuardian for PHP. Коммерческая защита, практически не встречается, на виртуальных хостингах не устанавливается. Позволяет устанавливать триальный срок работы скриптов с проверкой даты по внешним серверам точного времени, делать привязку защищаемых скриптов к серверам, ip-адресу, MAC-адресу сетевой карты, причем эти данные используются для расшифровки. Поддерживаются все операционные системы. Публичных декодеров нет.
Читать статью целиком »
Просмотров: 41515 | Комментариев: 36
Подсчет времени генерации страницы сайта
25.09.2008 | Категория: Web-мастеру и не только | Автор: ManHunter
Очевидно, что время генерации страницы - это разница от момента обработки первой строчки скрипта до момента обработки последней строчки. Для его расчета точности функции time() недостаточно, так как ее шаг равен 1 секунде. Страница же на сервере обычно генерируется за меньшее время. Если это не так, то стоит всерьез озадачиться оптимизацией вашего кода или сменой хостинг-провайдера. Для замеров более коротких интервалов времени в PHP существует функция microtime(). Она возвращает в виде строки текущее время с микросекундами, например:0.57975400 1222376863
Значит для подсчета времени требуется получить значения microtime() в начале и конце работы скрипта и отобразить разницу между ними. Для выделения из строки числовых значений воспользуемся функцией explode().
Code (PHP) : Убрать нумерацию
- <?
- // Начало скрипта
- // Получаем текущее время с микросекундами
- $mtime=explode(" ",microtime());
- // После выполнения команды explode() массив $mtime содержит значения:
- // $mtime[0] - микросекунды, $mtime[1] - секунды
- $tstart=$mtime[1]+$mtime[0]; // Засекаем начальное время
- ...
- ...
- // Основной код скрипта
- ...
- ...
- // Получаем текущее время с микросекундами
- $mtime=explode(" ",microtime());
- // Уже знакомая нам функция explode()
- $tend=$mtime[1]+$mtime[0]; // Засекаем конечное время
- // Округляем до двух знаков после запятой
- $totaltime=round(($tend-$tstart),2);
- // Результат на экран
- echo "Время генерации страницы: ".$totaltime." сек.";
- // Конец скрипта
- ?>
Читать статью целиком »
Просмотров: 8793 | Комментариев: 5
Сейчас на сайте 2 гостей и 3 новостей
23.09.2008 | Категория: Web-мастеру и не только | Автор: ManHunter
Смешно звучит, правда? А ведь такие уродливые сочетания встречаются на очень многих сайтах. И если в английском языке достаточно написать что-то типа day(s), byte(s) и это будет смотреться вполне нормально, то в русском языке в конструкциях "число + слово" обязательно придется учитывать склонения. Безумные извраты типа "гостя(ей)" и "новость(ей)" я даже не рассматриваю, за такое надо лишать доступа к компьютеру навсегда.Чтобы писать по-русски на своих сайтах я использую такую универсальную функцию:
Code (PHP) : Убрать нумерацию
- function num2word($num,$words) {
- $num=$num%100;
- if ($num>19) { $num=$num%10; }
- switch ($num) {
- case 1: { return($words[0]); }
- case 2:
- case 3:
- case 4: { return($words[1]); }
- default: { return($words[2]); }
- }
- }
Читать статью целиком »
Просмотров: 5833 | Комментариев: 13