返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >php怎么实现音乐列表
  • 393
分享到

php怎么实现音乐列表

php 2021-06-07 01:06:47 393人浏览
摘要

php实现音乐列表的方法:1、从文件当中读取内容,并解码;2、将数据展示在列表,并利用foreach对数据一一显示在列表当中即可。

本文操作环境:windows7系统、PHP7.1版、DELL G3电脑

php怎么实现音乐列表?

PHP实现音乐列表的上传、展示、删除:

思路
list.php列表展示
1、从文件当中读取内容,并解码

$JSON = file_get_contents('data.json');$songs = json_decode($json, true);

将数据展示在列表,利用foreach对数据一一显示在列表当中

<?php foreach ($songs as $item): ?>
        <tr>
          <td class="align-middle"><?php echo $item['title']; ?></td>
        </tr><?php endforeach ?>

add.php
1、表单提交给自身网页进行处理
2、给每个输入框一个name值
3、php处理的时候,可以通过$_POST[‘title’]对数据进行处理
4、处理之后将数据保存到文件/数据库当中

<fORM action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post" enctype="multipart/form-data"><label for="title">标题</label>
        <input type="text" class="form-control " id="title" name="title"> <button class="btn btn-primary btn-block">保存</button></form>
// 读取已有数据
  $songs = json_decode(file_get_contents('data.json'), true);
  // 追加新数据
  $songs[] = $new_song;
  // 将追加的结果写入文件
  file_put_contents('data.json', json_encode($songs));

del.php
1、需要执行删除就必须提供你想要删除的是谁,获取要删除的ID
这里的话 是通过一开始从文件/数据库当中读取出来的$item[‘id’]值,就可以判断是要删除哪一个,同时删除按钮a标签?后面是可以附带值传输给后台的

 <a class="btn btn-outline-danger btn-sm" href="del.php?id=<?php echo $item['id']; ?>">删除</a>

从数据库/文件当中读取数据
3、通过ID在数据中找到对应要删除的键,删除之后将数据放回文件/数据库中

源码
del.php

<?php// 只要有人请求我 del.php 我就执行删除操作// 如果需要我执行删除就必须提供你想要删除的是谁// 一般情况下如果客户端需要给服务端提供简单的数据标识,// 这种情况都会采用URL 地址传递问号参数的方式传递// 校验(客户端来的东西都不能信)if (empty($_GET['id'])) {
  exit('你必须提供要删除的数据ID'); // exit 会直接结束脚本的运行}// 确保客户端提交了 ID$id = $_GET['id'];// 1. 读取已有数据$json = file_get_contents('data.json');// 2. 反序列化$songs = json_decode($json, true);// 3. 遍历数组找到要删除的元素foreach ($songs as $item) {
  if ($item['id'] === $id) {
    // 找到了要删除的数据
    // 4. 在数组中删除这个元素
    // 4.1. 找到这个数据在数组的下标
    $index = array_search($item, $songs);
    array_splice($songs, $index, 1);
    // 5. 将删除过后的数组序列化成 JSON 字符串
    $new_json = json_encode($songs);
    // 6. 持久化
    file_put_contents('data.json', $new_json);
    break;
  }}// 跳转回去header('Location: /songs/list.php');

add.php

<?php

