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


Posted in PHP onMay 17, 2015

今天发现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 相关文章推荐
php开启安全模式后禁用的函数集合
Jun 26 PHP
浅析php中json_encode()和json_decode()
May 25 PHP
php时间戳格式化显示友好的时间函数分享
Oct 21 PHP
php计算两个坐标(经度,纬度)之间距离的方法
Apr 17 PHP
JavaScript实现滚动栏效果的方法
Apr 27 PHP
修改WordPress中文章编辑器的样式的方法详解
Dec 15 PHP
Zend Framework教程之Zend_Config_Ini用法分析
Mar 23 PHP
PHP递归遍历指定文件夹内的文件实现方法
Nov 15 PHP
php cli模式下获取参数的方法
May 05 PHP
thinkPHP框架实现的简单计算器示例
Dec 07 PHP
PHP设计模式之迭代器模式Iterator实例分析【对象行为型】
Apr 26 PHP
php使用Swoole实现毫秒级定时任务的方法
Sep 04 PHP
php获取json数据所有的节点路径
May 17 #PHP
php中memcache 基本操作实例
May 17 #PHP
PHP实现过滤各种HTML标签
May 17 #PHP
支持中文的PHP按字符串长度分割成数组代码
May 17 #PHP
php 批量查询搜狗sogou代码分享
May 17 #PHP
PHP解密Unicode及Escape加密字符串
May 17 #PHP
PHP实现远程下载文件到本地
May 17 #PHP
You might like
优化PHP代码技巧的小结
2013/06/02 PHP
php中simplexml_load_file函数用法实例
2014/11/12 PHP
PHP表单数据写入MySQL数据库的代码
2016/05/31 PHP
php使用curl获取header检测开启GZip压缩的方法
2018/08/15 PHP
php pdo连接数据库操作示例
2019/11/18 PHP
Javascript公共脚本库系列(一): 弹出层脚本
2011/02/24 Javascript
利用jq让你的div居中的好方法分享
2013/11/21 Javascript
2种jQuery 实现刮刮卡效果
2015/02/01 Javascript
JavaScript实现跨浏览器的添加及删除事件绑定函数实例
2015/08/04 Javascript
jquery弹出遮掩层效果【附实例代码】
2016/04/28 Javascript
微信小程序 页面之间传参实例详解
2017/01/13 Javascript
Vue中this.$router.push参数获取方法
2018/02/27 Javascript
nuxt.js 缓存实践
2018/06/25 Javascript
在vue中利用全局路由钩子给url统一添加公共参数的例子
2019/11/01 Javascript
微信小程序button标签open-type属性原理解析
2020/01/21 Javascript
[42:24]完美世界DOTA2联赛循环赛 LBZS vs DM BO2第一场 11.01
2020/11/02 DOTA
Python实现购物评论文本情感分析操作【基于中文文本挖掘库snownlp】
2018/08/07 Python
详解Python3之数据指纹MD5校验与对比
2019/06/11 Python
python把ipynb文件转换成pdf文件过程详解
2019/07/09 Python
在django中实现页面倒数几秒后自动跳转的例子
2019/08/16 Python
python基于plotly实现画饼状图代码实例
2019/12/16 Python
Python实现随机生成任意数量车牌号
2020/01/21 Python
python实现PDF中表格转化为Excel的方法
2020/06/16 Python
python爬虫使用正则爬取网站的实现
2020/08/03 Python
台湾团购、宅配和优惠券:17Life
2017/08/14 全球购物
美国和加拿大房车出售在线分类广告:RVT.com
2018/04/23 全球购物
Overload和Override的区别
2012/09/02 面试题
西安交大自主招生自荐信
2014/01/27 职场文书
创建省级文明单位实施方案
2014/02/27 职场文书
我们的节日端午节活动方案
2014/03/02 职场文书
教师党员群众路线教育实践活动心得体会
2014/11/04 职场文书
2014小学二年级班主任工作总结
2014/12/05 职场文书
工程项目合作意向书
2015/05/08 职场文书
不服劳动仲裁起诉书
2015/05/20 职场文书
2015年党务工作者个人工作总结
2015/10/22 职场文书
导游词之昭君岛
2020/01/17 职场文书