2016/4/19 ①单个文件上传 ②上传图片后 预览图片
1,f1.php
<!DOCTYPE html> <htmllang="en"> <head><metacharset="UTF-8"><title>Document</title> </head> <body> <!--作业:在网上找上传图片预览的代码 上传服务器 再预览--> <formaction="f1chuli.php"method="post"enctype="multipart/form-data"><inputtype="file"name="file"></input><inputtype="submit"value="上传"></input> </form> </body> </html>
2,f1chuli.php
1 <?php2 header("content-type:text/html;charset=utf-8");3 //上传文件的所有信息都保存在$_FILES["file"]数组中;4 //echo $_FILES["file"]["name"];//取文件名5 6 //echo $_FILES["file"]["type"];//取到 文件类型7 8 //echo $_FILES["file"]["size"];//取到 文件大小9 10 //echo $_FILES["file"]["tmp_name"]; //文件在服务器临时存放的路径 临时位置11 12 //echo $_FILES["file"]["error"];//判断上传是否出错13 14 //文件上传15 16 //1,判断是否出错 17 if ($_FILES["file"]["error"]) {18 echo "上传出错!";19 }20 else{21 //2.加限制条件 22 if ($_FILES["file"]["type"]=="image/jpeg" && $_FILES["file"]["size"]<1024000)23 {24 //处理文件名 25 $str= date("YmdHisms",time());//加时间戳 区别相同文件名26 //3.造一个存储的路径 27 $url="./img/".$str.$_FILES["file"]["name"];//如果还有重复 拼加用户名 28 29 30 $filename=iconv("UTF-8","gb2312", $url);31 //将路径的编码格式转换为国标,防止文件乱码 32 if (file_exists($filename)) {33 echo "该文件已经存在!";34 }35 else{36 37 38 //4.存储 39 move_uploaded_file($_FILES["file"]["tmp_name"],$filename);40 41 }42 }43 44 else 45 {46 echo "上传文件的类型不符合要求";47 }48 }49 50 51 ?>
View Code
显示效果:
②上传图片 图片预览 两种形式
1,ceshi.php + shangchuan.php 这种方法 必须在两个文件同级目录下
手动建立imags文件
ceshi.php
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <htmlxmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <metahttp-equiv="Content-Type"content="text/html; charset=utf-8" /> 5 <title>无标题文档</title> 6 </head> 7 8 <body> 9 <formid="sc"action="shangchuan.php"target="hidden_frame"method="post"enctype="multipart/form-data"> 10 <divid="yl"style="margin-left:0px; width:144px; height:170px; background-size:144px 170px; background-image:url(images/l7a3.jpg)"> 11 <inputtype="file"name="file"style="width:144px; height:170px; float:left; opacity:0;"width="146"onchange="document.getElementById('sc').submit()"/> 12 <imgid="pic"style="display:none"/> 13 </div> 14 <inputtype="button"value="保存"/> 15 </form> 16 <iframestyle="display:none;"name="hidden_frame"id="hidden_frame"> 17 </iframe> 18 19 </body> 20 <scripttype="text/javascript"> 21 //回调函数 22 functionshowimg(aa)23 {24 varl=document.getElementById("yl");25 varp=document.getElementById("pic");26 27 l.style.backgroundImage= "url("+aa+")";28 p.setAttribute("src",aa);29 }30 </script> 31 </html>
View Code
shangchuan.php
1 <?php2 //上传文件限制 3 if ((($_FILES["file"]["type"] == "image/gif")|| ($_FILES["file"]["type"] == "image/jpeg")|| ($_FILES["file"]["type"] == "image/pjpeg"))&& ($_FILES["file"]["size"] < 10000000))4 {5 //文件上传是否出错 6 if ($_FILES["file"]["error"] > 0)7 {8 echo "上传出错: " . $_FILES["file"]["error"] . "<br />";9 }10 else 11 {12 //输出文件信息 13 /*echo "文件名: " . $_FILES["file"]["name"] . "<br />";14 echo "类型: " . $_FILES["file"]["type"] . "<br />";15 echo "大小: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />";16 echo "临时路径: " . $_FILES["file"]["tmp_name"] . "<br />";*/ 17 18 //判断文件是否已存在 19 if (file_exists("images/" . $_FILES["file"]["name"]))20 {21 echo "<script language='javascript'>alert('".$_FILES["file"]["name"]."已经存在!')</script>";22 23 }24 else 25 {26 //造存储路径 27 $filename = "images/" . $_FILES["file"]["name"];28 //移动图片至保存路径,解决中文乱码问题 29 move_uploaded_file($_FILES["file"]["tmp_name"],iconv("UTF-8","gb2312",$filename));30 31 echo "该文件存储在了: " . "images/" . $_FILES["file"]["name"];32 echo "<script language='javascript'>parent.showimg('".$filename."')</script>";33 }34 }35 }36 else 37 {38 echo "上传失败";39 }40 41 ?>
View Code
显示效果: 最初 到 点击选图 再到文件显示
2,shangchuanyulan.php 不许要手动建立 同级目录下 会自动生成upload 文件夹
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 2 <html xmlns="http://www.w3.org/1999/xhtml"> 3 <head> 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 5 <title>无标题文档</title> 6 <?php7 8 $uptypes=array('image/jpg', //上传文件类型列表 9 'image/jpeg', 10 'image/png', 11 'image/pjpeg', 12 'image/gif', 13 'image/bmp', 14 'image/x-png');15 $max_file_size=5000000; //上传文件大小限制, 单位BYTE 16 $destination_folder="upload/"; //上传文件路径 17 $watermark=1; //是否附加水印(1为加水印,其他为不加水印); 18 $watertype=1; //水印类型(1为文字,2为图片) 19 $waterposition=1; //水印位置(1为左下角,2为右下角,3为左上角,4为右上角,5为居中); 20 $waterstring="newphp.site.cz"; //水印字符串 21 $waterimg="xplore.gif"; //水印图片 22 $imgpreview=1; //是否生成预览图(1为生成,其他为不生成); 23 $imgpreviewsize=1/2; //缩略图比例 24 ?> 25 <style type="text/css">body,td{font-family:tahoma,verdana,arial;font-size:11px;line-height:15px;background-color:white;color:#666666;margin-left:20px;} 26 strong{font-size:12px;}27 aink{color:#0066CC;} 28 a:hover{color:#FF6600;} 29 aisited{color:#003366;} 30 a:active{color:#9DCC00;} 31 table.itable{}32 td.irows{height:20px;background:url("index.php?i=dots" repeat-x bottom}</style> 33 </head> 34 <body> 35 <center><form enctype="multipart/form-data" method="post" name="upform"> 36 上传文件: <br><br><br> 37 <input name="upfile" type="file" style="width:200;border:1 solid #9a9999; font-size:9pt; background-color:#ffffff" size="17"> 38 <input type="submit" value="上传" style="width:30;border:1 solid #9a9999; font-size:9pt; background-color:#ffffff" size="17"><br><br><br> 39 允许上传的文件类型为:jpg|jpeg|png|pjpeg|gif|bmp|x-png|swf <br><br> 40 <a href="index.php">返回</a> 41 </form> 42 <?php43 if ($_SERVER['REQUEST_METHOD'] == 'POST')44 {45 if (!is_uploaded_file($_FILES["upfile"]["tmp_name"]))46 //是否存在文件 47 {48 echo "<font color='red'>文件不存在!</font>";49 exit;50 }51 $file = $_FILES["upfile"];52 if($max_file_size < $file["size"])53 //检查文件大小 54 {55 echo "<font color='red'>文件太大!</font>";56 exit;57 }58 if(!in_array($file["type"], $uptypes))59 //检查文件类型 60 {61 echo "<font color='red'>只能上传图像文件或Flash!</font>";62 exit;63 }64 if(!file_exists($destination_folder))65 mkdir($destination_folder);66 $filename=$file["tmp_name"];67 $image_size = getimagesize($filename);68 $pinfo=pathinfo($file["name"]);69 $ftype=$pinfo["extension"];70 $destination = $destination_folder.time().".".$ftype;71 if (file_exists($destination) && $overwrite != true)72 {73 echo "<font color='red'>同名文件已经存在了!</a>";74 exit;75 }76 if(!move_uploaded_file ($filename, $destination))77 {78 echo "<font color='red'>移动文件出错!</a>";79 exit;80 }81 $pinfo=pathinfo($destination);82 $fname=$pinfo["basename"];83 echo " <font color=red>已经成功上传</font><br>文件名: <font color=blue>".$destination_folder.$fname."</font><br>";84 echo " 宽度:".$image_size[0];85 echo " 长度:".$image_size[1];86 if($watermark==1)87 {88 $iinfo=getimagesize($destination,$iinfo);89 $nimage=imagecreatetruecolor($image_size[0],$image_size[1]);90 $white=imagecolorallocate($nimage,255,255,255);91 $black=imagecolorallocate($nimage,0,0,0);92 $red=imagecolorallocate($nimage,255,0,0);93 imagefill($nimage,0,0,$white);94 switch ($iinfo[2])95 {96 case 1: 97 $simage =imagecreatefromgif($destination);98 break;99 case 2: 100 $simage =imagecreatefromjpeg($destination);101 break;102 case 3: 103 $simage =imagecreatefrompng($destination);104 break;105 case 6: 106 $simage =imagecreatefromwbmp($destination);107 break;108 default: 109 die("<font color='red'>不能上传此类型文件!</a>");110 exit;111 }112 imagecopy($nimage,$simage,0,0,0,0,$image_size[0],$image_size[1]);113 imagefilledrectangle($nimage,1,$image_size[1]-15,80,$image_size[1],$white);114 switch($watertype)115 {116 case 1: //加水印字符串 117 imagestring($nimage,2,3,$image_size[1]-15,$waterstring,$black);118 break;119 case 2: //加水印图片 120 $simage1 =imagecreatefromgif("xplore.gif");121 imagecopy($nimage,$simage1,0,0,0,0,85,15);122 imagedestroy($simage1);123 break;124 }125 switch ($iinfo[2])126 {127 case 1: 128 //imagegif($nimage, $destination); 129 imagejpeg($nimage, $destination);130 break;131 case 2: 132 imagejpeg($nimage, $destination);133 break;134 case 3: 135 imagepng($nimage, $destination);136 break;137 case 6: 138 imagewbmp($nimage, $destination);139 //imagejpeg($nimage, $destination); 140 break;141 }142 //覆盖原上传文件 143 imagedestroy($nimage);144 imagedestroy($simage);145 }146 if($imgpreview==1)147 {148 echo "<br>图片预览:<br>";149 echo "<a href=\"".$destination."\" target='_blank'><img src=\"".$destination."\" width=".($image_size[0]*$imgpreviewsize)." height=".($image_size[1]*$imgpreviewsize);150 echo " alt=\"图片预览:\r文件名:".$destination."\r上传时间:\" border='0'></a>";151 }152 }153 ?> 154 </center> 155 </body> 156 </html>
View Code
显示效果: 从未选 到选中 到上传后 显示预览
上传相同的文件 因上传时间的不同导致上传文件的名称不同 加时间戳 和 后缀
文件目录显示效果:
3,待整理 文件名 随机获取
转载于:https://www.cnblogs.com/haodayikeshu/p/5408690.html
2016/4/19 ①单个文件上传 ②上传图片后 预览图片相关推荐
- struts上传word和excel文件到oracle,Struts文件上传,下载,重传,预览
[Struts2]☆★之文件上传,下载,重传,预览 今日群里一兄弟问我能否给一份struts文件上传下载的例子,因为自己项目比较紧所以想在网上找 些源码给他,但是纵观全网,写的都不是太全,这让新手使用 ...
- php文件上传及头像预览
php文件上传原理是通过form表单的enctype="multipart/form-data"属性将文件临时放到wamp文件夹中的tmp目录下,再通过后台php 程序将文件保存在 ...
- 用openoffice+jodconverter+webuploader+pdf.js实现文件上传、在线预览功能
一.背景 最近公司一个项目要实现一个文件上传以及多文档在线预览的功能,之前一直做无线工具开发的,没有涉及到这些东西.另外项目组缺java开发人员,而且自己也只是一个半吊子前端加小半吊子java开发人员 ...
- Element文件上传 pdf 及预览
目标:vue+element 实现上传图片及pdf 和预览功能 技术:vue.element.vue-pdf 安装及引入: //安装 npm install --save vue-pdf//引入 im ...
- java实现文件上传预览_jsp+springmvc实现文件上传、图片上传和及时预览图片
1.多文件上传:http://blog.csdn.net/a1314517love/article/details/24183273 2.单文件上传的简单示例:http://blog.csdn.net ...
- Java写file文件上传,在线预览思路
需要考虑的 1.存储路径区根据时间进行区分,例如根据年月份存放不同的文件目录/20220303 2.上传的文件为避免文件名相同,文件名存数据库,存储存放的文件名为UUID+后缀(如果不需要在线预览,则 ...
- php上传头像的代码,php实现文件上传及头像预览功能
php文件上传原理是通过form表单的enctype="multipart/form-data"属性将文件临时放到wamp文件夹中的tmp目录下,再通过后台php程序将文件保存在体 ...
- 在BAE搭建的Django中实现图片上传并用jquery预览图片
在BAE上搭建好了django,如何实现图片上传并预览呢? 想要实现图片上传并不难,但是想看到刚上传的图片,就得在服务器返回上传后图片的url.可是返回数据的话,网页就会重定向.因此想要在上传页面预览 ...
- SpringBoot实现PPT格式文件上传并在线预览
1.需要引入依赖 <dependency><groupId>com.itextpdf</groupId><artifactId>itextpdf< ...
最新文章
- 什么是BI?什么是DW?ETL(Extract-Transform-Load)是什么?
- 有一天人人都会变成程序猿
- 为Kindeditor控件添加图片自动上传功能
- java csv 追加_如何在Java中添加一个包含CSV数据的列
- 方法的直接调用,反射调用与……Lambda表达式调用
- linux节点ssh免密码登录linux节点
- 收藏 | 超轻量目标检测模型NanoDet,比YOLO跑得快,上线两天Star量超200
- Subarray Sum
- [Linux] 头文件加载顺序
- Linux常用命令介绍(三)——基础操作命令
- React.js及React Native知识及实践
- c语言保留三位小数用float,float保留三位小数
- traceview使用总结
- c/c++实现二叉树的创建以及前中后序遍历
- [读书笔记]职场动物进化手册
- dropbox无法访问后国内网盘对比选择
- IBM推出企业信息安全框架
- mongodb之快速入门
- ASCII 字元表(详细讲解)
- kettle命令运行工具(pan、kitchen、carte)
热门文章
- python查询oracle数据库_python针对Oracle常见查询操作实例分析
- python运行原理_Python线程池及其原理和使用(超级详细)
- python模拟密码有效性检测功能_检查密码有效性(Django/Python)
- html5css3js文件作业,HTML5 CSS3 JavaScriptWeb前端开发自测试卷2.docx
- 运维祈求不宕机_[国庆特辑] 程序员应该求谁保佑才能保证不宕机?
- Linux入门笔记——echo
- 树、二叉树、二叉搜索树_检查二叉树是否为BST(二叉搜索树)
- Visual Studio进行linux远程开发
- Hibernate中把Session和线程绑定的配置
- mysql5.7修改root密码_七小服公开课EMC isilon修改丢失的root密码