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

php导入文件夹图片保存到dedecms中

发布:smiling 来源: PHP粉丝网  添加日期:2014-09-10 10:08:34 浏览: 评论:0 

数据库连接我就不介绍了,这里就是简单的mysql连接了,我们主要是看核心代码了,原理就是glob函数遍历目录,然后再利用foreach遍历读取一个个的文件名字再由相关函数处理之后返回给我们编译好的sql语句再执行三表操作即可.

临时写的一个东西省时间而写的,因为有几千个产品带大图,所以我们写了这么一个程序了,希望对各位有帮助.

导入方法:http://www.phpfensi.com/a.php?typeid=你的id&path=你的目录

处理php文件,代码如下:

  1. $typeid = $_GET['typeid']; 
  2. if( ! intval$typeid ) ) 
  3.  echo '请传值给typeid'
  4.  exit
  5.  
  6. $path = $_GET['path']; 
  7.  
  8. if$path =="" ) 
  9.  echo '请传值给path ,如  a/b/c/'
  10.  exit
  11.  
  12.  
  13. function getfile($path
  14.  $dirs    = array(); 
  15.  foreach(glob("$path*"as $d
  16.  { 
  17.   $tmp = explode('.',$d); 
  18.   $k = end($tmp); 
  19.   if(is_file($d) && ( $k=='jpg' || $k =='gif' || $k=='png')) 
  20.   { 
  21.    $dirs[]    = $d
  22.   } 
  23.  } 
  24.  return $dirs
  25. $array = getfile($path); 
  26. foreach$array as $v => $vv ) 
  27.  //www.phpfensi.com取名字 
  28.  $t_name = explode'/',$vv ); ; 
  29.  $tV = end($t_name); 
  30.  list($name,$ext) = explode('.',$tV); 
  31.  
  32.  $sql ="INSERT INTO `dedecms_archives` (`typeid`, `typeid2`, `sortrank`, `flag`, `ismake`, `channel`, `arcrank`, `click`, `money`, `title`, `shorttitle`, `color`, `writer`, `source`, `litpic`, `pubdate`, `senddate`, `mid`, `keywords`, `lastpost`, `scores`, `goodpost`, `badpost`, `voteid`, `notpost`, `description`, `filename`, `dutyadmin`, `tackid`, `mtype`, `weight`) VALUES 
  33. ($typeid'0', 1394943742, 'c,p', 1, 17, 0, 156, 0, '$name''S".$typeid.mt_rand(0,99999)."''''admin''未知''/$vv', 1394943742, 1394943720, 1, '$name', 0, 0, 0, 0, 0, 0, '''', 1, 0, 0, 11)"; 
  34.  mysql_query( $sql ) or die( mysql_error().$sql ); 
  35.  $aid= mysql_insert_id(); 
  36.  
  37.  $sql2 ="INSERT INTO `dedecms_addonarticle17` (`aid`, `typeid`, `body`, `redirecturl`, `templet`, `userip`, `s_type`) VALUES 
  38. ($aid$typeid'<img  src=/".str_replace('231','600',$vv)." />''''''192.168.1.108''S12000".$name."')"; 
  39.  
  40.  mysql_query( $sql2 ) or die( mysql_error().$sql2 ); 
  41.  
  42.  $sql3 ="INSERT INTO `dedecms_arctiny` (`id`, `typeid`, `typeid2`, `arcrank`, `channel`, `senddate`, `sortrank`, `mid`) VALUES 
  43. ($aid$typeid'0', 0, 17, 1394943720, 1394943742, 1)"; 
  44.  
  45.  mysql_query( $sql3 ) or die( mysql_error().$sql3 ); 
  46.  
  47.  
  48.  
  49. echo '导入成功'
  50.  
  51. print_r($array); 

之后碰到一个小问题,就是导入数据在栏目可以看到,但在所有数据中看不到记录,生成时只有选择栏目生成才可以但用一键生成有问题,这个时我在发布时间是固定一个以前的时间了,大家可以使用time函数来获取当前时间了.

Tags: php导入文件夹 保存dedecms

分享到: