成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

上傳文件專題

Cympros / 3318人閱讀

摘要:默認(rèn)為即是開文件上傳至服務(wù)器上存儲臨時文件的地方,如果沒指定就會用系統(tǒng)默認(rèn)的臨時文件夾望文生意,即允許上傳文件大小的最大值。

1.一般上傳文件都是利用form表單已經(jīng)提交,并且一般都是通過http協(xié)議,小編在這里決得不防試試ftp協(xié)議上傳文件
2.form表單上傳,那么form表單里enctype="multipart/form-data"這個元素就不可少了
3.上傳
//判斷是否上傳成功(是否使用post方式上傳) 、
if(is_uploaded_file($_FILES"myfile")) {

    //把文件轉(zhuǎn)存到你希望的目錄(不要使用copy函數(shù))  
    $uploaded_file=$_FILES["myfile"]["tmp_name"]; 
    //我們給每個用戶動態(tài)的創(chuàng)建一個文件夾  
    $user_path=$_SERVER["DOCUMENT_ROOT"]."/studyphp/file/up/".$username;  
    //判斷該用戶文件夾是否已經(jīng)有這個文件夾  
    if(!file_exists($user_path)) {  
        mkdir($user_path);  
    }  
    $file_true_name=$_FILES["myfile"]["name"];    $move_to_file=$user_path."/".time().rand(1,1000).substr($file_true_name,strrpos($file_true_name,"."));  
    if(move_uploaded_file($uploaded_file,iconv("utf-8","gb2312",$move_to_file))) {  
        echo $_FILES["myfile"]["name"]."上傳成功";  
    } else {  
        echo "上傳失敗";  
    }  
} else {  
    echo "上傳失敗";  
} 

4.考慮的元素有文件大小,文件類型,如何防止用戶圖片覆蓋問題,如何防止同一個用戶的文件名相同的問題
5.假如你使用的是lnmp架構(gòu),那么針對nginx,針對php又有哪些設(shè)置針對文件上傳有關(guān)呢?
php:
file_uploads = on ;是否允許通過HTTP上傳文件的開關(guān)。默認(rèn)為ON即是開
upload_tmp_dir ;文件上傳至服務(wù)器上存儲臨時文件的地方,如果沒指定就會用系統(tǒng)默認(rèn)的臨時文件夾
upload_max_filesize = 8m ;望文生意,即允許上傳文件大小的最大值。默認(rèn)為2M
post_max_size = 8m ;指通過表單POST給PHP的所能接收的最大值,包括表單里的所有值。默認(rèn)為8M
進(jìn)一步配置以下的參數(shù)
max_execution_time = 600 ;每個PHP頁面運(yùn)行的最大時間值(秒),默認(rèn)30秒
max_input_time = 600 ;每個PHP頁面接收數(shù)據(jù)所需的最大時間,默認(rèn)60秒
memory_limit = 8m ;每個PHP頁面所吃掉的最大內(nèi)存,默認(rèn)8M
把上述參數(shù)修改后,在網(wǎng)絡(luò)所允許的正常情況下,就可以上傳大體積文件了
max_execution_time = 600
max_input_time = 600
memory_limit = 32m
file_uploads = on
upload_tmp_dir = /tmp
upload_max_filesize = 32m
post_max_size = 32m
nginx:
找到 http{} 段,在其中添加一行配置:
client_max_body_size 8m;
這也是nginx:413 Request Entity Too Large的處理辦法
下面負(fù)上利用ftp上傳文件的例子:
/**

仿寫CodeIgniter的FTP類

FTP基本操作:

1) 登陸; connect

2) 當(dāng)前目錄文件列表; filelist

3) 目錄改變; chgdir

4) 重命名/移動; rename

5) 創(chuàng)建文件夾; mkdir

6) 刪除; delete_dir/delete_file

7) 上傳; upload

8) 下載 download
*

@author quanshuidingdang
*/

