Ответы пользователя по тегу PHP
  • Как установить php 8.2 на ubuntu 18.04?

    sharp97
    @sharp97
    не фонтан но брызги есть
    пацаны, просто ставьте новую версию ubuntu - это решение которое помогло мне
    Ответ написан
    Комментировать
  • Как избавится от goto в этом примере кода?

    sharp97
    @sharp97
    не фонтан но брызги есть
    Для избавления от оператора goto в этом коде, вы можете использовать структуры данных, такие как циклы for и foreach, а также условные операторы if. Вот как вы можете переписать код без использования goto:
    тык

    static function startTranscoding($streamId) {
        $streamInfo = array();
        self::$ipTV_db->query("SELECT * FROM `streams` t1 INNER JOIN `streams_types` t2 ON t2.type_id = t1.type AND t2.live = 0 LEFT JOIN `transcoding_profiles` t4 ON t1.transcode_profile_id = t4.profile_id WHERE t1.direct_source = 0 AND t1.id = '%d'", $streamId);
    
        if (self::$ipTV_db->d1E5CE3B87bB868b9e6Efd39AA355A4F() <= 0) {
            return false;
        }
    
        $streamInfo["stream_info"] = self::$ipTV_db->f1ed191d78470660eDfF4A007696bc1f();
        $targetContainer = json_decode($streamInfo["stream_info"]["target_container"], true);
    
        if (json_last_error() === JSON_ERROR_NONE) {
            $streamInfo["stream_info"]["target_container"] = $targetContainer;
        } else {
            $streamInfo["stream_info"]["target_container"] = array($streamInfo["stream_info"]["target_container"]);
        }
    
        self::$ipTV_db->query("SELECT * FROM `streams_sys` WHERE stream_id  = '%d' AND `server_id` = '%d'", $streamId, SERVER_ID);
    
        if (self::$ipTV_db->D1E5cE3B87bb868B9E6EfD39Aa355a4F() <= 0) {
            return false;
        }
    
        $streamInfo["server_info"] = self::$ipTV_db->f1ed191D78470660EDFF4a007696BC1f();
        self::$ipTV_db->query("SELECT t1.*, t2.* FROM `streams_options` t1, `streams_arguments` t2 WHERE t1.stream_id = '%d' AND t1.argument_id = t2.id", $streamId);
        $streamInfo["stream_arguments"] = self::$ipTV_db->c126FD559932F625CDf6098d86C63880();
        $streamSource = urldecode(json_decode($streamInfo["stream_info"]["stream_source"], true)[0]);
    
        if (substr($streamSource, 0, 2) == "s:") {
            $streamSourceParts = explode(":", $streamSource, 3);
            $serverId = $streamSourceParts[1];
    
            if ($serverId != SERVER_ID) {
                $filePath = a78Bf8d35765BE2408c50712ce7A43aD::$StreamingServers[$serverId]["api_url"] . "&action=getFile&filename=" . urlencode($streamSourceParts[2]);
            } else {
                $filePath = $streamSourceParts[2];
            }
    
            $streamProtocol = null;
        } else {
            $streamProtocol = substr($streamSource, 0, strpos($streamSource, "://"));
            $filePath = str_replace(" ", "%20", $streamSource);
        }
    
        $streamArguments = implode(" ", self::eA860C1D3851c46D06e64911E3602768($streamInfo["stream_arguments"], $streamProtocol, "fetch"));
    
        if (isset($serverId) && $serverId == SERVER_ID && $streamInfo["stream_info"]["movie_symlink"] == 1) {
            $symlinkCommand = "ln -s \"{$filePath}\" " . MOVIES_PATH . $streamId . "." . pathinfo($filePath, PATHINFO_EXTENSION) . " >/dev/null 2>/dev/null & echo \$! > " . MOVIES_PATH . $streamId . "_.pid";
        }
    
        $subtitles = json_decode($streamInfo["stream_info"]["movie_subtitles"], true);
        $subtitlesString = '';
    
        for ($index = 0; $index < count($subtitles["files"]); $index++) {
            $subtitleFile = urldecode($subtitles["files"][$index]);
            $subtitleCharset = $subtitles["charset"][$index];
    
            if ($subtitles["location"] == SERVER_ID) {
                $subtitlesString .= "-sub_charenc \"{$subtitleCharset}\" -i \"{$subtitleFile}\" ";
            } else {
                $subtitlesString .= "-sub_charenc \"{$subtitleCharset}\" -i \"" . a78BF8D35765be2408c50712Ce7a43aD::$StreamingServers[$subtitles["location"]]["api_url"] . "&action=getFile&filename=" . urlencode($subtitleFile) . "\" ";
            }
        }
    
        $symlinkCommand = FFMPEG_PATH . " -y -nostdin -hide_banner -loglevel warning -err_detect ignore_err {FETCH_OPTIONS} -fflags +genpts -async 1 {READ_NATIVE} -i \"{STREAM_SOURCE}\" {$subtitlesString}";
    
        $readNativeOption = '';
    
        if (!($streamInfo["stream_info"]["read_native"] == 1)) {
            $readNativeOption = "-re";
        }
    
        if ($streamInfo["stream_info"]["enable_transcode"] == 1) {
            if ($streamInfo["stream_info"]["transcode_profile_id"] == -1) {
                $streamInfo["stream_info"]["transcode_attributes"] = array_merge(self::ea860c1d3851c46d06E64911e3602768($streamInfo["stream_arguments"], $streamProtocol, "transcode"), json_decode($streamInfo["stream_info"]["transcode_attributes"], true));
            } else {
                $streamInfo["stream_info"]["transcode_attributes"] = json_decode($streamInfo["stream_info"]["profile_options"], true);
            }
        } else {
            $streamInfo["stream_info"]["transcode_attributes"] = array();
        }
    
        $copyUnknownOption = "-map 0 -copy_unknown ";
    
        if (!empty($streamInfo["stream_info"]["custom_map"])) {
            $copyUnknownOption = $streamInfo["stream_info"]["custom_map"] . " -copy_unknown ";
        } elseif ($streamInfo["stream_info"]["remove_subtitles"] == 1) {
            $copyUnknownOption = "-map 0:a -map 0:v";
        }
    
        if (array_key_exists("-acodec", $streamInfo["stream_info"]["transcode_attributes"])) {
            $streamInfo["stream_info"]["transcode_attributes"]["-acodec"] = "copy";
        }
    
        if (array_key_exists("-vcodec", $streamInfo["stream_info"]["transcode_attributes"])) {
            $streamInfo["stream_info"]["transcode_attributes"]["-vcodec"] = "copy";
        }
    
        $fileExtensions = array();
    
        foreach ($streamInfo["stream_info"]["target_container"] as $extension) {
            $fileExtensions[$extension] = "-movflags +faststart -dn {$copyUnknownOption} -ignore_unknown {$subtitlesOptions} " . MOVIES_PATH . $streamId . "." . $extension . " ";
        }
    
        foreach ($fileExtensions as $extension => $codec) {
            if ($extension == "mp4") {
                $streamInfo["stream_info"]["transcode_attributes"]["-scodec"] = "mov_text";
            } elseif ($extension == "mkv") {
                $streamInfo["stream_info"]["transcode_attributes"]["-scodec"] = "srt";
            } else {
                $streamInfo["stream_info"]["transcode_attributes"]["-scodec"] = "copy";
            }
    
            $symlinkCommand .= implode(" ", self::F6664c80BDe3e9bbe2c12CEb906D5A11($streamInfo["stream_info"]["transcode_attributes"])) . " ";
            $symlinkCommand .= $codec;
        }
    
        $symlinkCommand .= " >/dev/null 2>" . MOVIES_PATH . $streamId . ".errors & echo \$! > " . MOVIES_PATH . $streamId . "_.pid";
        $symlinkCommand = str_replace(array("{FETCH_OPTIONS}", "{STREAM_SOURCE}", "{READ_NATIVE}"), array(empty($streamArguments) ? '' : $streamArguments, $filePath, empty($streamInfo["stream_info"]["custom_ffmpeg"]) ? $readNativeOption : ''), $symlinkCommand);
        shell_exec($symlinkCommand);
        file_put_contents("/tmp/commands", $symlinkCommand . "\n", FILE_APPEND);
        $pid = intval(file_get_contents(MOVIES_PATH . $streamId . "_.pid"));
    
        self::$ipTV_db->query("UPDATE `streams_sys` SET `to_analyze` = 1,`stream_started` = '%d',`stream_status` = 0,`pid` = '%d' WHERE `stream_id` = '%d' AND `server_id` = '%d'", time(), $pid, $streamId, SERVER_ID);
        return $pid;
    }

    Ответ написан
  • Как настроить редирект всех страниц форума с папки https на поддомен http (3.3.10)?

    sharp97
    @sharp97
    не фонтан но брызги есть
    Попробуй в .htaccess добавить это
    RewriteEngine On
    RewriteRule ^forum/(.*)$ http://forum.сайт.ru/$1 [R=301,L]
    Ответ написан
  • PHP: как снизить нагрузку на сервер при выполнение тяжёлого скрипта?

    sharp97
    @sharp97
    не фонтан но брызги есть
    оптимизируй очередями по 10 например
    Ответ написан
    Комментировать
  • Как получить ответ от файла(например main.php) в форме?

    sharp97
    @sharp97
    не фонтан но брызги есть
    По какому-то событию , например нажатие onclick на кнопку отправки выполнять fetch post запрос в main php где в echo должен быть какой-то ответ выполнения всего файла, далее на фронте на js сформировать response то есть ответ сервера и уже от ответа выполнять какие-либо нужные под вашу задачу действия
    Ответ написан
    Комментировать
  • Как правильно валидировать данные пользователя?

    sharp97
    @sharp97
    не фонтан но брызги есть
    Ты сам решаешь какая валидация тебе нужна , реализовать можно на js , получаешь response пароля , смотришь совпадает ли , если да то авторизоваться, если нет, то выводить мол пароль не совпадает, длину символов и т д все что душа пожелает
    Ответ написан
    Комментировать
  • Почему не срабатывает запрос, выдаёт NULL?

    sharp97
    @sharp97 Автор вопроса
    не фонтан но брызги есть
    Проблема была связана с экранированием кавычек
    <?php
    require_once 'connection.php';
    
    
    $select_stmt=$db->prepare('SELECT MAX(result) AS Name, COUNT(result) AS Count FROM `results` GROUP BY (result)');
    $select_stmt->setFetchMode(PDO::FETCH_ASSOC);
    $select_stmt->execute();
    while($record = $select_stmt->fetch()) {
    	$transfers[] = $record["Name"];
    	$counts[] = $record["Count"];
    }
    
    $mystring = implode("','", $transfers); 
    $transfers_modify = "'$mystring'";
    
    $select_stmt=$db->prepare('SELECT j.result_color,pas_project FROM structure_test t JOIN JSON_TABLE(t.structure, "$.exodus[*]" COLUMNS(result_combination varchar(20) PATH "$.result_combination", result_color varchar(20) PATH "$.result_color", result VARCHAR(20) PATH "$.result", result_description VARCHAR(255) PATH "$.result_description")) j WHERE j.result IN ('.$transfers_modify.') AND named_project=:pname');
    $select_stmt->execute(array(':pname'=>$pn));
    while($record = $select_stmt->fetch()){
    	if($select_stmt->rowCount() > 0){
    		if(password_verify($pp, $record["pas_project"])) 
    		{
    			$colors[] = $record["result_color"];
    		}
    	}		
    }
    
    
    
    $response = array("transfers"=>$transfers,"counts"=>$counts,"colors"=>$colors);
    echo json_encode($response, JSON_UNESCAPED_UNICODE);
    ?>

    https://www.programulin.ru/zashchita-ot-sql-in-ekc...
    Ответ написан
    Комментировать
  • Куда выгружать фотографии и картинки с сайта а затем подгружать по мере надобности на сайт?

    sharp97
    @sharp97
    не фонтан но брызги есть
    Создаёшь папку assets/img закидываешь туда все картинки оттуда берешь картиночки по мере надобности , потом на спринтхост/таймвеб или 000веб какой-то можешь выгрузить версточку для демонстрации итога и всё собственно
    Ответ написан
    Комментировать
  • Отправка данных (data) по ajax как вывести на экран?

    sharp97
    @sharp97
    не фонтан но брызги есть
    На примере: получили user и вывели
    <?php
    $user =$_POST["user"]; //получили user
    $mahinacii = $user + "3123"; // сделали какие то махинации которые нам нужны
    $response = array("itog" => $mahinacii );
    echo json_encode($response, JSON_UNESCAPED_UNICODE);
    ?>

    На той странице с которой аякс отправляется надо ещё дописать чуть
    $.ajax({
                    url: 'primer.php',
                    method: 'POST',
                    data: {
                        user: localStorage.getItem("user"),
                        name: $('#name').val(),
                        adress: $('#adress').val(),
                        phone: $('#phone').val(),
                        mail: $('#mail').val(),
                       },
    success: function(json){
    const config = JSON.parse(json);
    $("div.error_con").html(config.itog);
    }

    <div class="error_con" id="error_con"></div>
    как правило кстати json чик получается на выходе так что подредачил ответ так чтобы получали json, ну и поддержу челика с комментов fetch более актуальная штуковина
    Ответ написан
    Комментировать
  • Как правильно использовать Инклуды в HTML?

    sharp97
    @sharp97
    не фонтан но брызги есть
    если я правильно понял что ты хочешь сделать это
    <?php include_once 'header.php' ?>
    в header.php только контейнер
    потом разбиваешь на файлы nav и прочее и также подключаешь
    <header>
    <?php include_once 'nav.php' ?> 
    <?php include_once 'other.php' ?>  
    <?php include_once 'other2.php' ?>  
    </header>
    Ответ написан
    5 комментариев