Кафедра ИСиТ УО ВГТУ
  • Специальности
    • Экономика электронного бизнеса
    • Информационные системы
    • Information Control Systems
  • Каталог
  • Сайт кафедры
  • Сервисы
    • GitLab
    • ownCloud
    • JupyterHub
    • JupyterHub 2
    • VNC
    • Soft
  1. ИСиТ
  2. РВПсИПП
  3. Практика
  4. Лаб. работа “Работа с медиа контентом в Symfony”
  • ИСиТ
    • АОС
      • Теория
        • Введение в операционные системы
        • Управление памятью
        • Управление процессами
        • Система ввода-вывода
        • Информационная безопасность
        • Виртуализация
      • Практика
    • РВПсИПП
      • Теория
        • Настройка среды разработки для PHP
        • Разработка web-приложений на базе фреймворков
        • Основы Laravel
        • Шаблоны в Laravel
        • Модели и базы данных в Laravel
        • Формы и валидация в Laravel
        • Аутентификация и авторизация в Laravel
        • Создание REST API в Laravel
        • Работа с файлами и изображениями в Laravel
        • Тестирование и отладка в Laravel
        • Введение в фреймворк Symfony
        • Маршруты и контроллеры в Symfony
        • Шаблоны и Twig в Symfony
        • Формы и валидация в Symfony
        • Доступ к базам данных в Symfony
        • Аутентификация и авторизация в Symfony
        • Сервисы и зависимости в Symfony
        • Создание REST API в Symfony
        • Работа с файлами и медиа в Symfony
        • Сравнение и выбор фреймворка
        • Развертывание веб-приложения
      • Практика
        • Лаб. работа 1 “Создание нового приложения Laravel”
        • Лаб. работа 2 “Добавление главной страницы и базовых маршрутов”
        • Лаб. работа 3 “Создание моделей, миграций и сидеров”
        • Лаб. работа 4 “Создание индексных страниц и пагинация”
        • Лаб. работа 5 “Создание форм для работы с сущностями”
        • Лаб. работа 6 “Работа с файлами (эмуляция S3-хранилища)”
        • Лаб. работа “Создание маршрутов в Laravel”
        • Лаб. работа “Работа с базами данных в Laravel”
        • Лаб. работа “Работа с формами в Laravel”
        • Лаб. работа “Аутентификация и авторизация в Laravel”
        • Лаб. работа “Работа с файлами в Laravel”
        • Лаб. работа “Тестирование и оптимизация в Laravel”
        • Лаб. работа “Создание REST API в Laravel”
        • Лаб. работа “Основы Symfony”
        • Лаб. работа “Шаблоны и представления в Symfony”
        • Лаб. работа “Работа с базами данных в Symfony”
        • Лаб. работа “Фомы и аутентификация в Symfony”
        • Лаб. работа “Сервисы и зависимости в Symfony”
        • Лаб. работа “REST API в Symfony”
        • Лаб. работа “Работа с медиа контентом в Symfony”
        • Лаб. работа “Создание и развертывание проекта”
    • ПСП
      • Теория
        • Введение
        • Протокол HTTP
        • Программирование с использованием сокетов
        • Введение в PHP
        • Работа с базами данных в PHP
        • Объектно-ориентированные возможности PHP
        • Настройка среды разработки для PHP
        • Разработка web-приложений на базе фреймворков
      • Практика
        • Программное обеспечение
        • Регистрация в JupyterHub
        • Лаб. работа “Почтовые протоколы”
        • Лаб. работа “Протокол FTP”
        • Лаб. работа “Протокол HTTP”
        • Лаб. работа “Программирование сетевых приложений с использованием сокетов”
        • Лаб. работа “Основы PHP”
        • Лаб. работа “Массивы в PHP”
        • Лаб. работа “Создание веб-приложений с использованием Slim”
    • Компьютерные сети
      • Теория
        • Введение в компьютерные сети
        • Топологии сетей
        • Кодирование и мультиплексирование
        • Стеки протоколов
        • Адресация в компьютерных сетях
        • Система доменных имен (DNS)
        • Программирование с использованием сокетов
        • Введение в PHP
        • Протокол HTTP
        • Введение в компьютерные сети
      • Практика
        • Программное обеспечение
        • Регистрация в JupyterHub
        • Лаб. работа “Почтовые протоколы”
        • Лаб. работа “Протокол FTP”
        • Лаб. работа “Протокол HTTP”
        • Лаб. работа “Программирование сетевых приложений с использованием сокетов”
        • Лаб. работа “Основы PHP”
        • Лаб работа “Массивы в PHP”
    • РиОИИС
      • Теория
        • Классификация оптимизационных задач
        • Генетические алгоритмы
        • Системы массового обслуживания
        • Теория игр
        • Машинное обучение
        • Глубокое обучение (Deep learning)
        • Основы функционального программирования
        • Основы программирования на Haskell
        • Введение в логическое программирование
        • Инференция и рассуждения в логическом программировании
        • Разработка экспертных систем
        • Интеллектуальные системы и их архитектура
        • Веб-скрэйпинг
        • Сбор данных с открытых API
      • Практика
        • JupyterHub
        • Лаб. работа “Методы одномерной оптимизации”
        • Лаб. работа “Методы многомерной оптимизации”
        • Лаб. работа “Функции в Python”
        • Лаб. работа “Рекурсия в Python”
        • Лаб. работа “Итераторы в Python”
        • Лаб. работа “Генетические алгоритмы”
        • Лаб. работа “Haskell”
        • Лаб. работа “Логическое программирование”
        • Лаб. работа “Сбор данных с помощью веб-скрейпинга”
    • КСКР
      • Практика
        • Лаб. работа “Одномерные и двумерные массивы в C#”
        • Лаб. работа “Обращение матриц в C#”
    • Системное программирование
      • Теория
        • Управление памятью в Windows
        • Файловые операции в Windows
        • Управление процессами в Windows
        • Графический интерфейс Windows
        • ОС Unix
      • Практика
        • Лаб. работа “Работа с динамической памятью в Windows”
        • Лаб. работа “Операции с файлами в Windows”
        • Лаб. работа “Управление процессами в Windows”
        • Лаб. работа “Работа с виртуальной машиной Linux”
        • Лаб. работа “Язык командного энтерпритатора Shell”
        • Лаб. работа “Работа с файлами в Linux”
        • Лаб. работа “Работа с процессами в Linux”

