当前位置:首页 > CMS教程 > Thinkphp > 列表

ThinkPHP框架实现FTP图片上传功能示例

发布:smiling 来源: PHP粉丝网  添加日期:2021-11-15 11:24:40 浏览: 评论:0 

这篇文章主要介绍了ThinkPHP框架实现FTP图片上传功能,结合实例形式分析了thinkPHP框架实现ftp图片上传功能相关的配置、文件传输功能等操作技巧,需要的朋友可以参考下。

本文实例讲述了ThinkPHP框架实现FTP图片上传功能。分享给大家供大家参考,具体如下:

背景:

图片上传功能应该是个极为普遍的,在此参考了ThinkPHP 框架中的集成方法整理了一下FTP图片的上传功能,这样方便在后台操作时,把有关的图片直接上传到线上的图片服务器,避免大流量访问的图片加载缓慢,降低网站的访问压力,不合理之处,敬请指摘...

操作:

1.前端设计

这里主要为了测试功能的实现,使用最简单的设计,既方便参考又有利于后期的功能扩展。如下附upload.html主要代码,着重注意红框圈出的代码,其中css样式比较简单,需要的可以参考后面的源代码。

ThinkPHP图片上传 FTP图片上传

2.后台控制器设计

config.class.php 主要代码如下所示,其中设计的表“conf”在此只需用两个字段就好——'tag','value',可以使用简单的varchar类型。

  1. public function upload(){ 
  2.   if (IS_POST){ 
  3.     foreach ($_FILES as $key => $value){ 
  4.       $img = handleImg($key); 
  5.       $furl = C('REMOTE_ROOT').$img
  6.       if ($img){ 
  7.         ftp_upload($furl,$img); 
  8.         $saveData['value'] = $img
  9.         M('conf'
  10.           ->where("tag = '".$key."'"
  11.           ->save($saveData); 
  12.       } 
  13.     } 
  14.     $this->success('FTP 测试完成',U('Config/upload'),2); 
  15.   }else
  16.     $imgUrl = M('conf'
  17.       ->where("tag = 'upImg'"
  18.       ->getField('value'); 
  19.     $this->assign('imgUrl',$imgUrl); 
  20.     $this->display(); 
  21.   } 

3.配置数据

在公共配置文件中,进行如下常量的数据配置,参考代码如下,注意配置FTP 账号及密码的正确性,此处安全起见只是举例。

  1. //ftp(外网服务器)上传文件相关参数 
  2. 'FTP_SEVER'    => 'http://img.52zhenmi.com', //此地址,作为图片读取的位置 请上线前仔细确认 
  3. 'FTP_HOST'    => 'img.52zhenmi.com'
  4. 'WEB_SEVER'   => 'http://img.52zhenmi.com'
  5. 'WEB_M_SERVER'  => 'http://www.52zhenmi.com/m'
  6. 'FTP_NAME'    => 'fexxxi',//ftp帐户 
  7. 'FTP_PWD'    => '1qxxxxxxw',//ftp密码 
  8. 'FTP_PORT'    => '21',//ftp端口,默认为21 
  9. 'FTP_PASV'    => true,//是否开启被动模式,true开启,默认不开启 
  10. 'FTP_SSL'    => false,//ssl连接,默认不开启 
  11. 'FTP_TIMEOUT'  => 60,//超时时间,默认60,单位 s 
  12. 'REMOTE_ROOT'  => '/',//图片服务器根目录 

4.引入文件

以我的代码为例,在此引用了两个文件,其中的FTP.class.php 放在了'/Library/Think' 目录下;Upload.class.php 放在了'/Library/Org/Net'目录下,可根据自己的使用习惯自行调整目录,只要保证实例化路径时没问题就可。

5.公共函数添加

注意添加上文步骤2中使用到的公共函数。

  1. /** 
  2.  * 图片上传的公共处理方法 
  3.  * @param string $fileName 图片上传的name 
  4.  * @return string 图片的存储路径 
  5.  */ 
  6. function handleImg($fileName){ 
  7.   if($_FILES[$fileName]['tmp_name'] != ""){ 
  8.     $img = $_FILES[$fileName]; 
  9.     $imgUrl = __ROOT__."/public"
  10.     $upload = new \Org\Net\Upload($img$imgUrl); 
  11.     return $upload->main(); 
  12.   } 
  13. //FTP上传文件函数 
  14. function ftp_upload($remotefile,$localfile){ 
  15.   $ftp = new \Think\Ftp(); 
  16.   $data['server'] = C('FTP_HOST'); 
  17.   $data['username'] = C('FTP_NAME');//ftp帐户 
  18.   $data['password'] = C('FTP_PWD');//ftp密码 
  19.   $data['port'] = C('FTP_PORT');//ftp端口,默认为21 
  20.   $data['pasv'] = C('FTP_PASV');//是否开启被动模式,true开启,默认不开启 
  21.   $data['ssl'] = C('FTP_SSL');//ssl连接,默认不开启 
  22.   $data['timeout'] = C('FTP_TIMEOUT');//超时时间,默认60,单位 s 
  23.   $info = $ftp->start($data); 
  24.   if($info){ 
  25.     if($ftp->put($remotefile,$localfile)){} 
  26.   } 
  27.   $ftp->close(); 

6.操作截图

ThinkPHP图片上传 FTP图片上传

7.提示

对于这份参考代码,涉及到的公共方法handleImg()会先将需要上传的图片传到当前操作的网站根目录,之后又会通过ftp_upload()将图片传到对应的图片FTP服务器,从实现步骤上看第一步多余,主要是开发过程中的测试服务器不符合FTP账号要求,同时又要方便线上内容修改的及时更新,暂没优化,也不麻烦,算留大家一个自由发挥的机会吧。

Tags: ThinkPHP图片上传 FTP图片上传

分享到: