表单提交音乐文件(php)
利用点空闲时间来写个博客,最近做的项目中需要表单提交音频的,图片的,各种类型,把它存到数据库里,这里先来说一下音乐文件的表单提交吧,后几天再来更新输入数据库的,先看一下效果
点击浏览
就会出来预览,点击mp3的文件
打开播放也可以正常播放
再来换一张图片,试试能不能传上
提交张图片
点击提交
提交不成功,因为这个只允许MP3格式的文件提交
刚才还没看mp3的提交,下面提交一下MP3文件
点击提交
因为没有给它设置跳转页面,所以还在它的处理页面
和图片上传的原理是一样的,图片上传在我的前几篇博客中有,一样得需要在自己的目录下新建一个文件夹
而提交的内容都得存入这个文件夹中
看一下里面有没有刚才我们提交的MP3文件
运行成功
如果再提交一遍的话还会有
点击提交
看一下文件夹里
依然有。
下面来看一下我们这个的源代码
先来看主页面的
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>无标题文档</title>
- </head>
- <script src="http://cdn.bootcss.com/jquery/1.11.1/jquery.min.js"></script>
- <body>
- <div class="box_input" style="margin-bottom: 20px;">
- <form action="shiyancl.php" method="post" style="width: 960px;" enctype="multipart/form-data">
- <input id="test" style="display: inline-block;" type="file" name="file"/>
- <audio id="audio" controls autoplay="" style="display: none; "></audio>
- <input type="submit" id="mp3_submit" style="display: none;margin-left: 25px;" type="button" value="提交"/>
- </form>
- </div>
- </body>
- <script>
- //录音上传
- $(function () {
- $("#test").change(function () {
- var objUrl = getObjectURL(this.files[0]);
- $("#audio").attr("src", objUrl);
- $("#audio")[0].pause();
- $("#audio").show();
- $("#mp3_submit").show()
- getTime();
- });
- });
- <!--获取mp3文件的时间 兼容浏览器-->
- function getTime() {
- setTimeout(function () {
- var duration = $("#audio")[0].duration;
- if(isNaN(duration)){
- getTime();
- }
- else{
- console.info("该歌曲的总时间为:"+$("#audio")[0].duration+"秒")
- }
- }, 10);
- }
- <!--把文件转换成可读URL-->
- function getObjectURL(file) {
- var url = null;
- if (window.createObjectURL != undefined) { // basic
- url = window.createObjectURL(file);
- } else if (window.URL != undefined) { // mozilla(firefox)
- url = window.URL.createObjectURL(file);
- } else if (window.webkitURL != undefined) { // webkit or chrome
- url = window.webkitURL.createObjectURL(file);
- }
- return url;
- }
- </script>
- </html>
再来看它的提交页面的代码 文件名是shiyancl.php
- <?php
- //var_dump($_FILES["file"]); //索引写它的name值
- //判断文件上传是否出错
- if($_FILES["file"]["error"])
- {
- echo $_FILES["file"]["error"];
- }
- else
- {
- //控制上传文件类型
- if(($_FILES["file"]["type"]=="audio/mpeg" || $_FILES["file"]["type"]=="mp3/mp3") && $_FILES["file"]["size"]<500000)
- {
- //找到文件存放的位置
- $filename = "./file/".date("YmdHis").$_FILES["file"]["name"]; //加 . 拼接
- //转换编码格式
- $filename = iconv("UTF-8","gb2312",$filename);
- //判断文件是否存在
- if(file_exists($filename))
- {
- echo "该文件已存在!";
- }
- else
- {
- //保存文件
- move_uploaded_file($_FILES["file"]["tmp_name"],$filename); //移动上传文件
- }
- }
- else
- {
- echo "文件类型不正确";
- }
- }
再写之前可以用var_dump输出一下你要提交的东西
它就会给你返会数据类型什么的
有些东西可以根据这个改
等我把其他功能做出来会继续上传的,希望会对大家有所帮助
表单提交音乐文件(php)的更多相关文章
- jquery mobile 表单提交 图片/文件 上传
jquerymobile 下面 form 表单提交 和普通html没区别,最主要是 <form 要加一个 data-ajax='false' 否则 上传会失败 1 html代码 <!do ...
- node07---post请求、表单提交、文件上传
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 织梦cmsf表单提交到邮箱 织梦表单发送到邮箱 织梦自定义表单发邮箱
大家在做织梦做网站开发时会遇到一个问题:织梦的自定义表单是一个很鸡肋的功能,不仅在后台展示得奇丑,而且也没有提醒功能,使用起来很不方便.很多人用织梦自定义表单时,都想用户提交表单的时候可以发送到自己的 ...
- php表单提交 图片、音乐、视频、文字,四种类型共同提交到数据库
这个问题一直困扰了我好几天,终于在今天让我给解决了,难以掩饰的激动. 其实在之前没有接触到这种问题,只是表单提交数据而已,再就是图片,四种类型同时提交还真是没遇到过,做了一个系统,其中有一个功能就是提 ...
- 使用jquery form插件进行异步带文件的表单提交
引入form插件与jquery 的js文件后 获取表单的jq对象 然后.ajaxSubmit提交表单即可 实现添加品牌的异步表单提交 function addBarandImg(formId) { $ ...
- js实现无刷新表单提交文件,将ajax请求转换为form请求方法
最近在做项目的时候遇到一个需要上传文件的需求,因为ajax请求是无法上传二进制文件流的,所以只能用form表单提交,而form提交有一个问题就是会使页面刷新,本文解决了form表单提交文件时页面刷新的 ...
- c# 模拟表单提交,post form 上传文件、大数据内容
表单提交协议规定:要先将 HTTP 要求的 Content-Type 设为 multipart/form-data,而且要设定一个 boundary 参数,这个参数是由应用程序自行产生,它会用来识别每 ...
- 【HTML相关】iframe+javascript实现一个表单提交后多个处理文件按序处理
最近在弄一个网页的问题,总结如下. [问题描述] 页面中包括以下几个部分:1)表单form,供用户输入图片文件:2)iframe1,显示a.php文件的内容,a.php接收客户端图片并保存,后台程序处 ...
- input file 在开发中遇到的问题 类似ajax form表单提交 input file中的文件
最近在做项目的过程中遇到个问题,在这里做个记录防止日后忘记 现今的主流浏览器由于ajax提交form表单无法把文件类型数据提交到后台,供后台处理,可是开发中由于某些原因又不得不用ajax提交文件, 为 ...
随机推荐
- 从Visual Studio看微软20年技术变迁
前言 这个世界从来都不缺变革,从工业革命到晶体管和集成电路,从生活电器到物联网,从简陋人机到精致体验,我们在享受技术带来的便捷的同时,也在为复杂设计而带来的挑战和生产力下降而痛并快乐着.而迫切期盼的, ...
- Caused by: java.lang.RuntimeException: java.io.IOException: invalid constant type: 18
工程启动的时候有报下面这个错误的,更新下工程的jar包依赖,然后在工程的pom文件里加上下面的jar包 Caused by: java.lang.RuntimeException: java.io.I ...
- win7下Apache2.4安装、配置及服务自启动
为了测试微信平台接口,在电脑上安装的Apache服务器,把安装步骤记下来以后备用 第一篇文章,不好请见谅 Apache2.4.17下载地址:http://www.apachelounge.com/do ...
- Office 365开发概述及生态环境介绍(一)
原文于2017年3月13日首发于LinkedIn,请参考这个链接 离上一篇文章,很快又过去了两星期的时间.今天抓紧晚上的时间,开始了Office 365开发系列文章的第一篇,我会帮助大家回顾一下过去O ...
- 基于GDAL的遥感影像显示(C#版)
基于GDAL的遥感影像显示(C#版) - 菜菜的专栏 - 博客频道 - CSDN.NET http://blog.csdn.net/RSyaoxin/article/details/9220735
- 解决MVC中JsonResult返回 弹出文件下载对话框
设置一下返回类型为HTML TEXT就可以了 JsonResult json = Json(xxx, JsonRequestBehavior.DenyGet); json.ContentType = ...
- [译]Selenium Python文档:三、导航控制
你使用WebDriver要做的第一件事就是访问一个链接.一般通过调用get方法来实现: driver.get("http://www.baidu.com") 在将控制权返给你的脚本 ...
- python 附加作业01
题目1: 画方块 输入样例: 10 a 输出样例: 代码: N=eval(input()) c=input() for i in range(N): for j in range(N): print( ...
- ubuntu-terminal快捷键
常用快捷键功能:Tab 自动补全 Ctrl+a 光标移动到开始位置 Ctrl+e 光标移动到最末尾 Ctrl+k 删除此处至末尾的所有内容 Ctrl+u 删除此处至开始的所有内容 Ctrl+d 删除当 ...
- 微服务--webapi实现,脱离iis,脱离tomcat
前言 微服务,顾名思义就是微小的单一的服务程序,单一流程,单一发布,开发和部署都可独立: 这是我的理解: 但基于web的服务,不管是webservice还是webapi等类似的服务都需要基于iis或者 ...