uploadify 火狐 php,ThinkPHP 解决使用uploadify 在Firefox浏览器上传图片出现HTTP 302报错...

一、uploadify使用详解

1.在html中的file标签可以用来上传文件,但是在文件较大或者多文件上传的时候,file标签就不太适合了。而uploadify插件是基于js的jQuery库写的,结合ajax和flash,实现多文件上传功能。

2.主要文件:

jquery.uploadify.js (主要插件)

jquery-1.7.2.min.js (jquery主件)

uploadify.swf (flash上传插件)

uploadify.css (上传样式表)

uploadify-cancel.png (flash上传按钮图标)

uploadify.php (上传处理数据)

uploads文件夹 (默认保存上传文件目录)

3.在上传的页面引入js/css文件,然后初始化一些参数变量

$(function () {

$('#file_upload').uploadify({

buttonText:'选择文件',

swf: '{$smarty.const.SITE_PUBLIC_URL}Admin/uploadify/uploadify.swf',

uploader: '{$smarty.const.__CONTROLLER__}/Upload',

method:'get',

onSWFReady:function(){

$('#file_upload').uploadify('disable', true);

},

onUploadStart:function(file){

var spot=$('#spot').val();

var coid={$arrData['coid']};

var session_id={$smarty.session.session_id};

$("#file_upload").uploadify("settings", "formData", { 'spot' : spot,'coid':coid,'session_id':session_id});

},

onUploadSuccess:function(file, data, response){

}

});

});

接着就是在body里面添加调用标签

多图上传*

最后就是在后台处理上传的文件。。。。。。

二、出现的问题

1.由于jquery uploadify是借助flash来实现上传的,所以可能在浏览器禁止网站运行flash是会出现如下这个情况:

281afd06e3fd

281afd06e3fd

281afd06e3fd

正常的情况:

281afd06e3fd

2.Jquery Uploadify在IE浏览器可以正常上传,在Chrome浏览器使用也是正常的,只有在Firefox浏览器使用才会出现HTTP 302报错。

281afd06e3fd

在实现异步上传的时候,每一个文件在上传时都会提交给服务器一个请求。每个请求都需要安全验证,session和cookie的校验。由于jquery uploadify是借助flash来实现上传的,每一次向后台发送数据流请求时,IE会自动把本地cookie存储捆绑在一起发送给服务器。但是firefox不会这样做,所以在进行验证登录的时候就出现了HTTP 302 报错。如果把这个模块放在不需要验证的地方是不会出现这种报错的。

Session又称为会话状态,是Web系统中最常用的状态,用于维护和当前浏览器实例相关的一些信息。Session对于每一个客户端是不一样的,用户首次与Web服务器建立连接的时候,服务器会给用户分发一个 SessionID作为标识。SessionID是一个由24个字符组成的随机字符串。用户每次提交页面,浏览器都会把这个SessionID包含在 HTTP头中提交给Web服务器,这样Web服务器就能区分当前请求页面的是哪一个客户端。

三.解决问题

1.解决方案一:

在插件初始化的时候,把本地记录下来的session值,以及身份验证值传给初始化方法,进行参数赋值,这样,每次异步请求上传文件的时候,相应的 session值就包含在请求文件中了。

onUploadStart:function(file){

var spot=$('#spot').val();

var coid={$arrData['coid']};

var session_id={$smarty.session.session_id};

$("#file_upload").uploadify("settings", "formData", {'spot' : spot,'coid':coid,'session_id':session_id});

},

服务器端(ThinkPHP控制器)代码

public function _initialize(){

//此处为解决Uploadify在火狐下出现http 302错误 重新设置SESSION

$session_name= session_name();

if(isset($_GET['session_id']))

{

session_id($_GET['session_id']);

session_start();

}

//执行登陆验证检测函数

$this->powerverify();

}

2.解决方案二:

onUploadStart:function(file){

var spot=$('#spot').val();

var coid={$arrData['coid']};

var session_id={$smarty.session.session_id};

$("#file_upload").uploadify("settings", "formData", {'spot' : spot,'coid':coid,'session_id':session_id});

},

服务器端(ThinkPHP控制器)代码

在核心类文件夹里下的Conf/convention.php中 将 VAR_SESSION_ID打开(建议在模块的conf文件中添加配置,如在模块下的Conf/config.php中添加 ‘VAR_SESSION_ID’ => ‘session_id’,)

return array(

'VAR_SESSION_ID' => 'session_id',//sessionID的提交变量

);

在解决了问题之后,我再上Firefox浏览器去上传图片就成功了!

281afd06e3fd

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值