【发布时间】:2015-10-18 08:59:47
【问题描述】:
我有 javascript 代码可以检测何时将图像粘贴到 contenteditable 字段中:
document.onpaste = function(event){
var items=(event.clipboardData || event.originalEvent.clipboardData || event.dataTransfer).items;
for(i in items){
var item=items[i];
if(item.kind==='file' && ~item.type.indexOf("image")){ //is file and is image
event.preventDefault();
var blob=item.getAsFile();
console.log(item, blob);
var data=new FormData();
data.append('fname','imageFromClipboard'); //extension for file name??
data.append('newImage',blob);
sendImage(data); //just a $.POST request
}
}
}
以及接收图像 POST 请求的 PHP 代码:
$image = $_FILES['newImage'];
$imageFileType = pathinfo($image["name"],PATHINFO_EXTENSION); // obviously doesn't work
$imageId = new ImageId();
$imageName = $imageId.".".$imageFileType;
// [... some checks on the file ...]
$targetFile = "../../images/uploads/{$imageName}";
if($imageOK && move_uploaded_file($image["tmp_name"],$targetFile)){
//[ do stuff ]
如何从 blob 可靠地获取文件扩展名?我应该用 JS 还是 PHP 来做? 所有可能的图像文件类型是否可以只在斜杠处拆分 MIME 类型(例如“image/png”)并将其用作扩展名?
【问题讨论】:
标签: javascript php blob file-extension