class Ftp {

private $hostname
= "";
private $username
= "";
private $password
= "";
private $port
= 21;
private $passive
= TRUE;
private $debug
= TRUE;
private $conn_id
= FALSE;

/**

構(gòu)造函數(shù)
*

@param array 配置數(shù)組 : $config = array("hostname"=>"","username"=>"","password"=>"","port"=>""...);
*/

public function __construct($config = array()) {
if(count($config) > 0) {
$this->_init($config);
}
}

/**

FTP連接
*

@access public

@param array 配置數(shù)組

@return boolean
*/

public function connect($config = array()) {
if(count($config) > 0) {
$this->_init($config);
}
//判斷是否打開了ftp連接
if(FALSE === ($this->conn_id = @ftp_connect($this->hostname,$this->port))) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_connect");
}
return FALSE;
}
//判斷是否登錄成功
if( ! $this->_login()) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_login");
}
return FALSE;
}
//判斷是否開啟FTP被動模式
if($this->passive === TRUE) {
ftp_pasv($this->conn_id, TRUE);
}

return TRUE;
}

/**

目錄改變
*

@access public

@param string 目錄標(biāo)識(ftp)

@param boolean

@return boolean
*/

public function chgdir($path = "", $supress_debug = FALSE) {
if($path == "" OR ! $this->_isconn()) {
return FALSE;
}

$result = @ftp_chdir($this->conn_id, $path);

if($result === FALSE) {
if($this->debug === TRUE AND $supress_debug == FALSE) {
$this->_error("ftp_unable_to_chgdir:dir[".$path."]");
}
return FALSE;
}

return TRUE;
}

/**

目錄生成
*

@access public

@param string 目錄標(biāo)識(ftp)

@param int 文件權(quán)限列表

@return boolean
*/

public function mkdir($path = "", $permissions = NULL) {
if($path == "" OR ! $this->_isconn()) {
return FALSE;
}

$result = @ftp_mkdir($this->conn_id, $path);

if($result === FALSE) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_mkdir:dir[".$path."]");
}
return FALSE;
}

if( ! is_null($permissions)) {
$this->chmod($path,(int)$permissions);
}

return TRUE;
}

/**

上傳
*

@access public

@param string 本地目錄標(biāo)識

@param string 遠(yuǎn)程目錄標(biāo)識(ftp)

@param string 上傳模式 auto || ascii

@param int 上傳后的文件權(quán)限列表

@return boolean
*/

public function upload($localpath, $remotepath, $mode = "auto", $permissions = NULL) {
if( ! $this->_isconn()) {
return FALSE;
}
//判斷本地文件是否存在
if( ! file_exists($localpath)) {
if($this->debug === TRUE) {
$this->_error("ftp_no_source_file:".$localpath);
}
return FALSE;
}
//判斷上傳模式
if($mode == "auto") {

  //獲取文件后綴類型

$ext = $this->_getext($localpath);

  //根據(jù)后綴類型決定上傳模式是 FTP_ASCII(文本模式) 還是 FTP_BINARY(二進(jìn)制模式);

$mode = $this->_settype($ext);
}

$mode = ($mode == "ascii") ? FTP_ASCII : FTP_BINARY;
//上傳
$result = @ftp_put($this->conn_id, $remotepath, $localpath, $mode);
//判斷上傳是否成功
if($result === FALSE) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_upload:localpath[".$localpath."]/remotepath[".$remotepath."]");
}
return FALSE;
}
//判斷是否需要改寫文件權(quán)限
if( ! is_null($permissions)) {
$this->chmod($remotepath,(int)$permissions);
}

return TRUE;
}

/**

下載
*

@access public

@param string 遠(yuǎn)程目錄標(biāo)識(ftp)

@param string 本地目錄標(biāo)識

@param string 下載模式 auto || ascii

@return boolean
*/

public function download($remotepath, $localpath, $mode = "auto") {
if( ! $this->_isconn()) {
return FALSE;
}

if($mode == "auto") {
$ext = $this->_getext($remotepath);
$mode = $this->_settype($ext);
}

$mode = ($mode == "ascii") ? FTP_ASCII : FTP_BINARY;

$result = @ftp_get($this->conn_id, $localpath, $remotepath, $mode);

if($result === FALSE) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_download:localpath[".$localpath."]-remotepath[".$remotepath."]");
}
return FALSE;
}

