PHP上传文件到服务器的指定文件夹,怎么实现
2个回答
展开全部
下面是接收前台传过来的图片,然后存储的代码。原理接本上都相同。注意。分割线下面是对应的html代码。不过我这里面引用了我的主数据库操作文件。所以你可能运行不起来。但是你可以把sql之类的还有$res之类的地方注释掉。。不行了。太多了。html页面发不下你追问吧。我追问里面再发html代码
<?php
/**
* Created by alandic lidjio.
* User: lidjio
* Date: 2016/12/16
* Time: 12:04
*/
header("Content-Type:text/html;charset=utf-8");
require_once ('Sqltool.php');
//step 1 使用$_FILES['pic']["error"] 检查错误
if(isset($_GET["action"])=="img"){
if($_FILES["img"]["error"] > 0){
switch($_FILES["img"]["error"]) {
case 1:
echo "<script type='text/javascript'>alert('上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值<br>');history.back();</script>";
break;
case 2:
echo "<script type='text/javascript'>alert('上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值');history.back();</script>";
break;
case 3:
echo "<script type='text/javascript'>alert('文件只有部分被上传');history.back();</script>";
break;
case 4:
echo "<script type='text/javascript'>alert('没有文件被上传');history.back();</script>";
break;
default:
echo "<script type='text/javascript'>alert('末知错误');history.back();</script>";
}
exit;
}
$maxsize=2000000; //50k
//step 2 使用$_FILES["pic"]["size"] 限制大小 单位字节 2M=2000000
if($_FILES["img"]["size"] > $maxsize ) {
echo "<script type='text/javascript'>alert('上传的文件太大,不能超过{$maxsize}字节');history.back();</script>";
exit;
}
//step 3 使用$_FILES["pic"]["type"]或是文件的扩展名 限制类型 MIME image/gif image/png gif png jpg
/* list($dl, $xl) = explode("/", $_FILES["pic"]["type"]);
if($dl!="image"){
echo "请上传一个图片,不充许其它类型文件";
exit;
}
*/
$allowtype=array("png", "gif", "jpg", "jpeg");
$arr=explode(".", $_FILES["img"]["name"]);
$hz=$arr[count($arr)-1];
if(!in_array($hz, $allowtype)){
echo "<script type='text/javascript'>alert('这是不允许的类型');history.back();</script>";
exit;
}
//step 4 将让传后的文件名改名
$filepath="upload/";
$fileimgweb="upload/";//为了符合UBB的路径
$randname=date("Y").date("m").date("d").date("H").date("i").date("s").rand(100, 999).".".$hz;
//将临时位置的文件移动到指定的目录上即可
if(is_uploaded_file($_FILES["img"]["tmp_name"])){
if(move_uploaded_file($_FILES["img"]["tmp_name"],$filepath.$randname)){
$imgnum=$_GET['imgnum'];
$dt_carck_id=$_GET['dt_carck_id'];
echo "<script type='text/javascript'>history.back();</script>";
session_start();
$_SESSION['images'] = $fileimgweb.$randname;
$fileurl=$fileimgweb.$randname;
echo $fileurl;
$sql="UPDATE dt_carcheck SET dt_carck_img".$imgnum."= '"."$fileurl"."' WHERE dt_carck_id='".$dt_carck_id."'";
$res=execute_dml($sql);
echo "<br/>";
// echo $sql;
echo "<br/>";
// echo $res;
}else{
echo "<script type='text/javascript'>alert('上传失败');history.back();</script>";
}
}else{
echo"<script type='text/javascript'>alert('不是一个上传文件');history.back();</script>";
}
}
?>
---------------------------------------------------------------------------------
<?php
/**
* Created by alandic lidjio.
* User: lidjio
* Date: 2016/12/16
* Time: 12:04
*/
header("Content-Type:text/html;charset=utf-8");
require_once ('Sqltool.php');
//step 1 使用$_FILES['pic']["error"] 检查错误
if(isset($_GET["action"])=="img"){
if($_FILES["img"]["error"] > 0){
switch($_FILES["img"]["error"]) {
case 1:
echo "<script type='text/javascript'>alert('上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值<br>');history.back();</script>";
break;
case 2:
echo "<script type='text/javascript'>alert('上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值');history.back();</script>";
break;
case 3:
echo "<script type='text/javascript'>alert('文件只有部分被上传');history.back();</script>";
break;
case 4:
echo "<script type='text/javascript'>alert('没有文件被上传');history.back();</script>";
break;
default:
echo "<script type='text/javascript'>alert('末知错误');history.back();</script>";
}
exit;
}
$maxsize=2000000; //50k
//step 2 使用$_FILES["pic"]["size"] 限制大小 单位字节 2M=2000000
if($_FILES["img"]["size"] > $maxsize ) {
echo "<script type='text/javascript'>alert('上传的文件太大,不能超过{$maxsize}字节');history.back();</script>";
exit;
}
//step 3 使用$_FILES["pic"]["type"]或是文件的扩展名 限制类型 MIME image/gif image/png gif png jpg
/* list($dl, $xl) = explode("/", $_FILES["pic"]["type"]);
if($dl!="image"){
echo "请上传一个图片,不充许其它类型文件";
exit;
}
*/
$allowtype=array("png", "gif", "jpg", "jpeg");
$arr=explode(".", $_FILES["img"]["name"]);
$hz=$arr[count($arr)-1];
if(!in_array($hz, $allowtype)){
echo "<script type='text/javascript'>alert('这是不允许的类型');history.back();</script>";
exit;
}
//step 4 将让传后的文件名改名
$filepath="upload/";
$fileimgweb="upload/";//为了符合UBB的路径
$randname=date("Y").date("m").date("d").date("H").date("i").date("s").rand(100, 999).".".$hz;
//将临时位置的文件移动到指定的目录上即可
if(is_uploaded_file($_FILES["img"]["tmp_name"])){
if(move_uploaded_file($_FILES["img"]["tmp_name"],$filepath.$randname)){
$imgnum=$_GET['imgnum'];
$dt_carck_id=$_GET['dt_carck_id'];
echo "<script type='text/javascript'>history.back();</script>";
session_start();
$_SESSION['images'] = $fileimgweb.$randname;
$fileurl=$fileimgweb.$randname;
echo $fileurl;
$sql="UPDATE dt_carcheck SET dt_carck_img".$imgnum."= '"."$fileurl"."' WHERE dt_carck_id='".$dt_carck_id."'";
$res=execute_dml($sql);
echo "<br/>";
// echo $sql;
echo "<br/>";
// echo $res;
}else{
echo "<script type='text/javascript'>alert('上传失败');history.back();</script>";
}
}else{
echo"<script type='text/javascript'>alert('不是一个上传文件');history.back();</script>";
}
}
?>
---------------------------------------------------------------------------------
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询