Как проверить, что входной поток stdin не пустой (php://stdin)
Можно например так:
1 2 3 4 |
if (posix_isatty(STDIN)){ die("--на входе дожен быть файл лога астры!"); }; $txt=file_get_contents('php://stdin','r'); |
Жизнь замечательных грибов
Здесь собраны статьи, наработки, исправление ошибок и решение проблем связанных с разработкой на языке PHP
Можно например так:
1 2 3 4 |
if (posix_isatty(STDIN)){ die("--на входе дожен быть файл лога астры!"); }; $txt=file_get_contents('php://stdin','r'); |
Иногда попадаются письма, которые не удается распарсить средствами модуля imap на php — вложения он упорно видит одним файлом winmail.dat . Это «подарок» от Microsoft Outlook, который когда пользователь выбирает тип письма RTF, не заморачиваясь завертывает в файл winmail.dat и письмо, и вложения и с письмом помимо заголовков отправляет только это вложение. А люди — которые не пользуются Outlook — по мнению Microsoft — это ваши проблемы 😉
Решение — использование консольной утилиты tnef. Например:
1 |
tnef -f /usr/local/www/apache24/ssl/data/pays/1/rpost/winmail.dat -C /usr/local/www/apache24/ssl/data/pays/1/rpost |
Штатно величину таймаута можно указать следующим образом:
1 2 3 4 5 6 7 |
$ctx = stream_context_create(array( 'http' => array( 'timeout' => 1 ) ) ); $lst= file_get_contents($external_adap,0,$ctx); |
Собрал в кучку полезные функции для работы с IP адресами, которые наиболее часто использую.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 |
/** * Конвертируем ip/mask в диапазон IP * 127.0.0.1/24 -> массив [0] 127.0.0.1 [1] 127.0.255.255 * @param type $net * @return type */ function cidrconv($net) { $start = strtok($net,"/"); $n = 3 - substr_count($net, "."); if ($n > 0) { for ($i = $n;$i > 0; $i--) $start .= ".0"; } $bits1 = str_pad(decbin(ip2long($start)), 32, "0", STR_PAD_LEFT); $net = (1 << (32 - substr(strstr($net, "/"), 1))) - 1; $bits2 = str_pad(decbin($net), 32, "0", STR_PAD_LEFT); $final = ""; for ($i = 0; $i < 32; $i++) { if ($bits1[$i] == $bits2[$i]) $final .= $bits1[$i]; if ($bits1[$i] == 1 and $bits2[$i] == 0) $final .= $bits1[$i]; if ($bits1[$i] == 0 and $bits2[$i] == 1) $final .= $bits2[$i]; } return array($start, long2ip(bindec($final))); } /** * Возвращает маску из IP вида 255.255.255.0 -> 24 * @param type $ip * @return type */ function ip2mask($ip){ $res=false; $intip=ip2long($ip); if ($intip>0){ $binstr=decbin($intip); $res= strpos($binstr,"0"); }; return $res; }; /** * Попадает ли ip в заданный диапазон * true - да, false - нет * Например: (10.0.1.3,10.0.0.0/8) -> true * @param type $ip * @param type $mask */ function ip_in_range($ip,$mask){ $res=false; $ipd=cidrconv($mask); $ip=ip2long($ip); $start=ip2long($ipd[0]); $end=ip2long($ipd[1]); if (($ip>=$start) and ($ip<=$end)){$res=true;}; return $res; }; /** * Возвращает true если IP белый, false если серый * @param type $ip */ function WhiteIP($ip){ $res=true; if (ip_in_range($ip,"10.0.0.0/8")==true){$res=false;}; if (ip_in_range($ip,"172.16.0.0/12")==true){$res=false;}; if (ip_in_range($ip,"192.168.0.0/16")==true){$res=false;}; return $res; }; |
Пример использования:
1 2 3 4 5 |
var_dump(cidrconv("10.0.0.0/8")); var_dump(ip2mask("255.255.255.0")); var_dump(ip_in_range("10.20.30.40","10.0.0.0/8")); var_dump(WhiteIP("172.16.40.11")); var_dump(WhiteIP("176.192.40.11")); |
Результат:
1 2 3 4 5 6 7 8 9 10 |
array(2) { [0]=> string(8) "10.0.0.0" [1]=> string(14) "10.255.255.255" } int(24) bool(true) bool(false) bool(true) |
Задача: по нажатию кнопки на странице, чтоб вызывался диалог сохранения файла и собственно сохранялся произвольный файл с сервера.
Решение:
В коде html страницы упоминаем скрытую форму:
1 2 3 |
<form method="post" action="inc/csvExport.php"> <input type="hidden" name="csvBuffer" id="csvBuffer" value="" /> </form> |
Добавляем туда же обработчик нажатия вида:
1 2 3 4 5 6 7 |
$("#viewwork").click(function(){ document.forms[0].method='POST'; document.forms[0].action=save_file.php; document.forms[0].target='_self'; document.forms[0].submit(); return false; }); |
Ну код на сервере для:
save_file.php:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
<?php // Данный код создан и распространяется по лицензии GPL v3 // Изначальный автор данного кода - Грибов Павел // http://грибовы.рф $ex= "1;2;3;4;5;6;7"; header("Content-type: application/msexcel"); header("Accept-Ranges: bytes"); header("Content-Length: " . strlen($ex)); header("Content-Disposition: attachment; filename=rep_by_addr.csv"); ?> |
csvExport.php:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
<?php // Данный код создан и распространяется по лицензии GPL v3 // Изначальный автор данного кода - Грибов Павел // http://грибовы.рф header('Content-type: application/vnd.ms-excel'); if (isset($_GET["csv"])==true){ header("Content-Disposition: attachment; filename=file.csv"); } else { header("Content-Disposition: attachment; filename=file.xls"); }; header("Pragma: no-cache"); $buffer = $_POST['csvBuffer']; try{ echo $buffer; }catch(Exception $e){ } ?> |