82 views

05至08更新后ThinkPHP+swfupload多图上传

By | 2019年3月3日

首先,让我们看看图片的效果。如果你需要下载,你可以学习。不一定是在ThinkHP中,但我确实喜欢使用ThinkHP进行开发。

wKioL1Mr-0aC72bCAAILmrMA__Y660.jpg

可以。现在我们需要的是在线下载很多swfupload.js,百度吧。之前有人给我加了QQ,说我的博客帖子大多是代码,不懂,后来我写了博客文章来解释想法,然后开始分享代码。

多图上传的全过程

1.写好html代码,包括上传以后显示的效果的html,以及加载swfupload组件.和flash

2.添加图片后,上传到php进行上传,返回上传图片的地址,加载到预览区。

3.点击X以后,ajax调用php的方法去删除预览区域的图片.

4.除了在预览区域添加图片和删除图片外,隐藏字段的值也会更改,以便在整个表单上载和提交之后,可以将图片的地址保存到数据库中。

好了。先写html代码吧。(css文件我就不贴了)

<!DOCTYPE html PUBLIC “-//W3C//DTD XHTML 1.0 Transitional//EN” “http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>
<html xmlns=”http://www.w3.org/1999/xhtml”>
<head>
<meta http-equiv=”Content-Type” content=”text/html; charset=utf-8″ />
<meta http-equiv=”Cache-control” content=”private, must-revalidate” />
<title>flash无刷新多图片上传</title>
<script type=”text/javascript”>
var path=’__STYLE__’;
var url=’__URL__’;
</script>
<script type=”text/javascript” src=”__STYLE__/js/jquery.js”></script>
<script type=”text/javascript” src=”__STYLE__/js/swfupload.js”></script>
<script type=”text/javascript” src=”__STYLE__/js/handlers.js”></script>
<link href=”__STYLE__/css/default.css” rel=”stylesheet” type=”text/css” />
<script type=”text/javascript”>
var swfu;
window.onload = function () {
swfu = new SWFUpload({
upload_url: “__URL__/uploadImg”,
post_params: {“PHPSESSID”: “<?php echo session_id();?>”},
file_size_limit : “2 MB”,
file_types : “*.jpg;*.png;*.gif;*.bmp”,
file_types_description : “JPG Images”,
file_upload_limit : “100”,
file_queue_error_handler : fileQueueError,
file_dialog_complete_handler : fileDialogComplete,
upload_progress_handler : uploadProgress,
upload_error_handler : uploadError,
upload_success_handler : uploadSuccess,
upload_complete_handler : uploadComplete,
button_image_url : “__STYLE__/images/upload.png”,
button_placeholder_id : “spanButtonPlaceholder”,
button_width: 113,
button_height: 33,
button_text : ”,
button_text_style : ‘.spanButtonPlaceholder { font-family: Helvetica, Arial, sans-serif; font-size: 14pt;} ‘,
button_text_top_padding: 0,
button_text_left_padding: 0,
button_window_mode: SWFUpload.WINDOW_MODE.TRANSPARENT,
button_cursor: SWFUpload.CURSOR.HAND,
flash_url : “__STYLE__/swf/swfupload.swf”,
custom_settings : {
upload_target : “divFileProgressContainer”
},
debug: false
});
};
</script>
</head>
<body>
<form action=”__URL__/s” method=”post”>
<div style=”width: 610px; height: auto; border: 1px solid #e1e1e1; font-size: 12px; padding: 10px;”>
<span id=”spanButtonPlaceholder”></span>
<div id=”divFileProgressContainer”></div>
<div id=”thumbnails”>
<ul id=”pic_list” style=”margin: 5px;”></ul>
<div style=”clear: both;”></div>
</div>
</div>
<input type=”hidden” name=”s” id=”” value=””/>
<input type=”submit” value=”提交” />
</form>
</body>
</html>

详细说一下swfupload的配置项

upload_url 是上传图片处理的php地址

file_size_limit 上传大小限制

file_upload_limit 限制用户一次上载多张图片,0不受限制

file_queue_error_handler

file_dialog_complete_handler 关闭文件上载选择框后要执行的方法

upload_error_handler 发生文件上载错误时要执行的方法

upload_success_handler 文件上传成功后的执行方法

upload_complete_handler 文件上传完成后的执行方法

debug: false 想研究swfupload的可以把这个设置为true,调试模式

接下来是上传图片的PHP代码。我用的是tp上传类,简单易懂。

function uploadImg() {
import(‘ORG.Net.UploadFile’);
$upload = new UploadFile();// 实例化上传类
$upload->maxSize = 3145728 ;// 设置附件上传大小
$upload->allowExts = array(‘jpg’, ‘gif’, ‘png’, ‘jpeg’);// 设置附件上传类型
$savepath=’./uploads/’.date(‘Ymd’).’/’;
if (!file_exists($savepath)){
mkdir($savepath);
}
$upload->savePath = $savepath;// 设置附件上传目录
if(!$upload->upload()) {// 上传错误提示错误信息
$this->error($upload->getErrorMsg());
}else{// 上传成功 获取上传文件信息
$info = $upload->getUploadFileInfo();
}
print_r(J(__ROOT__.’/’.$info[0][‘savepath’].’/’.$info[0][‘savename’]));
}

当上传成功时,echo或print输出地址,因为它使用Ajax。

预览区域设置的代码

function uploadSuccess(file, serverData){
addImage(serverData);
var $svalue=$(‘form>input[name=s]’).val();
if($svalue==”){
$(‘form>input[name=s]’).val(serverData);
}else{
$(‘form>input[name=s]’).val($svalue+”|”+serverData);
}
}
function addImage(src){
var newElement = “<li><img class=’content’ src='” + src + “‘ style=\”width:100px;height:100px;\”><img class=’button’ src=”+window.path+”/images/fancy_close.png></li>”;
$(“#pic_list”).append(newElement);
$(“img.button”).last().bind(“click”, del);
}

serrdata是以php返回的图像地址。返回后,它直接调用addImage方法将地址加载到一个ul中。同时更新隐藏域中的值

删除图片设置

var del = function(){
// var fid = $(this).parent().prevAll().length + 1;
var src=$(this).siblings(‘img’).attr(‘src’);
var $svalue=$(‘form>input[name=s]’).val();
$.ajax({
type: “GET”, //访问WebService使用Post方式请求
url: window.url+”/del”, //调用WebService的地址和方法名称组合—WsURL/方法名
data: “src=” + src,
success: function(data){
var $val=$svalue.replace(data,”);
$(‘form>input[name=s]’).val($val);
}
});
$(this).parent().remove();
}
ajax方式,提交到php方式,成功则更新隐藏域里的val,并且销毁元素。

function del() {
$src=str_replace(__ROOT__.’/’, ”, str_replace(‘//’, ‘/’, $_GET[‘src’]));
if (file_exists($src)){
unlink($src);
}
print_r($_GET[‘src’]);
exit();
}
删除的简单方法是从Ajax提交的地址中删除文件并返回删除的地址。Ajax处理并自动更新隐藏域的VAL

整个thinkhp+swfupload上传方法都结束了。这很简单。

本文转载于:http://win-man.com
本文关键词:编程教程 网络安全专家 高防解决方案专家
作者:IT编程顾问

发表评论

电子邮件地址不会被公开。 必填项已用*标注