摘要:默認為即是開文件上傳至服務器上存儲臨時文件的地方,如果沒指定就會用系統默認的臨時文件夾望文生意,即允許上傳文件大小的最大值。
1.一般上傳文件都是利用form表單已經提交,并且一般都是通過http協議,小編在這里決得不防試試ftp協議上傳文件
2.form表單上傳,那么form表單里enctype="multipart/form-data"這個元素就不可少了
3.上傳
//判斷是否上傳成功(是否使用post方式上傳) 、
if(is_uploaded_file($_FILES"myfile")) {
//把文件轉存到你希望的目錄(不要使用copy函數) $uploaded_file=$_FILES["myfile"]["tmp_name"]; //我們給每個用戶動態的創建一個文件夾 $user_path=$_SERVER["DOCUMENT_ROOT"]."/studyphp/file/up/".$username; //判斷該用戶文件夾是否已經有這個文件夾 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架構,那么針對nginx,針對php又有哪些設置針對文件上傳有關呢?
php:
file_uploads = on ;是否允許通過HTTP上傳文件的開關。默認為ON即是開
upload_tmp_dir ;文件上傳至服務器上存儲臨時文件的地方,如果沒指定就會用系統默認的臨時文件夾
upload_max_filesize = 8m ;望文生意,即允許上傳文件大小的最大值。默認為2M
post_max_size = 8m ;指通過表單POST給PHP的所能接收的最大值,包括表單里的所有值。默認為8M
進一步配置以下的參數
max_execution_time = 600 ;每個PHP頁面運行的最大時間值(秒),默認30秒
max_input_time = 600 ;每個PHP頁面接收數據所需的最大時間,默認60秒
memory_limit = 8m ;每個PHP頁面所吃掉的最大內存,默認8M
把上述參數修改后,在網絡所允許的正常情況下,就可以上傳大體積文件了
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的處理辦法
下面負上利用ftp上傳文件的例子:
/**
仿寫CodeIgniter的FTP類
FTP基本操作:
1) 登陸; connect
2) 當前目錄文件列表; filelist
3) 目錄改變; chgdir
4) 重命名/移動; rename
5) 創建文件夾; 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;
/**
構造函數
*
@param array 配置數組 : $config = array("hostname"=>"","username"=>"","password"=>"","port"=>""...);
*/
public function __construct($config = array()) {
if(count($config) > 0) {
$this->_init($config);
}
}
/**
FTP連接
*
@access public
@param array 配置數組
@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 目錄標識(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 目錄標識(ftp)
@param int 文件權限列表
@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 本地目錄標識
@param string 遠程目錄標識(ftp)
@param string 上傳模式 auto || ascii
@param int 上傳后的文件權限列表
@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);
//根據后綴類型決定上傳模式是 FTP_ASCII(文本模式) 還是 FTP_BINARY(二進制模式);
$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;
}
//判斷是否需要改寫文件權限
if( ! is_null($permissions)) {
$this->chmod($remotepath,(int)$permissions);
}
return TRUE;
}
/**
下載
*
@access public
@param string 遠程目錄標識(ftp)
@param string 本地目錄標識
@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 遠程目錄標識(ftp)
@param string 新目錄標識
@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 文件標識(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 目錄標識(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) {
//如果我們無法刪除,那么就可能是一個文件夾
//所以我們遞歸調用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;
}
/**
修改文件權限
*
@access public
@param string 目錄標識(ftp)
@return boolean
*/
public function chmod($path, $perm) {
if( ! $this->_isconn()) {
return FALSE;
}
//只有在PHP5中才定義了修改權限的函數(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 目錄標識(ftp)
@return array
*/
public function filelist($path = ".") {
if( ! $this->_isconn()) {
return FALSE;
}
return ftp_nlist($this->conn_id, $path);
}
/**
關閉FTP
*
@access public
@return boolean
*/
public function close() {
if( ! $this->_isconn()) {
return FALSE;
}
return @ftp_close($this->conn_id);
}
/**
FTP成員變量初始化
*
@access private
@param array 配置數組
@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;
}
/**
從文件名中獲取后綴擴展
*
@access private
@param string 目錄標識
@return string
*/
private function _getext($filename) {
if(FALSE === strpos($filename, ".")) {
return "txt";
}
$extarr = explode(".", $filename);
return end($extarr);
}
/**
從后綴擴展定義FTP傳輸模式 ascii 或 binary
*
@access private
@param string 后綴擴展
@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", //服務器地址
"username" => "ftpadminuser", //FTP登錄賬號
"password" => "admin_user", //FTP登錄密碼
"port" => 2112 //端口號
);
$ftp = new Ftp();
//連接
$ftp->connect($config);
//上傳第一個參數是本地文件名,第二個參數是FTP文件名
$rs=$ftp->upload("jsyh.flv","jsyh.flv");
if($rs){
echo 1;
}
// $ftp->download("ftp_upload.log","ftp_download.log");
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/22850.html
摘要:簡單來說,就是我們創建一對密鑰,其中一個是私鑰保存在本地設備中,另一個是公鑰,傳到你的中,之所以叫做密鑰對,是因為使用公鑰加密的消息只能使用對應的私鑰解密。 配置 1).如果你使用的不是Pass,那么先配置VPS或者專用的服務器才能運行PHP應用。本文假設你會使用vim或者nano編輯器。2).我們選擇nginx服務器來作為我們的web服務器。 首次登錄 ssh root@123.45...
摘要:準備工作服務器最好使用服務器,小白推薦安裝寶塔面板。備案域名小程序賬號建議注冊企業賬號,可以使用已認證的公眾號快速創建。七牛賬號使用,加快網站訪問速度。如需使用小程序發帖,也會用到。注意不要使用以下的。 showImg(https://segmentfault.com/img/bVUUeU?w=600&h=280); 準備工作 1服務器 最好使用Linux服務器,小白推薦安裝寶塔面板。...
摘要:攻擊方式端口掃描攻擊洪水攻擊洪水攻擊跳轉攻擊防范手段保證服務器系統的安全確保服務器軟件沒有任何漏洞,防止攻擊者入侵。 前端需要知道的web安全知識 標簽(空格分隔): 未分類 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中間人攻擊 [Point] Sql/Nosql ...
摘要:攻擊方式端口掃描攻擊洪水攻擊洪水攻擊跳轉攻擊防范手段保證服務器系統的安全確保服務器軟件沒有任何漏洞,防止攻擊者入侵。 前端需要知道的web安全知識 標簽(空格分隔): 未分類 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中間人攻擊 [Point] Sql/Nosql ...
閱讀 2328·2023-04-26 00:01
閱讀 810·2021-10-27 14:13
閱讀 1848·2021-09-02 15:11
閱讀 3393·2019-08-29 12:52
閱讀 544·2019-08-26 12:00
閱讀 2575·2019-08-26 10:57
閱讀 3417·2019-08-26 10:32
閱讀 2860·2019-08-23 18:29