return TRUE;
}

/**

重命名/移動
*

@access public

@param string 遠(yuǎn)程目錄標(biāo)識(ftp)

@param string 新目錄標(biāo)識

@param boolean 判斷是重命名(FALSE)還是移動(TRUE)

@return boolean
*/

public function rename($oldname, $newname, $move = FALSE) {
if( ! $this->_isconn()) {
return FALSE;
}

$result = @ftp_rename($this->conn_id, $oldname, $newname);

if($result === FALSE) {
if($this->debug === TRUE) {
$msg = ($move == FALSE) ? "ftp_unable_to_rename" : "ftp_unable_to_move";
$this->_error($msg);
}
return FALSE;
}

return TRUE;
}

/**

刪除文件
*

@access public

@param string 文件標(biāo)識(ftp)

@return boolean
*/

public function delete_file($file) {
if( ! $this->_isconn()) {
return FALSE;
}

$result = @ftp_delete($this->conn_id, $file);

if($result === FALSE) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_delete_file:file[".$file."]");
}
return FALSE;
}

return TRUE;
}

/**

刪除文件夾
*

@access public

@param string 目錄標(biāo)識(ftp)

@return boolean
*/

public function delete_dir($path) {
if( ! $this->_isconn()) {
return FALSE;
}

//對目錄宏的"/"字符添加反斜杠""
$path = preg_replace("/(.+?)/*$/", "1/", $path);

//獲取目錄文件列表
$filelist = $this->filelist($path);

if($filelist !== FALSE AND count($filelist) > 0) {
foreach($filelist as $item) {
//如果我們無法刪除,那么就可能是一個文件夾
//所以我們遞歸調(diào)用delete_dir()
if( ! @delete_file($item)) {
$this->delete_dir($item);
}
}
}

//刪除文件夾(空文件夾)
$result = @ftp_rmdir($this->conn_id, $path);

if($result === FALSE) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_delete_dir:dir[".$path."]");
}
return FALSE;
}

return TRUE;
}

/**

修改文件權(quán)限
*

@access public

@param string 目錄標(biāo)識(ftp)

@return boolean
*/

public function chmod($path, $perm) {
if( ! $this->_isconn()) {
return FALSE;
}

//只有在PHP5中才定義了修改權(quán)限的函數(shù)(ftp)
if( ! function_exists("ftp_chmod")) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_chmod(function)");
}
return FALSE;
}

$result = @ftp_chmod($this->conn_id, $perm, $path);

if($result === FALSE) {
if($this->debug === TRUE) {
$this->_error("ftp_unable_to_chmod:path[".$path."]-chmod[".$perm."]");
}
return FALSE;
}
return TRUE;
}

/**

獲取目錄文件列表
*

@access public

@param string 目錄標(biāo)識(ftp)

@return array
*/

public function filelist($path = ".") {
if( ! $this->_isconn()) {
return FALSE;
}

return ftp_nlist($this->conn_id, $path);
}

/**

關(guān)閉FTP
*

@access public

@return boolean
*/

public function close() {
if( ! $this->_isconn()) {
return FALSE;
}

return @ftp_close($this->conn_id);
}

/**

FTP成員變量初始化
*

@access private

@param array 配置數(shù)組

@return void
*/

private function _init($config = array()) {
foreach($config as $key => $val) {
if(isset($this->$key)) {
$this->$key = $val;
}
}

//特殊字符過濾
$this->hostname = preg_replace("|.+?://|","",$this->hostname);
}

/**

FTP登陸
*

@access private

@return boolean
*/

private function _login() {
return @ftp_login($this->conn_id, $this->username, $this->password);
}

/**

判斷con_id
*

@access private

@return boolean
*/

private function _isconn() {
if( ! is_resource($this->conn_id)) {
if($this->debug === TRUE) {
$this->_error("ftp_no_connection");
}
return FALSE;
}
return TRUE;
}

/**

從文件名中獲取后綴擴(kuò)展
*

@access private

@param string 目錄標(biāo)識

@return string
*/