function receive_form () {
  // global $error_type;
  // 1. 校验客户端提交的数据
  // 1.1. 校验标题
  // empty($_POST['title']) === !(isset($_POST['title']) && $_POST['title'] !== '')
  // empty函数的作用就是判断一个成员是否为空(未定义、值为false)
  if (empty($_POST['title'])) {
    // 标题未正常填写
    $GLOBALS['error_type'] = 'title';
    $GLOBALS['error_msg'] = "填写标题";
    return;
  }

  if (empty($_POST['artist'])) {
    // 歌手未正常填写
    $GLOBALS['error_type'] = 'artist';
    $GLOBALS['error_msg'] = "填写歌手";
    return;
  }

  // ===================================================

  // echo "校验文件";
  // 校验上传文件
  //  1. 校验是否上传成功(error)
  if ($_FILES['source']['error'] !== UPLOAD_ERR_OK) {
    $GLOBALS['error_type'] = 'source';
    $GLOBALS['error_msg'] = "上传失败";
    return;
  }

  //  2. 校验上传文件的类型(type)
  $allowed_source_types = array('audio/mp3', 'audio/wma');
  if (!in_array($_FILES['source']['type'], $allowed_source_types)) {
    $GLOBALS['error_type'] = 'source';
    $GLOBALS['error_msg'] = "只能上传音频文件";
    return;
  }

  //  3. 校验文件大小(size)文件的大小单位是字节
  if (1 * 1024 * 1024 > $_FILES['source']['size'] || $_FILES['source']['size'] > 10 * 1024 * 1024) {
    $GLOBALS['error_type'] = 'source';
    $GLOBALS['error_msg'] = "上传文件大小不合理";
    return;
  }

  //  将文件从临时目录中移动到网站下面
  $tmp_path = $_FILES['source']['tmp_name']; // 临时路径
  $dest_path = '../uploads/mp3/' . $_FILES['source']['name']; // 存放路径
  $source = substr($dest_path, 2);
  $moved = move_uploaded_file($tmp_path, $dest_path); // 返回移动是否成功

  if (!$moved) {
    $GLOBALS['error_type'] = 'source';
    $GLOBALS['error_msg'] = "上传失败";
    return;
  }

  // ============= 处理多个文件逻辑 ====================

  // 如果一个文件域是多文件上传的话,文件域的 name 应该是由 [] 结尾
  for ($i = 0; $i < count($_FILES['images']['error']); $i++) {
    // 1. 校验上传成功
    if ($_FILES['images']['error'][$i] !== UPLOAD_ERR_OK) {
      $GLOBALS['error_type'] = 'images';
      $GLOBALS['error_msg'] = "上传图片失败";
      return;
    }
    // 2. 校验文件类型
    $allowed_images_types = array('image/jpeg', 'image/png', 'image/gif');
    if (!in_array($_FILES['images']['type'][$i], $allowed_images_types)) {
      $GLOBALS['error_type'] = 'images';
      $GLOBALS['error_msg'] = "只能上传图片文件";
      return;
    }
    // 3. 校验大小
    if ($_FILES['images']['size'][$i] > 1 * 1024 * 1024) {
      $GLOBALS['error_type'] = 'images';
      $GLOBALS['error_msg'] = "上传文件大小不合理";
      return;
    }
    // 移动文件
    $img_tmp_path = $_FILES['images']['tmp_name'][$i]; // 临时路径
    $img_dest_path = '../uploads/img/' . $_FILES['images']['name'][$i]; // 存放路径
    $img_moved = move_uploaded_file($img_tmp_path, $img_dest_path); // 返回移动是否成功
    if (!$img_moved) {
      $GLOBALS['error_type'] = 'images';
      $GLOBALS['error_msg'] = "上传图片失败";
      return;
    }

    $images[] = substr($img_dest_path, 2);
  }

  // 2. 保存数据
  $new_song = array(
    'id' => uniqid(), // uniqid 获取一个唯一ID
    'title' => $_POST['title'],
    'artist' => $_POST['artist'],
    'images' => $images,
    'source' => $source
  );
  // 读取已有数据
  $songs = json_decode(file_get_contents('data.json'), true);
  // 追加新数据
  $songs[] = $new_song;
  // 将追加的结果写入文件
  file_put_contents('data.json', json_encode($songs));

  // 3. 响应
  header('Location: /songs/list.php');
}

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
  // 处理接收校验表单
  receive_form();
}

?>
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>添加新音乐</title>
  <link rel="stylesheet" href="bootstrap.CSS">
