Ответы пользователя по тегу PHP
  • Почему не работают прокси curl?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Скорее уж тогда так:
    global $proxy;
        $proxyRand = rand(0, count($proxy) - 1);
        $proxySplit = preg_split("~:~", $proxy[$proxyRand]);
        $proxyCheck = curl_init('https://yandex.ru');
        curl_setopt($proxyCheck, CURLOPT_RETURNTRANSFER, true);
        curl_setopt($proxyCheck, CURLOPT_SSL_VERIFYPEER, false);
        curl_setopt($proxyCheck, CURLOPT_HEADER, false);
        curl_setopt($proxyCheck, CURLOPT_FOLLOWLOCATION, true);
        curl_setopt($proxyCheck, CURLOPT_PROXY, $proxySplit[0]);
        curl_setopt($proxyCheck, CURLOPT_PROXYPORT, $proxySplit[1]);
        if (!empty($proxySplit[2]) AND !empty($proxySplit[3])) {
            curl_setopt($proxyCheck, CURLOPT_PROXYUSERPWD, $proxySplit[2].':'.$proxySplit[3]);
        }
        if (!$proxyCheckExec = curl_exec($proxyCheck)) {
            curl_close($proxyCheck);
            print("valid");
            die("Stopped");
            if (!empty($proxySplit[2]) AND !empty($proxySplit[3])) {
                return ['ip_port' => $proxySplit[0].':'.$proxySplit[1], 'user_pass' => $proxySplit[2].":".$proxySplit[3]];
            } else {
                return ['ip_port' => $proxySplit[0].':'.$proxySplit[1]];
            }
        }
        else {
            die(curl_error($proxyCheck));
        }
    Ответ написан
    Комментировать
  • Php Curl — как узнать Content Lenth отправляемого запроса?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Посмотрите функцию curl_getinfo().
    Скорее всего пригодится CURLINFO_HEADER_OUT, ну или CURLINFO_REQUEST_SIZE.
    Ответ написан
  • Почему не получается обработать $_GET запрос?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Проверяйте логи. По умолчанию web-север не пишет в свой лог-файл параметры HTTP-запросов.
    Там указывается только имя запущенного скрипта, но не GET/POST параметры.

    Самое простое: в скрипте первой строкой прописать: error_log(print_r($_GET, true));
    и смотреть в errorlog-е web-сервера сообщение с прилетевшими GET-параметрами.
    Видимо там чего-то вдруг не найдётся...
    Ответ написан
  • Обфускация php проекта?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    3 комментария
  • Почему данные не выводятся?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Так можно же показывать сообщения и об остальных ошибках MySQL:
    <?php
    
      // Соединиться с сервером БД
      mysql_connect("localhost", "admin", "pass") or die (mysql_error());
    
      // Выбрать БД
      mysql_select_db("db") or die(mysql_error());
      mysql_query("SET NAMES 'utf8'") or die (mysql_error());
    
      // SQL-запрос
      $strSQL = "SELECT * FROM sell";
    
      // Выполнить запрос (набор данных $rs содержит результат)
      $rs = mysql_query($strSQL) or die (mysql_error ());
    
      // Цикл по recordset $rs
      // Каждый ряд становится массивом ($row) с помощью функции mysql_fetch_array
      while($row = mysql_fetch_array($rs)) {
    
    
    
         echo '<div><div class="popular-box"><div class="title">' . $row["name"] . '<span>' . $row["description"] . '</span></div>';
         echo '<img src=">' . $row['img'] . '"';
         echo '<div class="price"' . $row['price'] . '</div>';
         echo '<a href="#modal-order" data-toggle="modal"><span class="pe-7s-cart"></span></a>';
      }
    
      // Закрыть соединение с БД
      mysql_close();
      ?>
    Ответ написан
    Комментировать
  • Почему полученые после SELECT строки, ведут себя так?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Прочитайте документацию. Перечитайте документацию. Поймите написанное в документации. Или вот:
    $arrayQuery = mysqli_fetch_all($query1, MYSQLI_ASSOC);
    var_dump($arrayQuery);
    Ответ написан
    Комментировать
  • Деобфускация php кода. Возможно ли?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Не можете декодировать HEX-строки в файле?
    <?php   file_put_contents(pathinfo($argv[1], PATHINFO_FILENAME).".out", preg_replace_callback("/\\\\x([0-9a-f]{2})/i", function ($a){return pack("H*" , $a[1]);}, file_get_contents($argv[1])));   ?>

    Сохранить в файл dehex.php, и запускать командой php -f dehex.php file_with_hex.txt.
    На что нужно заменить строку file_with_hex.txt - догадаетесь?
    А догадаетесь, что же теперь находится в появившемся файле file_with_hex.out?
    Ответ написан
    Комментировать
  • Функция PHP сохранила значение?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    <?php
    function test(){
        if (empty($GLOBALS['my_special_test_value'])) $GLOBALS['my_special_test_value'] = rand(1, 5);
        return $GLOBALS['my_special_test_value'];
    }
    ?>
    Ответ написан
    1 комментарий
  • Почему unlink не удаляет файл?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Самый тупой прямолинейный затратный по ресурсам способ, для проверки:
    echo(shell_exec("rm -f ".escapeshellcmd(__DIR__."/cookie_".$num["Id"].".txt")." 2>&1"));
    Ответ написан
    Комментировать
  • Не работает авторизация на php?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    В браузере в Web Developer Tools посмотри на вкладке Network, что же именно передаётся из формы логина на сервер, и что прилетает с сервера в ответ. Видимо там прилетает совсем _НЕ_ 'ok' в формате JSON.
    Ответ написан
    Комментировать
  • Почему в БД крокозябры?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Ой подозреваю, в PHP-скриптах после создания коннекта к базе данных прописано mysql_query("SET NAMES 'CP1251'");.
    Или другой вариант: mysqli_set_charset($db_connect, 'cp1251');.
    Вот ей-ей прописано...
    Ответ написан
  • Переадресация на заданную страницу с формы обратной связи. Как реализовать?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Ни на что, потому что это только текст типа "Спасибо большое!" внутри элемента <div> (который изначально скрыт).

    После удачной отправки данных из формы на сервер некий JavaScript, который выполнил отправку, делает этот элемент видимым, соответственно сообщение "появляется" в модальной форме.

    Вам нужно найти и поменять JavaScript, который отправляет, а затем меняет видимость. Прописать туда необходимый переход. Но чуствуется, сделать это вы не сможете, нужен опыт.
    Ответ написан
  • Как выполнить shell_exec, чтобы PHP не дожидался окончания системной команды?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    А попробуйте так:
    <?php
    $output = shell_exec('C:\Windows\system32\cmd.exe /c start Watch.bat '  . htmlspecialchars($_GET["name"]));
    ?>
    Ответ написан
  • Почему при запросе SQL через тело функции PHP получаю ошибку соединения?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Про область видимости переменных уже подсказали, внимательно изучайте.
    А что-бы было на чём осознать написанное в документации, вот ваш код (с простейшей защитой от SQL-иньекций, тоже стоит изучить):
    function sql_query($user_id) {
        global $connection;
        $query = "SELECT * FROM users WHERE id='".mysqli_real_escape_string($connection, $user_id)."'";
        if(!$query_result = mysqli_query($connection, $query)) {
                die('Query failed: '.mysqli_error($connection));
        } else {
                echo ('Complete');
        }
        return $query_result;
    }
    Ответ написан
    Комментировать
  • Как в PHP отсортировать такие элементы?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    <?php
    function my_sorting($in, $sort)
    {
        $tmp = array();
        foreach ($sort as $k => $v) $tmp[$k] = "";
        foreach ($in as $v) ($t = array_search($v, $sort)) !== false ? $tmp[$t] .= $v."\n" : $tmp[] = $v."\n";
        return implode("", $tmp);
    }
    
    $arr = array("Асфальт", "Карапуз", "Конфеты", "Пряники");
    var_dump(my_sorting($arr, array("Пряники", "Асфальт", "Конфеты")));
    Ответ написан
    Комментировать
  • Как последовательно получать данные с разных url и спользуя curl?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Должно быть так (смотрите на аргументы curl_exec() и curl_close()):
    $url_p = curl_init($url);
    curl_setopt_array($url_p, array(
          CURLOPT_HTTPHEADER => $arHeaderList,
          CURLOPT_FOLLOWLOCATION => true,
          CURLOPT_RETURNTRANSFER => true,
          ));
    $result1 = curl_exec($url_p);
    curl_close($url_p);
    Ответ написан
  • Не получается сделать защиту от SQL атак. Почему?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    И никакой проверки на валидность строки в $_SESSION['id']? И нет защиты от иньекции при выполнении SQL-запроса с INSERT-ом?
    Ответ написан
  • Можно ли исправить эту очень полезную функцию PHP?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Исходный вариант кода, но исправленный:
    $CONF = array('category' => array('name' => "Hello", 'data' => array()));
    
    function aGetByKey(&$array, $index, $value = null) {
        if (strpos($index, "."))
            list($index, $key) = explode('.', $index, 2);
        if (!isset($index) OR !isset($array[$index]))
            throw new Exception("No such key: " . $index);
    
        if(!empty($key))
            return aGetByKey($array[$index], $key, $value);
    
        $old = $array[$index];
        if ($value !== null)
            $array[$index] = $value;
    
        return $old;
    }
    
    function conf($key, $value = null) {
        global $CONF;
        return aGetByKey($CONF, $key, $value);
    }
    
    //Хотелось-бы чтобы она работала так:
    echo conf('category.name'); //Hello
    echo conf('category.name', 'World'); //Hello, потому что возвращается предыдущее значение $old
    echo conf('category.name'); // World
    
    conf('category.data', ['amount' => 158, 'kind' => 36]); // echo() нельзя, потому что вернётся массив
    echo conf('category.data')['amount']; //158
    Ответ написан
  • Как прочитать файл через `require` более одного раза?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Умеет. Это не require();, но для простого файла конфигурации - вполне достаточно.
    <?php
    file_put_contents("x2.php", "\$x=1;");
    eval(file_get_contents("x2.php"));
    var_dump($x);
    file_put_contents("x2.php", "\$x=2;");
    eval(file_get_contents("x2.php"));
    var_dump($x);
    ?>

    даст:
    int(1)
    int(2)

    Правда на входе eval() код должен быть без тегов <?php и ?> - но это уж сами решите, верно?
    Ответ написан
  • Как пропустить итерацию если команда вызывает ошибку PHP?

    @AUser0
    Чем больше знаю, тем лучше понимаю, как мало знаю.
    Плохо, плохо... Почему у вас в программировании всё так плохо?!

    ПРАВИЛЬНЫЙ вариант вашего кода:
    $sql_array = array();
    foreach($product['oc_product_description'] as $k => $v){
            $sql_array[] = "{$k} = ?";
    }
    $this->db->prepare("INSERT INTO oc_product_description SET ".implode(", ", $sql_array))->execute(array_values($product['oc_product_description']));
    unset($sql_array);


    Но если у вас действительно ЕСТЬ необходимость создавать столько записей (напрягитесь, осознайте далее написанное), сколько всего ПОЛЕЙ (ну типа там id,type,num,cost,category_id,sklad,etc) в таблице - тогда приведённый выше код нужно поменять. Но я сильно сомневаюсь, что вам нужна толпа записей вида:
    id=100
    id=100, type=tovar
    id=100, type=tovar, num=10
    id=100, type=tovar, num=10, cost=26.4
    id=100, type=tovar, num=10, cost=26.4, category_id=4
    id=100, type=tovar, num=10, cost=26.4, category_id=4, sklad=true
    id=100, type=tovar, num=10, cost=26.4, category_id=4, sklad=true, etc=...

    А именно так ваш код заполняет таблицу, дополняя запрос поле за полем, размножая записи как тараканов.

    Вердикт: Вы хоть вдумываетесь, что вы творите?!
    Ответ написан
    4 комментария