Maison >développement back-end >tutoriel php >Développer un lecteur de musique efficace en utilisant le framework PHP Symfony
Avec la popularité de l'Internet mobile et des services musicaux, les lecteurs de musique sont devenus un élément indispensable de nos vies. Pour les développeurs souhaitant développer eux-mêmes un lecteur de musique, utiliser le framework PHP Symfony sera un choix efficace.
Symfony est un framework PHP basé sur le modèle MVC. Il fournit de nombreux outils et composants efficaces pour aider les développeurs à créer rapidement des applications Web de haute qualité. Dans cet article, nous présenterons comment utiliser le framework Symfony pour créer un lecteur de musique efficace.
Un lecteur de musique doit gérer correctement les informations de métadonnées des fichiers musicaux, telles que le nom de l'album, le nom de la chanson, l'artiste Nom, etc. Symfony peut utiliser Doctrine ORM pour gérer les données. ORM signifie "Object Relational Mapping", qui peut mapper les données de la base de données en objets PHP, et les objets PHP peuvent être utilisés pour effectuer des opérations de base de données.
Dans Symfony, utilisez Composer pour installer le composant Doctrine :
composer require symfony/orm-pack
Dans Doctrine, vous pouvez utiliser des annotations ou des fichiers XML pour définir les attributs et les relations des entités (Entity). Voici un exemple d'entité :
<?php namespace AppEntity; use DoctrineORMMapping as ORM; /** * @ORMEntity(repositoryClass="AppRepositorySongRepository") */ class Song { /** * @ORMId() * @ORMGeneratedValue() * @ORMColumn(type="integer") */ private $id; /** * @ORMColumn(type="string", length=255) */ private $title; /** * @ORMColumn(type="string", length=255) */ private $artist; /** * @ORMColumn(type="string", length=255) */ private $album; // 其他属性 /** * @ORMColumn(type="datetime") */ private $uploadedAt; // getter和setter方法 }
Dans cette entité, nous définissons les propriétés de la chanson, comme le titre, l'artiste, l'album, etc. Nous définissons également l'attribut d'heure de téléchargement, qui nous aide à trier les chansons.
Dans Symfony, vous pouvez utiliser l'outil en ligne de commande pour créer et mettre à jour les tables de la base de données :
php bin/console doctrine:schema:create php bin/console doctrine:schema:update --force
<?php namespace AppController; use AppEntitySong; use SymfonyBundleFrameworkBundleControllerAbstractController; use SymfonyComponentRoutingAnnotationRoute; class MusicController extends AbstractController { /** * @Route("/music", name="music") */ public function index() { $songs = $this->getDoctrine() ->getRepository(Song::class) ->findAll(); return $this->render('music/index.html.twig', [ 'songs' => $songs, ]); } }Dans le modèle, vous pouvez utiliser les instructions de boucle et les variables de Twig pour afficher la liste de musique. Voici un exemple simple :
{% extends 'base.html.twig' %} {% block body %} <h1>My Music Player</h1> <ul> {% for song in songs %} <li>{{ song.title }} - {{ song.artist }} ({{ song.album }})</li> {% endfor %} </ul> {% endblock %}Cela récupérera les chansons de la base de données et les affichera dans une liste.
<?php namespace AppController; use SymfonyBundleFrameworkBundleControllerAbstractController; use SymfonyComponentHttpFoundationRequest; use SymfonyComponentHttpFoundationResponse; use SymfonyComponentRoutingAnnotationRoute; class MusicController extends AbstractController { /** * @Route("/music/{id}/file", name="music_file") */ public function file(Request $request, $id) { $song = $this->getDoctrine() ->getRepository(Song::class) ->find($id); $path = $this->getParameter('music_directory').'/'.$song->getPath(); $response = new Response(); $response->headers->set('Content-Type', 'audio/mpeg'); $response->headers->set('Content-Disposition', 'inline; filename="'.basename($path).'"'); $response->headers->set('Content-Length', filesize($path)); $response->setContent(file_get_contents($path)); return $response; } }Dans ce contrôleur, nous récupérons une chanson de la base de données et extrayons le contenu de son fichier musical sous forme de flux de réponse. Nous définissons également les en-têtes Content-Type et Content-Disposition de la réponse, ainsi que l'en-tête Content-Length. Notez que le chemin du fichier de musique ici est obtenu à partir du paramètre Symfony (Paramètre), et nous pouvons le stocker dans le fichier de paramètres pour utiliser différents chemins dans différents environnements. Dans Twig, nous pouvons transmettre l'URL du fichier musical dans la balise audio pour lire la musique dans le navigateur.
{% extends 'base.html.twig' %} {% block body %} <h1>My Music Player</h1> <ul> {% for song in songs %} <li> {{ song.title }} - {{ song.artist }} ({{ song.album }}) <audio controls> <source src="{{ path('music_file', { 'id': song.id }) }}" type="audio/mpeg"> </audio> </li> {% endfor %} </ul> {% endblock %}À cet endroit, nous utilisons la fonction path pour obtenir l'URL du fichier musical de la route et l'utilisons comme valeur d'attribut src de la balise source.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!