欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

讓codeigniter與swfupload整合的最佳解決方案

 更新時(shí)間:2014年06月12日 16:50:41   投稿:shichen2014  
網(wǎng)上有很多關(guān)于ci與swfupload的帖子,不過(guò),并不是很完整,所以,這里綜合各家優(yōu)點(diǎn),經(jīng)過(guò)自己實(shí)際經(jīng)驗(yàn),做了下整理,需要的朋友可以參考下

codeigniter是一款輕量,便捷的MVC框架,最近的項(xiàng)目涉及到批量上傳,于是,就是用了swfupload這個(gè)插件,雖然網(wǎng)上有很多關(guān)于ci與swfupload的帖子,不過(guò),并不是很完整,所以,這里綜合各家優(yōu)點(diǎn),經(jīng)過(guò)自己實(shí)際經(jīng)驗(yàn),做了下整理。

問(wèn)題1:獲取不到文件類(lèi)型?

回答: 由于SWFUPLOAD所有類(lèi)型文件的MIME均為application/octet-stream,故使用Codeigniter自帶的上傳類(lèi)無(wú)法準(zhǔn)確獲取是否為圖片,根據(jù)ci官方的wiki已經(jīng)給出了解答

In your view file, include the SWFUpload javascript file:

復(fù)制代碼 代碼如下:
<script type="text/javascript" src="jscripts/SWFUpload/mmSWFUpload.js"></script>
In your controller, pass “Filedata” as the name value for the do_upload function:
$this->upload->do_upload('Filedata')
In your mimes.php file, add ‘a(chǎn)pplication/octet-stream' for all allowed image formats
'gif'    =>    array('image/gif', 'application/octet-stream'),
'jpeg'    =>    array('image/jpeg', 'image/pjpeg', 'application/octet-stream'),
'jpg'    =>    array('image/jpeg', 'image/pjpeg', 'application/octet-stream'),
'jpe'    =>    array('image/jpeg', 'image/pjpeg', 'application/octet-stream'),
'png'    =>    array('image/png',  'image/x-png', 'application/octet-stream'),

問(wèn)題2:帶有session驗(yàn)證的后臺(tái),會(huì)導(dǎo)致上傳后退出登陸的狀況

回答:

一般方法:swfuplaod在上傳時(shí),會(huì)新開(kāi)一個(gè)進(jìn)程,和原來(lái)的進(jìn)程不一致,要解決這個(gè)問(wèn)題,需要指定session_id,然后在登錄頁(yè)面判斷,如果有post過(guò)來(lái)的session_id,那么就用函數(shù)session_id( $_POST['PHP_SESSIONID'])指定一下。
上傳頁(yè)的JS里面,可以獲取當(dāng)前的SESSION_ID的。

ci中的狀態(tài):一般情況下,因?yàn)橹T如uploadify,swfupload采用的都是flash客戶(hù)端,這樣它們產(chǎn)生的useragent與用戶(hù)使用瀏覽器的user-agent必然不同。所以,雖然用戶(hù)登錄了你的系統(tǒng)產(chǎn)生了一個(gè)session,但是當(dāng)觸發(fā)上傳程序時(shí)會(huì)產(chǎn)生另一個(gè)session(在上述useragent選項(xiàng)開(kāi)啟的情況下)。

所以,不是session丟失了,而是當(dāng)你上傳文件時(shí),CI為uploadify另外創(chuàng)建了一個(gè)session。

解決方法1:將$config['sess_match_useragent']設(shè)置成FALSE,重試。

解決方法2(推薦):為了安全起見(jiàn),不建議使用第1條解決方案,而是使用另外的驗(yàn)證方法,比如在每次上傳時(shí),在url中附加一個(gè)token與服務(wù)器端的token比對(duì)(比如這個(gè)token可以是用戶(hù)名的hash值)。具體實(shí)現(xiàn)方法請(qǐng)參考stblog的上傳驗(yàn)證實(shí)現(xiàn)(使用的是swfupload)。----我嘗試了這個(gè)方法,重點(diǎn)在于,如果你的session類(lèi)是放在autoload里自動(dòng)加載的,那么,這樣肯定是失敗的,解決辦法是,新建一個(gè)類(lèi),例如MY_Controller繼承于CI_Controller,用于后臺(tái)登陸,需要權(quán)限判斷后臺(tái)處理,講upload類(lèi)繼承于CI_Controller這樣的話(huà),就不經(jīng)過(guò)session類(lèi)的驗(yàn)證了,當(dāng)然上傳還是得驗(yàn)證,不過(guò)可以用post_params傳值進(jìn)行驗(yàn)證:

示例:

復(fù)制代碼 代碼如下:
class Upload extends CI_Controller {
//*******
//*****
}
//~~~~~~~~~~~~~~~~~
class client_photo extends MY_Controller {
    function __construct() {
        parent::__construct();
    }
 function index() {
}
}
//~~~~~~~~~~~~~~~~~~~~~
class MY_Controller extends CI_Controller {
    public function __construct() {
        parent::__construct();
        $this->load->library('session');
}
}

相關(guān)文章

最新評(píng)論