摘要:默認(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
摘要:簡單來說,就是我們創(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]...
摘要:準(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ù)器,小白推薦安裝寶塔面板。...
摘要:攻擊方式端口掃描攻擊洪水攻擊洪水攻擊跳轉(zhuǎn)攻擊防范手段保證服務(wù)器系統(tǒng)的安全確保服務(wù)器軟件沒有任何漏洞,防止攻擊者入侵。 前端需要知道的web安全知識 標(biāo)簽(空格分隔): 未分類 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中間人攻擊 [Point] Sql/Nosql ...
摘要:攻擊方式端口掃描攻擊洪水攻擊洪水攻擊跳轉(zhuǎn)攻擊防范手段保證服務(wù)器系統(tǒng)的安全確保服務(wù)器軟件沒有任何漏洞,防止攻擊者入侵。 前端需要知道的web安全知識 標(biāo)簽(空格分隔): 未分類 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中間人攻擊 [Point] Sql/Nosql ...
閱讀 2322·2023-04-26 00:01
閱讀 809·2021-10-27 14:13
閱讀 1840·2021-09-02 15:11
閱讀 3392·2019-08-29 12:52
閱讀 542·2019-08-26 12:00
閱讀 2574·2019-08-26 10:57
閱讀 3416·2019-08-26 10:32
閱讀 2859·2019-08-23 18:29