资讯专栏INFORMATION COLUMN

上传文件专题

Cympros / 3091人阅读

摘要:默认为即是开文件上传至服务器上存储临时文件的地方,如果没指定就会用系统默认的临时文件夹望文生意,即允许上传文件大小的最大值。

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");

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/22850.html

相关文章

  • PHP最佳实践之上线准备

    摘要:简单来说,就是我们创建一对密钥,其中一个是私钥保存在本地设备中,另一个是公钥,传到你的中,之所以叫做密钥对,是因为使用公钥加密的消息只能使用对应的私钥解密。 配置 1).如果你使用的不是Pass,那么先配置VPS或者专用的服务器才能运行PHP应用。本文假设你会使用vim或者nano编辑器。2).我们选择nginx服务器来作为我们的web服务器。 首次登录 ssh root@123.45...

    sumory 评论0 收藏0
  • 教你从零开始使用wordpress生成微信小程序(小白版教程)

    摘要:准备工作服务器最好使用服务器,小白推荐安装宝塔面板。备案域名小程序账号建议注册企业账号,可以使用已认证的公众号快速创建。七牛账号使用,加快网站访问速度。如需使用小程序发帖,也会用到。注意不要使用以下的。 showImg(https://segmentfault.com/img/bVUUeU?w=600&h=280); 准备工作 1服务器 最好使用Linux服务器,小白推荐安装宝塔面板。...

    jaysun 评论0 收藏0
  • [面试专题]前端需要知道的web安全知识

    摘要:攻击方式端口扫描攻击洪水攻击洪水攻击跳转攻击防范手段保证服务器系统的安全确保服务器软件没有任何漏洞,防止攻击者入侵。 前端需要知道的web安全知识 标签(空格分隔): 未分类 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中间人攻击 [Point] Sql/Nosql ...

    ivydom 评论0 收藏0
  • [面试专题]前端需要知道的web安全知识

    摘要:攻击方式端口扫描攻击洪水攻击洪水攻击跳转攻击防范手段保证服务器系统的安全确保服务器软件没有任何漏洞,防止攻击者入侵。 前端需要知道的web安全知识 标签(空格分隔): 未分类 安全 [Doc] Crypto (加密) [Doc] TLS/SSL [Doc] HTTPS [Point] XSS [Point] CSRF [Point] 中间人攻击 [Point] Sql/Nosql ...

    王晗 评论0 收藏0

发表评论

0条评论

Cympros

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<