PHP怎样上传图片以及预览图片?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP怎样上传图片以及预览图片?相关的知识,希望对你有一定的参考价值。
本地图片,就搞个img,设置他的src就可以实现;参考如下:
<div class="column " style="width: 400px; margin-left: 200px;" id="imageShow">
<div id="productImageNew">@*用于图片预览*@
</div>
<div id="productImage">
<div class="widget the-common-margin-top" style="height: 400px; border: 1px solid #eeeeee;
padding: 3px;">
<img id="imgHolder" style="max-height: 390px; max-width: 390px;" />
</div>
</div>
</div>
<form id="formImageUpload" name="formImageUpload" method="post" action="/DocTeam/ProductsImage/UploadImage"
enctype="multipart/form-data">
<div id="fileDiv">
<input type="file" id="theFile" name="theFile" size="20" style="cursor: pointer;
width: 65px; height: 60px; position: absolute; filter: alpha(opacity:1); -moz-opacity: 0;
opacity: 0; z-index: 102;" />
</div>
<input type="hidden" name="imageId_hide" id="imageId_hide" />
</form>
<div id="cover" style="position: absolute; background-color: White; z-index: 10;
filter: alpha(opacity=100); -moz-opacity: 1; opacity: 1; overflow: auto; width: 400px;">
<input id="selectImage" type="button" style="width: 65px; height: 60px;" value="Select" />
<br />
<br />
<input type="button" value="Upload" id="imageUpload" style="width: 65px; height: 60px;"
disabled="disabled" onclick="javascript:uploadImage();" />
</div>
//js本地图片预览,兼容ie[6-9]、火狐、Chrome17+、Opera11+、Maxthon3
function PreviewImage(fileObj, imgPreviewId, divPreviewId)
var allowExtention = ".jpg,.bmp,.gif,.png"; //允许上传文件的后缀名document.getElementById("hfAllowPicSuffix").value;
var extention = fileObj.value.substring(fileObj.value.lastIndexOf(".") + 1).toLowerCase();
var browserVersion = window.navigator.userAgent.toUpperCase();
if (allowExtention.indexOf(extention) > -1)
if (fileObj.files) //html5实现预览,兼容chrome、火狐7+等
if (window.FileReader)
var reader = new FileReader();
reader.onload = function (e)
document.getElementById(imgPreviewId).setAttribute("src", e.target.result);
reader.readAsDataURL(fileObj.files[0]);
else if (browserVersion.indexOf("SAFARI") > -1)
alert("不支持Safari6.0以下浏览器的图片预览!");
else if (browserVersion.indexOf("MSIE") > -1)
if (browserVersion.indexOf("MSIE 6") > -1) //ie6
document.getElementById(imgPreviewId).setAttribute("src", fileObj.value);
else //ie[7-9]
fileObj.select();
if (browserVersion.indexOf("MSIE 9") > -1)
fileObj.blur(); //不加上document.selection.createRange().text在ie9会拒绝访问
var newPreview = document.getElementById(divPreviewId + "New");
if (newPreview == null)
newPreview = document.createElement("div");
newPreview.setAttribute("id", divPreviewId + "New");
var a = document.selection.createRange().text;
// newPreview.style.width = document.getElementById(imgPreviewId).width + "px";
// newPreview.style.height = document.getElementById(imgPreviewId).height + "px";
//newPreview.style.width = 390 + "px";
newPreview.style.height = 390 + "px";
newPreview.style.border = "solid 1px #eeeeee";
newPreview.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=\'scale\',src=\'" + document.selection.createRange().text + "\')";
var tempDivPreview = document.getElementById(divPreviewId);
// tempDivPreview.parentNode.insertBefore(newPreview, tempDivPreview);
newPreview.style.display = "block";
tempDivPreview.style.display = "none";
else if (browserVersion.indexOf("FIREFOX") > -1) //firefox
var firefoxVersion = parseFloat(browserVersion.toLowerCase().match(/firefox\\/([\\d.]+)/)[1]);
if (firefoxVersion < 7) //firefox7以下版本
document.getElementById(imgPreviewId).setAttribute("src", fileObj.files[0].getAsDataURL());
else //firefox7.0+
document.getElementById(imgPreviewId).setAttribute("src", window.URL.createObjectURL(fileObj.files[0]));
else
document.getElementById(imgPreviewId).setAttribute("src", fileObj.value);
else
alert("仅支持" + allowExtention + "为后缀名的文件!");
fileObj.value = ""; //清空选中文件
if (browserVersion.indexOf("MSIE") > -1)
fileObj.select();
document.selection.clear();
fileObj.outerHTML = fileObj.outerHTML;
function setTheFileButton_Cover_SelectImageButton()
// debugger;
// var position = $("#selectImage", "#cover").position();
// var css = top: position.top, left: position.left ;
// $("#theFile", "#fileDiv").css(css);
var $imgHolder = $(\'#imgHolder\', "#productImage");
var tempDiv = $("#temp_div");
$("#select", "#cover").click(function ()
$("#theFile", "#fileDiv").click().select();
);
$("#theFile", "#fileDiv").click(function ()
$(this).blur();
);
$("#theFile", "#fileDiv").change(function ()
PreviewImage(this, \'imgHolder\', \'productImage\');
setTheFileButton_Cover_SelectImageButton();
// alert("预览已生成!");
$("#imageUpload").prop("disabled", false);
); 参考技术A 表单上传 后台files处理
jQuery图片上传前先在本地预览(不经过后端处理)
前段时间遇到一个问题,前端想实现图片上传预览(不经过后端PHP或JAVA处理),用户点击file按钮上传文件,点击确定马上就能看到预览的效果,但在实现的时候无论怎样都取不到file上图片的真实路径,得到的反而是C:\fakepath\a.jpg,这个路径是错误的。百度之后得到说浏览器基于保护用户的相关安全措施,隐藏了上传的真实路径,用fakepath代替,当然,调整浏览器的相关安全设置可以解决这个问题。但我们不可能让所有用户都通过设置浏览器的安全设置来进行图片上传,这种方法在网络交互上显然不现实。
/*
*名称:图片上传本地预览插件 v1.1
*介绍:基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari
*插件网站:http://keleyi.com/keleyi/phtml/image/16.htm
*参数说明:
Img:图片ID;
Width:预览宽度;
Height:预览高度;
ImgType:支持文件类型;
Callback:选择文件显示图片后回调方法;
*使用方法:
<div> <img id="ImgPr" width="120" height="120" /></div> <input type="file" id="up" />
把需要进行预览的IMG标签外 套一个DIV 然后给上传控件ID给予uploadPreview事件
$("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120, ImgType: ["gif", "jpeg", "jpg", "bmp", "png"], Callback: function () { }});
实例:
jQuery.fn.extend({ uploadPreview: function (opts) { var _self = this, _this = $(this); opts = jQuery.extend({ Img: "ImgPr", Width: 100, Height: 100, ImgType: ["gif", "jpeg", "jpg", "bmp", "png"], Callback: function () {} }, opts || {}); _self.getObjectURL = function (file) { var url = null; if (window.createObjectURL != undefined) { url = window.createObjectURL(file) } else if (window.URL != undefined) { url = window.URL.createObjectURL(file) } else if (window.webkitURL != undefined) { url = window.webkitURL.createObjectURL(file) } return url }; _this.change(function () { if (this.value) { if (!RegExp("\.(" + opts.ImgType.join("|") + ")$", "i").test(this.value.toLowerCase())) { alert("选择文件错误,图片类型必须是" + opts.ImgType.join(",") + "中的一种"); this.value = ""; return false } //高版本Jquey使用 if ($.support.leadingWhitespace) if ($.browser.msie) { //低版本jquery中使用的方式 try { $("#" + opts.Img).attr(‘src‘, _self.getObjectURL(this.files[0])) } catch (e) { var src = ""; var obj = $("#" + opts.Img); var div = obj.parent("div")[0]; _self.select(); if (top != self) { window.parent.document.body.focus() } else { _self.blur() } src = document.selection.createRange().text; document.selection.empty(); obj.hide(); obj.parent("div").css({ ‘filter‘: ‘progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)‘, ‘width‘: opts.Width + ‘px‘, ‘height‘: opts.Height + ‘px‘ }); div.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = src } } else { $("#" + opts.Img).attr(‘src‘, _self.getObjectURL(this.files[0])) } opts.Callback() } }) } });
调用:
$(function () { $("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120 }); });
HTML结构:
<div> <img id="ImgPr" width="120" height="120" /> </div> <input type="file" id="up" />
以上是关于PHP怎样上传图片以及预览图片?的主要内容,如果未能解决你的问题,请参考以下文章