最近,gfs这边要做一个网站,我也有幸参与其中。
网站使用php作为开发语言,这使得一向使用java的我有点不习惯,但语言都是相通的嘛,用了两个晚上看完两本php教程,于是跃跃欲试,尝试完成自己的任务。
我要完成的是一部分是在个人信息录入时,照片的上传(ps:上传到服务器,而非数据库)以及读取。
应该说,完成起来并不是很困难,之前也没用表单post过图片,便很想尝试一哈,弄了一上午,终于把上传机理弄清楚了。
下面是部分代码。功能很简陋,只考虑到最理想情况。
表单页
uppic.php
其中,难点在于,对于$_FILES["photo"]["tmp_name"]和move_uploaded_file()的理解。
下面是Google的关于数组$_FILES[][]的资料
$_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.
非常重要的一点是:文件通过post提交后是保存在C:/WINDOWS/temp/临时文件夹中,下面是处理结果
可以看到这并不是我们想要的结果,
我们还需要用move_uploaded_file()对上传文件处理
下面是解决方案move_uploaded_file($_FILES["photo"]["tmp_name"],$path)
通过$_FILES["photo"]["tmp_name"],我们可以轻松获得上传的临时文件,将它保存到我们指定的路径中。我们为什么不用知道临时文件的路径,就可以复制该文件到指定目录呢?
其实,这要归功于$_FILES[][]是一个全局数组,这大大方便了我们的复制操作。
其他要做的事就很简单了。
不过要做一个完善的,安全的上传文件系统还有很多要做,但那就是所向披靡的事了。