private function _getext($filename) {
if(FALSE === strpos($filename, ".")) {
return "txt";
}

$extarr = explode(".", $filename);
return end($extarr);
}

/**

從后綴擴(kuò)展定義FTP傳輸模式 ascii 或 binary
*

@access private

@param string 后綴擴(kuò)展

@return string
*/

private function _settype($ext) {
$text_type = array (
"txt",
"text",
"php",
"phps",
"php4",
"js",
"css",
"htm",
"html",
"phtml",
"shtml",
"log",
"xml"
);

return (in_array($ext, $text_type)) ? "ascii" : "binary";
}

/**

錯誤日志記錄
*

@access prvate

@return boolean
*/

private function _error($msg) {
return @file_put_contents("ftp_err.log", "date[".date("Y-m-d H:i:s")."]-hostname[".$this->hostname."]-username[".$this->username."]-password[".$this->password."]-msg[".$msg."]n", FILE_APPEND);
}
}

使用:
require_once("ftp.php");
$config = array(
"hostname" => "101.64.183.92", //服務(wù)器地址
"username" => "ftpadminuser", //FTP登錄賬號
"password" => "admin_user", //FTP登錄密碼
"port" => 2112 //端口號
);
$ftp = new Ftp();
//連接
$ftp->connect($config);
//上傳第一個參數(shù)是本地文件名,第二個參數(shù)是FTP文件名
$rs=$ftp->upload("jsyh.flv","jsyh.flv");
if($rs){
echo 1;
}
// $ftp->download("ftp_upload.log","ftp_download.log");

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/22850.html

相關(guān)文章

  • PHP最佳實踐之上線準(zhǔn)備

    摘要:簡單來說,就是我們創(chuàng)建一對密鑰,其中一個是私鑰保存在本地設(shè)備中,另一個是公鑰,傳到你的中,之所以叫做密鑰對,是因為使用公鑰加密的消息只能使用對應(yīng)的私鑰解密。 配置 1).如果你使用的不是Pass,那么先配置VPS或者專用的服務(wù)器才能運(yùn)行PHP應(yīng)用。本文假設(shè)你會使用vim或者nano編輯器。2).我們選擇nginx服務(wù)器來作為我們的web服務(wù)器。 首次登錄 ssh [email protected]...

    sumory 評論0 收藏0
  • 教你從零開始使用wordpress生成微信小程序(小白版教程)

    摘要:準(zhǔn)備工作服務(wù)器最好使用服務(wù)器,小白推薦安裝寶塔面板。備案域名小程序賬號建議注冊企業(yè)賬號,可以使用已認(rèn)證的公眾號快速創(chuàng)建。七牛賬號使用,加快網(wǎng)站訪問速度。如需使用小程序發(fā)帖,也會用到。注意不要使用以下的。 showImg(https://segmentfault.com/img/bVUUeU?w=600&h=280); 準(zhǔn)備工作 1服務(wù)器 最好使用Linux服務(wù)器,小白推薦安裝寶塔面板。...

    jaysun 評論0 收藏0
  • [面試專題]前端需要知道的web安全知識

    摘要:攻擊方式端口掃描攻擊洪水攻擊洪水攻擊跳轉(zhuǎn)攻擊防范手段保證服務(wù)器系統(tǒng)的安全確保服務(wù)器軟件沒有任何漏洞,防止攻擊者入侵。 前端需要知道的web安全知識 標(biāo)簽(空格分隔): 未分類 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中間人攻擊 [Point] Sql/Nosql ...

    ivydom 評論0 收藏0
  • [面試專題]前端需要知道的web安全知識

    摘要:攻擊方式端口掃描攻擊洪水攻擊洪水攻擊跳轉(zhuǎn)攻擊防范手段保證服務(wù)器系統(tǒng)的安全確保服務(wù)器軟件沒有任何漏洞,防止攻擊者入侵。 前端需要知道的web安全知識 標(biāo)簽(空格分隔): 未分類 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中間人攻擊 [Point] Sql/Nosql ...

    王晗 評論0 收藏0

發(fā)表評論

0條評論

Cympros

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<