</head>
<body>
  <div class="container py-5">
    <h1>添加新音乐</h1>
    <hr>
    <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post" enctype="multipart/form-data">
      <div>
        <label for="title">标题</label>
        <input type="text" class="form-control <?php echo isset($error_type) && $error_type === 'title' ? 'is-invalid' : ''; ?>" id="title" name="title" value="<?php echo isset($_POST['title']) ? $_POST['title'] : ''; ?>">
        <small><?php echo $error_msg; ?></small>
      </div>
      <div>
        <label for="artist">歌手</label>
        <input type="text" class="form-control <?php echo isset($error_type) && $error_type === 'artist' ? 'is-invalid' : ''; ?>" id="artist" name="artist" value="<?php echo isset($_POST['artist']) ? $_POST['artist'] : ''; ?>">
        <small><?php echo $error_msg; ?></small>
      </div>
      <div>
        <label for="images">海报</label>
        <!-- multiple 可以让文件域多选 -->
        <!-- accept 可以指定文件域能够选择的默认文件类型 MIME Type -->
        <!-- image/* 代表所有类型图片 -->
        <!-- 除了使用 MIME 类型 还可以使用文件后缀名限制:.png,.jpg -->
        <input type="file" id="images" name="images[]" multiple accept="image/*">
      </div>
      <div>
        <label for="source">音乐</label>
        <input type="file" class="form-control <?php echo isset($error_type) && $error_type === 'source' ? 'is-invalid' : ''; ?>" id="source" name="source" accept="audio/*">
        <small><?php echo $error_msg; ?></small>
      </div>
      <button class="btn btn-primary btn-block">保存</button>
    </form>
  </div>
</body>
</html>

list.php

<?php

// 1. 读取文件内容
$json = file_get_contents('data.json');
// 2. 反序列化
// json_decode 第二个参数可以用来指定返回数据都采用 关联数组的方式 描述对象
$songs = json_decode($json, true);
// 3. 遍历数据渲染HTML
// var_dump($songs);

?>
<!DOCTYPE html>
<html>
<head>
  <meta charset="UTF-8">
  <title>音乐列表</title>
  <link rel="stylesheet" href="bootstrap.css">
</head>
<body>
  <div class="container py-5">
    <h1>音乐列表</h1>
    <hr>
    <div class="px-2 mb-3">
      <a href="add.php" class="btn btn-secondary btn-sm">添加</a>
    </div>
    <table class="table table-bordered table-striped table-hover">
      <thead>
        <tr>
          <th><input type="checkbox" name="" id=""></th>
          <th>标题</th>
          <th>歌手</th>
          <th>海报</th>
          <th>音乐</th>
          <th>操作</th>
        </tr>
      </thead>
      <tbody>
        <?php foreach ($songs as $item): ?>
        <tr>
          <td><input type="checkbox" name="" id=""></td>
          <td><?php echo $item['title']; ?></td>
          <td><?php echo $item['artist']; ?></td>
          <td>
            <?php foreach ($item['images'] as $img): ?>
            <img src="<?php echo $img; ?>" alt="">
            <?php endforeach ?>
          </td>
          <td><audio src="<?php echo $item['source']; ?>" controls></audio></td>
          <td>
            <a class="btn btn-outline-danger btn-sm" href="del.php?id=<?php echo $item['id']; ?>">删除</a>
            <!-- hidden 隐藏域 -->
            <!-- <form action="del.php" method="get">
              <input type="hidden" name="id" value="<?php echo $item['id']; ?>">
              <button class="btn btn-danger btn-sm">删除</button>
            </form> -->
          </td>
        </tr>
        <?php endforeach ?>
      </tbody>
    </table>
  </div>
</body>
</html>

以上就是php怎么实现音乐列表的详细内容,更多请关注编程界其它相关文章!

--结束END--

本文标题: php怎么实现音乐列表

本文链接: https://www.lsjlt.com/news/453.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • php怎么实现音乐列表
    php实现音乐列表的方法:1、从文件当中读取内容,并解码;2、将数据展示在列表,并利用foreach对数据一一显示在列表当中即可。 ...
    393
    2023-03-24
    php
  • php网页怎么增加音乐播放器
    php网页增加音乐播放器的方法:1、定义一个磁盘下的mp3文件路径;2、读取文件大小;3、设置文件头的媒体类型;4、读取文件即可。 ...
    580
    2023-03-24
    php 音乐播放器
  • 怎么用PHP+Ajax实现点击加载更多列表数据
    这篇文章主要介绍“怎么用PHP+Ajax实现点击加载更多列表数据”,在日常操作中,相信很多人在怎么用PHP+Ajax实现点击加载更多列表数据问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用PHP+Ajax ...
    525
    2023-03-24
    php ajax
  • php怎么获取类方法的参数列表
    php中,可用func_get_args()函数来获取类方法的参数列表,只需要在类方法内添加“$argsArr=func_get_args()”语句即可。func_get_args()函数可获取类方法的所有参数,返回一个包含参数列表的数组。 ...
    196
    2023-03-24
    php 参数列表
  • php怎么实现翻译
    php实现翻译的方法:1、创建一个PHP示例文件;2、通过有道翻译json格式来显示传值;3、利用PHP自带的函数,抓取URL返回的json数据;4、将json数据转换成对象类的形式即可。 ...
    325
    2023-03-24
    php 翻译
  • php怎么实现日历
    php实现日历的方法:1、创建一个PHP示例文件并设置编码为utf-8;2、创建table表格;3、通过mktime等函数获取时间日期;4、通过for循环实现日历功能即可。 ...
    720
    2023-03-24
    PHP 日历
  • php怎么实现翻页
    php实现翻页的方法:1、查询所有符合条件需要进行分页的总数据,计算展示的总页数;2、获取当前显示的是第几页信息;3、根据限制条件查询出当前页所需显示出来的数据;4、将每一条数据echo替换HTML结构内容中,最后显示出来即可。 ...
    602
    2023-03-24
    php 翻页
  • php怎么实现校检
    php实现校检的方法:1、声明“session_start();”函数;2、创建验证码实现的代码;3、在验证码实现之前声明一个空变量,用来存放验证码;4、用POST方式来接收验证码即可。 ...
    153
    2023-03-24
    php 校检
  • php怎么实现群发
    php实现群发的方法:1、获取第三方的接口api;2、通过“function http_request($url,$data = null){...}”代码发送请求;3、直接调用第三方的url地址,并根据要求的接口传参数即可。 ...
    818
    2023-03-24
    php 群发短信
  • php怎么实现限流
    这篇文章给大家分享的是有关php怎么实现限流的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。什么是接口限流那么什么是限流呢?顾名思义,限流就是限制流量,包括并发的流量和一定时间内的总流量,就像你宽带包了1个G的流量 ...
    757
    2023-03-24
    php
  • Android利用SoundPool实现音乐池
    这篇文章主要为大家详细介绍了Android利用SoundPool实现音乐池,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...
    174
    2023-03-24
    Android SoundPool 音乐池
  • java实现播放背景音乐
    这篇文章主要为大家详细介绍了java实现播放背景音乐,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 ...
    768
    2023-03-24
    java播放背景音乐 java背景音乐 java播放音乐
  • php怎么实现浏览记录
    php实现浏览记录的方法:1、设置初始数据;2、获取cookie记录;3、判断浏览记录是否存在;4、将浏览数组序列化后写入cookie;5、读取cookie记录即可。 ...
    729
    2023-03-24
    php
  • php怎么实现文字反转
    php实现文字反转的方法:1、使用strrev函数实现反转;2、通过把分割字符串到一个数组中,然后遍历拼接来实现反转;3、利用递归来实现反转。 ...
    417
    2023-03-24
    php 反转
  • php怎么实现分页接口
    php实现分页接口的方法:1、接收页数值;2、计算总条数;3、计算偏移量;4、通过“select * from 表名 limit ($offset ,$page)”语句查询每页数据。 ...
    524
    2023-03-24
    php
  • php 怎么实现访客次数
    php实现访客次数的方法:1、创建两个数据库表;2、在要进行统计次数的页面上添加代码“$realip=getip();modifyipcount($realip);”即可。 ...
    585
    2023-03-24
    php
  • php怎么实现搜索效果
    php实现搜索效果的方法:1、初始化查询条件;2、调用查询方法;3、计算页面显示数据条数;4、在设置的“搜索”菜单中,调用“protected function _search(){...}”搜索方法即可。 ...
    542
    2023-03-24
    php 搜索
  • php 怎么实现小票打印
    php实现小票打印的方法:1、在优声云打印开放平台注册账号;2、查看打印机接口开发文档;3、通过编写PHP接口代码,实现打印排版等功能即可。 ...
    134
    2023-03-24
    php
  • php sprintf 怎么实现替换
    php sprintf实现替换的方法:1、创建一个PHP示例文件;2、通过“sprintf("There are %u million cars in %s.",$number,$str);”把指定符号替换掉即可。 ...
    257
    2023-03-24
    php sprintf
  • php怎么实现ip收集
    php实现获取ip的方法:1、使用“$_SERVER["REMOTE_ADDR"]”获取;2、使用“($user_IP) ? $user_IP : $_SERVER["REMOTE_ADDR"]”获取;3、使用getRealIp方法获取等。 ...
    770
    2023-03-24
    php ip
热门问答
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作