Home >Backend Development >PHP Tutorial >上传图片 - 在输入框内粘贴图片并上传到服务器,请问怎么用PHP实现?

上传图片 - 在输入框内粘贴图片并上传到服务器,请问怎么用PHP实现?

WBOY
WBOYOriginal
2016-06-06 20:27:381296browse

在输入框内粘贴图片并上传到服务器,请问怎么用PHP实现?(并不是上传本地文件的那种,是从剪切板来的)

回复内容:

在输入框内粘贴图片并上传到服务器,请问怎么用PHP实现?(并不是上传本地文件的那种,是从剪切板来的)

大概原理就是:监听粘贴时间,然后检测是否有图片,然后触发AJAX上传,PHP接收原理和文件上传一致

<code><?php header("Access-Control-Allow-Origin:*");
$url  = 'http://'.$_SERVER['HTTP_HOST'];
$file = (isset($_POST["file"])) ? $_POST["file"] : '';
if($file)
{
    $data = base64_decode(str_replace('data:image/png;base64,', '', $file));  //截图得到的只能是png格式图片,所以只要处理png就行了
    $name = md5(time()) . '.png';  // 这里把文件名做了md5处理
    file_put_contents($name, $data);
    echo "$url/$name";
    die;
}
?>


<div id="box" style="width:400px;height:400px;border:1px solid;" contenteditable>
</div>
<input type="hidden" name="img" value="" id="img_puth">

<script>
    //查找box元素,检测当粘贴时候,
    document.querySelector('#box').addEventListener('paste', function(e) {

        //判断是否是粘贴图片
        if (e.clipboardData && e.clipboardData.items[0].type.indexOf('image') > -1) 
        {
            var that      = this,
                reader   = new FileReader();
                file     = e.clipboardData.items[0].getAsFile();

            //ajax上传图片
            reader.onload = function(e) 
            {
                var xhr = new XMLHttpRequest(),
                    fd  = new FormData();

                xhr.open('POST', '', true);
                xhr.onload = function () 
                {
                    var img = new Image();
                    img.src = xhr.responseText;

                       // that.innerHTML = '<img src="'+img.src+'" alt=""/>';
                    document.getElementById("img_puth").value = img.src;
                }

                // this.result得到图片的base64 (可以用作即时显示)
                fd.append('file', this.result); 
                that.innerHTML = '<img src="'+this.result+'" alt=""/>';
                xhr.send(fd);
            }
            reader.readAsDataURL(file);
        }
    }, false);
</script></code>
Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn