zoukankan      html  css  js  c++  java
  • 网页中上传文件操作

    要实现的效果:

    主页代码:

    <form action="chuli.php" method="post" enctype="multipart/form-data">
    <input type="file" name="file"/>
    <input  type="submit" value="上传"/>
    </form>

    处理页面:

    <?php
    //获取到上传的文件
    var_dump($_FILES["file"]);//$_FILES本身就为数组
    //控制文件类型和大小
    if(($_FILES["file"]["type"]=="image/png"||$_FILES["file"]["type"]=="image/jpeg")&&$_FILES["file"]["size"]<=102400)
    {
        //上传操作
        //设置存储路径
        $filename="./img/".date("YmdHis").$_FILES["file"]["name"];
        //将存储路径的编码格式变为国标
        $filename=iconv("UTF-8","gb2312",$filename);//这一步要先于移动文件执行
        
        //如果文件名重复,出现覆盖
        //判断文件是否存在
        if(file_exists($filename))//判断存储路径中的文件名是否存在
        {
            die("文件名已存在");
            }
        //移动文件
        $yuan=$_FILES["file"]["tmp_name"];
        move_uploaded_file($yuan,$filename);
        
        }
    else
    {
        echo "上传失败";
        }
    //减少文件重名的概率,把未知文件添加进存储路径中的方法:修改文件名、新建文件夹(一般用于文件名无法修改时);

     <a>标签的小功能:

    a标签指向文件时,如果该文件是浏览器可以打开的则直接打开,如图片;打不开的则下载,如txt文件,word,excel,ppt文件。

    $_FILES数组内容如下:
    $_FILES['myFile']['name'] 客户端文件的原名称。
    $_FILES['myFile']['type'] 文件的 MIME 类型,需要浏览器提供该信息的支持,例如"image/gif"。
    $_FILES['myFile']['size'] 已上传文件的大小,单位为字节。
    $_FILES['myFile']['tmp_name'] 文件被上传后在服务端储存的临时文件名,一般是系统默认。可以在php.ini的upload_tmp_dir 指定,但 用 putenv() 函数设置是不起作用的。
    $_FILES['myFile']['error'] 和该文件上传相关的错误代码。['error'] 是在 PHP 4.2.0 版本中增加的。下面是它的说明:(它们在PHP3.0以后成了常量)
    UPLOAD_ERR_OK
    值:0; 没有错误发生,文件上传成功。
    UPLOAD_ERR_INI_SIZE
    值:1; 上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
    UPLOAD_ERR_FORM_SIZE
    值:2; 上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
    UPLOAD_ERR_PARTIAL
    值:3; 文件只有部分被上传。
    UPLOAD_ERR_NO_FILE
    值:4; 没有文件被上传。
    值:5; 上传文件大小为0.

    文件被上传结束后,默认地被存储在了临时目录中,这时您必须将它从临时目录中删除或移动到其它地方,如果没有,则会被删除。也就是不管是否上传成功,脚本执行完后临时目录里的文件肯定会被删除。所以在删除之前要用PHP的 copy() 函数将它复制到其它位置,此时,才算完成了上传文件过程。

  • 相关阅读:
    WebSocket使用及优化(心跳机制与断线重连)
    JS案例:触底懒加载
    你知道近来年大火的DDD是如何兴起的吗?以及与微服务的关系
    Sql Server的Cross Apply用法
    跨域信息传递解决方案
    【转】理解字节序
    NATAPP优惠码
    <学习笔记>筛法
    <学习笔记>线性基
    【react + BizCharts】
  • 原文地址:https://www.cnblogs.com/jinshui/p/5629546.html
Copyright © 2011-2022 走看看