php实现粘贴截图并完成上传功能

 更新时间:2015年05月17日 16:49:39   投稿:hebedich  
知乎回答问题编辑框用 Ctrl+V 粘贴图片是如何实现的?刚发现知乎编辑器有这么强的功能,在研究的过程中发现原来segmentfault也实现了这么强大的功能,下面结合2者来看看我们如何实现。

今天发现segmentfault的评论留言里面可以粘贴上传图片,于是研究了下怎么实现的!
原理很简单其实就是监控粘贴事件,然后检测是否粘贴的东西里面有图片,有的话直接触发ajax上传

代码可以直接运行,有兴趣你们可以试试

<?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>

以上所述就是本文的全部内容了,希望大家能够喜欢。

相关文章

  • php curl简单采集图片生成base64编码(并附curl函数参数说明)

    php curl简单采集图片生成base64编码(并附curl函数参数说明)

    今天小编就为大家分享一篇关于php curl简单采集图片生成base64编码(并附curl函数参数说明),小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • php 使用mpdf实现指定字段配置字体样式的方法

    php 使用mpdf实现指定字段配置字体样式的方法

    前两天在做一个pdf导出功能,使用的插件是kartik-v/yii2-mpdf,此插件使用的是mpdf。接下来通过本文给大家介绍php 使用mpdf实现指定字段配置字体样式的方法,需要的朋友可以参考下
    2019-07-07
  • Yii2 assets清除缓存的方法

    Yii2 assets清除缓存的方法

    这篇文章主要介绍了Yii2 assets清除缓存的方法,涉及Yii中assets相关函数调用与配置技巧,需要的朋友可以参考下
    2016-05-05
  • laravel5实现微信第三方登录功能

    laravel5实现微信第三方登录功能

    这篇文章主要介绍了laravel5实现微信第三方登录功能,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-12-12
  • 基于PHP实现用户在线状态检测

    基于PHP实现用户在线状态检测

    这篇文章主要介绍了基于PHP实现用户在线状态检测,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • Zend Framework入门教程之Zend_Config组件用法详解

    Zend Framework入门教程之Zend_Config组件用法详解

    这篇文章主要介绍了Zend Framework入门教程之Zend_Config组件用法,结合实例形式分析了Zend_Config组件针对各种类型配置文件操作的相关技巧,需要的朋友可以参考下
    2016-12-12
  • mysqli_set_charset和SET NAMES使用抉择及优劣分析

    mysqli_set_charset和SET NAMES使用抉择及优劣分析

    尽量使用mysqli_set_charset(mysqli:set_charset)而不是SET NAMES, 当然, 这个内容在PHP手册中也有叙及, 但是却没有解释为什么,接下来为您揭下神秘面纱
    2013-01-01
  • ThinkPHP表单令牌错误的相关解决方法分析

    ThinkPHP表单令牌错误的相关解决方法分析

    这篇文章主要介绍了ThinkPHP表单令牌错误的相关解决方法,分析了thinkPHP出现令牌错误的相关处理过程与解决方法,具有一定参考借鉴价值,需要的朋友可以参考下
    2016-05-05
  • php缩小png图片不损失透明色的解决方法

    php缩小png图片不损失透明色的解决方法

    png图片如果带了透明色按照jpg的方式来缩小,就会造成透明色损失。那么如何处理才能保存透明色呢?下面的代码就可以解决这个问题
    2013-12-12
  • smarty简单模板变量输出方法

    smarty简单模板变量输出方法

    这篇文章主要介绍了smarty简单模板变量输出方法,涉及Smarty模板中数组的定义、使用及assign方法进行变量替换的相关技巧,需要的朋友可以参考下
    2016-07-07

最新评论