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>

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

相关文章

  • Yii 框架使用Gii生成代码操作示例

    Yii 框架使用Gii生成代码操作示例

    这篇文章主要介绍了Yii 框架使用Gii生成代码操作,结合实例形式F分析了Yii 使用Gii生成代码基本操作步骤与相关注意事项,需要的朋友可以参考下
    2020-05-05
  • PHP register_shutdown_function()函数的使用示例

    PHP register_shutdown_function()函数的使用示例

    这篇文章主要介绍了PHP register_shutdown_function()函数的使用示例,当我们的脚本执行完成或者意外死掉导致 php 执行即将关闭时,register_shutdown_function()这个函数会被调用,需要的朋友可以参考下
    2015-06-06
  • 完美解决thinkphp验证码出错无法显示的方法

    完美解决thinkphp验证码出错无法显示的方法

    这篇文章主要介绍了完美解决thinkphp验证码出错无法显示的方法,对比官网给出的方法结合自身的实践,给出了一个相对可行的解决方法,具有一定的参考借鉴价值,需要的朋友可以参考下
    2014-12-12
  • Yii实现简单分页的方法

    Yii实现简单分页的方法

    这篇文章主要介绍了Yii实现简单分页的方法,涉及Yii模型调用读取数据及视图操作相关技巧,需要的朋友可以参考下
    2016-04-04
  • yii实现CheckBox复选框在同一行显示的方法

    yii实现CheckBox复选框在同一行显示的方法

    这篇文章主要介绍了yii实现CheckBox复选框在同一行显示的方法,对比了网上搜集的方法,给出了改进的意见,非常具有实用价值,需要的朋友可以参考下
    2014-12-12
  • tp5框架的增删改查操作示例

    tp5框架的增删改查操作示例

    这篇文章主要介绍了tp5框架的增删改查操作,结合实例形式分析了thinkPHP5框架数据库连接及增删改查相关操作的控制器与视图使用技巧,需要的朋友可以参考下
    2019-10-10
  • PHP多进程编程实例

    PHP多进程编程实例

    这篇文章主要介绍了PHP多进程编程实例,本文讲解的是在Linux下实现PHP多进程编程,需要的朋友可以参考下
    2014-10-10
  • PHP使用header方式实现文件下载功能

    PHP使用header方式实现文件下载功能

    这篇文章主要介绍了PHP使用header方式实现文件下载功能,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-11-11
  • PHP递归获取目录内所有文件的实现方法

    PHP递归获取目录内所有文件的实现方法

    下面小编就为大家带来一篇PHP递归获取目录内所有文件的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-11-11
  • ThinkPHP3.1新特性之动态设置自动完成和自动验证示例

    ThinkPHP3.1新特性之动态设置自动完成和自动验证示例

    这篇文章主要介绍了ThinkPHP3.1动态设置自动完成和自动验证,需要的朋友可以参考下
    2014-06-06

最新评论