php 图片上传php
基础原理: html
经过使用php的全局数组 $_FILES,你能够从客户计算机向远程服务器上传文件。数组
第一个参数是表单的 input name,第二个下标能够是 "name"、"type"、"size"、 "tmp_name" 或 "error"。 以下所示:服务器
$_FILES["file"]["name"] - 上传文件的名称post
$_FILES["file"]["type"] - 上传文件的类型spa
$_FILES["file"]["size"] - 上传文件的大小,以字节计code
$_FILES["file"]["tmp_name"] - 存储在服务器的文件的临时副本的名称orm
$_FILES["file"]["error"] - 由文件上传致使的错误代码htm
功能代码以下:blog
input_file.html
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>input_file</title> </head> <body> <form action="./upload.php" method='post' enctype="multipart/form-data"> <input type="file" name="file"> <p><input type="submit"></p> </form> </body> </html>
upload.php
<?php header("Content-type: text/html; charset=utf-8"); // 接收到的参数 $file = $_FILES['file']; //传输的数据 $name = $file['name']; //文件名 $type = strtolower(substr($name, strrpos($name, '.')+1)); //获得文件类型,而且都转成小写 $allow_type = array('jpg', 'jpeg', 'gif', 'png'); //容许上传的文件类型 if( !in_array($type, $allow_type) ) { // 不是容许的文件类型 return; } //判断是不是经过HTTP POST上传的 if(!is_uploaded_file($file['tmp_name'])){ //若是不是经过HTTP POST上传的 return ; } $upload_path = "./img/"; //上传文件的存放路径 //开始移动文件到相应的文件夹 if(move_uploaded_file($file['tmp_name'],$upload_path.$file['name'])){ echo "Successfully!"; }else{ echo "Failed!"; } ?>