Содержание

  • Шаг 1: Установка необходимых пакетов
  • Шаг 2: Создание сущности Image
  • Шаг 3: Создание формы загрузки изображений
  • Шаг 4: Создание контроллера для работы с изображениями
  • Шаг 5: Создание шаблонов
  • Шаг 6: Тестирование приложения
  1. ИСиТ
  2. РВПсИПП
  3. Практика
  4. Лаб. работа “Работа с медиа контентом в Symfony”

Лаб. работа “Работа с медиа контентом в Symfony”

Разработка web-приложений с использованием программных платформ
Практика
Автор

Бизюк Андрей

Дата публикации

29 февраля 2024 г.

В этой лабораторной работе мы изучим, как работать с медиа контентом в Symfony. Для этого мы создадим простое приложение, которое будет позволять пользователям загружать изображения и отображать их на странице.

Шаг 1: Установка необходимых пакетов

Для работы с медиа контентом в Symfony нам понадобятся следующие пакеты:

  • Symfony Form
  • Symfony Validator
  • Symfony FileLoader
  • Doctrine ORM

Установите эти пакеты, используя Composer:

composer require symfony/form
composer require symfony/validator
composer require symfony/file-loader
composer require doctrine/orm

Шаг 2: Создание сущности Image

Создайте новую сущность Image, используя команду Doctrine:

php bin/console make:entity Image

Задайте поля для сущности Image:

  • id (integer, primary key, auto-increment)
  • name (string, length 255)
  • path (string, length 255)
  • createdAt (datetime)
  • updatedAt (datetime)

Создайте миграцию и обновите базу данных:

php bin/console make:migration
php bin/console doctrine:migrations:migrate

Шаг 3: Создание формы загрузки изображений

Создайте новую форму загрузки изображений, используя команду Symfony:

php bin/console make:form ImageType

Задайте поля для формы ImageType:

  • image (FileType, required)

Измените конфигурацию формы, чтобы она использовала сущность Image:

public function buildForm(FormBuilderInterface $builder, array $options): void
{
    $builder
        ->add('image', FileType::class, [
            'required' => true,
            'label' => 'Select an image',
        ])
    ;
}

public function configureOptions(OptionsResolver $resolver): void
{
    $resolver->setDefaults([
        'data_class' => Image::class,
    ]);
}

Шаг 4: Создание контроллера для работы с изображениями

Создайте новый контроллер, используя команду Symfony:

php bin/console make:controller ImageController

Добавьте действие для загрузки изображений:

/**
 * @Route("/images/upload", name="image_upload")
 */
public function upload(Request $request, EntityManagerInterface $entityManager): Response
{
    $image = new Image();
    $form = $this->createForm(ImageType::class, $image);
    $form->handleRequest($request);

    if ($form->isSubmitted() && $form->isValid()) {
        $file = $form['image']->getData();
        $fileName = md5(uniqid()).'.'.$file->guessExtension();
        $file->move($this->getParameter('images_directory'), $fileName);
        $image->setName($fileName);
        $image->setPath($this->getParameter('images_directory'));
        $entityManager->persist($image);
        $entityManager->flush();

        return $this->redirectToRoute('image_index');
    }

    return $this->render('image/upload.html.twig', [
        'form' => $form->createView(),
    ]);
}

Добавьте действие для отображения списка изображений:

/**
 * @Route("/images", name="image_index")
 */
public function index(EntityManagerInterface $entityManager): Response
{
    $images = $entityManager->getRepository(Image::class)->findAll();

    return $this->render('image/index.html.twig', [
        'images' => $images,
    ]);
}

Шаг 5: Создание шаблонов

Создайте шаблон для формы загрузки изображений:

{% extends 'base.html.twig' %}

{% block body %}
    <h1>Upload an image</h1>

    {{ form_start(form) }}
        {{ form_row(form.image) }}
        <button type="submit">Upload</button>
    {{ form_end(form) }}
{% endblock %}

Создайте шаблон для отображения списка изображений:

{% extends 'base.html.twig' %}

{% block body %}
    <h1>Images</h1>

    <ul>
        {% for image in images %}
            <li>
                <img src="{{ asset('uploads/' ~ image.name) }}" alt="{{ image.name }}" width="200">
            </li>
        {% endfor %}
    </ul>
{% endblock %}

Шаг 6: Тестирование приложения

Запустите приложение и перейдите по адресу /images/upload. Загрузите несколько изображений и убедитесь, что они отображаются на странице /images.

Дополнительные материалы:

  • Документация Symfony Form
  • Документация Symfony Validator
  • Документация Symfony FileLoader
  • Документация Doctrine ORM
Наверх
Лаб. работа “REST API в Symfony”
Лаб. работа “Создание и развертывание проекта”