fileModel.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418
  1. <?php
  2. class fileClassModel extends Model
  3. {
  4. public function initModel()
  5. {
  6. $this->fileall = ',aac,ace,ai,ain,amr,app,arj,asf,asp,aspx,av,avi,bin,bmp,cab,cad,cat,cdr,chm,com,css,cur,dat,db,dll,dmv,doc,docx,dot,dps,dpt,dwg,dxf,emf,eps,et,ett,exe,fla,ftp,gif,hlp,htm,html,icl,ico,img,inf,ini,iso,jpeg,jpg,js,m3u,max,mdb,mde,mht,mid,midi,mov,mp3,mp4,mpeg,mpg,msi,nrg,ocx,ogg,ogm,pdf,php,png,pot,ppt,pptx,psd,pub,qt,ra,ram,rar,rm,rmvb,rtf,swf,tar,tif,tiff,txt,url,vbs,vsd,vss,vst,wav,wave,wm,wma,wmd,wmf,wmv,wps,wpt,wz,xls,xlsx,xlt,xml,zip,';
  7. $this->mimitype = c('file')->getAllMime();
  8. }
  9. /***
  10. * 添加预览和下载记录
  11. */
  12. public function addlogs($fileid, $type)
  13. {
  14. $uarr = array();
  15. $uarr['fileid'] = $fileid;
  16. $uarr['type'] = $type;
  17. $uarr['optname'] = $this->adminname;
  18. $uarr['optid'] = $this->adminid;
  19. $uarr['ip'] = $this->rock->ip;
  20. $uarr['web'] = $this->rock->web;
  21. $uarr['optdt'] = $this->rock->now;
  22. return m('files')->insert($uarr);
  23. }
  24. public function getmime($lx)
  25. {
  26. if(!isset($this->mimitype[$lx]))$lx = 'unkown';
  27. return $this->mimitype[$lx];
  28. }
  29. public function getfile($mtype, $mid, $where='')
  30. {
  31. if($where=='')$where = "`mtype`='$mtype' and `mid` in($mid)";
  32. $rows = $this->getall("$where order by `id`");
  33. return $rows;
  34. }
  35. public function addfile($fileid, $mtype, $mid, $mknum='')
  36. {
  37. if(!$this->isempt($fileid)){
  38. $this->update("`mtype`='$mtype',`mid`='$mid',`mknum`='$mknum'", "`id` in($fileid) and `mid`=0");
  39. }
  40. }
  41. public function getstr($mtype, $mid, $lx=0, $where='')
  42. {
  43. $filearr = $this->getfile($mtype, $mid, $where);
  44. $fstr = $this->getstrstr($filearr, $lx);
  45. return $fstr;
  46. }
  47. public function getstrstr($filearr, $lx)
  48. {
  49. $fstr = '';
  50. if($filearr)foreach($filearr as $k=>$rs){
  51. if($k>0)$fstr.='<br>';
  52. $fstr .= $this->getfilestr($rs, $lx);
  53. }
  54. return $fstr;
  55. }
  56. //获取聚合文件
  57. public function getallstr($filearr, $mid, $lx=0)
  58. {
  59. $farr = array();
  60. if($filearr)foreach($filearr as $k=>$rs){
  61. if($rs['mid']==$mid)$farr[] = $rs;
  62. }
  63. return $this->getstrstr($farr, $lx);
  64. }
  65. public function isimg($ext)
  66. {
  67. return $this->contain('|jpg|png|gif|bmp|jpeg|', '|'.$ext.'|');
  68. }
  69. public function isoffice($ext)
  70. {
  71. return contain('|doc|docx|xls|xlsx|ppt|pptx|pdf|', '|'.$ext.'|');
  72. }
  73. public function isbianju($ext)
  74. {
  75. return contain('|doc|docx|xls|xlsx|ppt|pptx|', '|'.$ext.'|');
  76. }
  77. public function isyulan($ext)
  78. {
  79. return contain(',txt,log,html,htm,js,php,php3,mp4,md,cs,sql,java,json,css,asp,aspx,shtml,cpp,c,vbs,jsp,xml,bat,ini,conf,sh,', ','.$ext.',');
  80. }
  81. //判断是否可预览
  82. public function isview($ext)
  83. {
  84. if($this->isimg($ext))return true;
  85. if($this->isoffice($ext))return true;
  86. if($this->isyulan($ext))return true;
  87. return contain(',mp3,ogg,mp4,', ','.$ext.',');
  88. }
  89. //获取缩略图的路径
  90. public function getthumbpath($rs)
  91. {
  92. $thumbpath = $this->rock->repempt(arrvalue($rs, 'thumbpath'));
  93. if(!isempt($thumbpath)){
  94. if(substr($thumbpath,0,4)=='http')return $thumbpath;
  95. if(!file_exists($thumbpath))$thumbpath='';
  96. }
  97. if(isempt($thumbpath))$thumbpath = arrvalue($rs, 'thumbplat');
  98. if(!isempt($thumbpath)){
  99. $thumbpath = str_replace('{FILEURL}', getconfig('rockfile_url'), $thumbpath);
  100. $thumbpath = $this->rock->gethttppath($thumbpath);
  101. }
  102. return $thumbpath;
  103. }
  104. //$lx=2详情,$lx=3是flow.php getdatalog下读取的
  105. public function getfilestr($rs, $lx=0)
  106. {
  107. $fstr= '';
  108. if(!$rs)return $fstr;
  109. $str = $this->rock->jm->strrocktoken(array('a'=>'down','id'=>$rs['id']));
  110. $url = ''.URL.'index.php?rocktoken='.$str.'';
  111. $str = 'href="'.$url.'"';
  112. $ext = $rs['fileext'];
  113. $id = $rs['id'];
  114. $isimg= $this->isimg($ext);
  115. $strd= $str;
  116. if($lx==1)$str='href="javascript:;" onclick="return js.downshow('.$rs['id'].')"';
  117. if($lx>=2){
  118. $paths = $rs['filepath'];
  119. if(arrvalue($rs,'filepathout'))$paths = $rs['filepathout'];
  120. if(!$isimg)$paths='';
  121. $str='href="javascript:;" onclick="return c.downshow('.$rs['id'].',\''.$ext.'\',\''.$paths.'\',\''.$rs['filenum'].'\')"';//详情上预览
  122. }
  123. $flx = $rs['fileext'];
  124. if(!$this->contain($this->fileall,','.$flx.','))$flx='wz';
  125. $str1 = '';
  126. $imurl = ''.URL.'web/images/fileicons/'.$flx.'.gif';
  127. $thumbpath = $this->getthumbpath($rs);
  128. if($isimg && !isempt($thumbpath))$imurl = $thumbpath;
  129. $isdel = file_exists($rs['filepath']);
  130. if(substr($rs['filepath'],0,4)=='http')$isdel=true;
  131. if(!isempt($rs['filenum']))$isdel=true;
  132. if(arrvalue($rs,'filepathout'))$isdel=true;
  133. $fstr .='<img src="'.$imurl.'" align="absmiddle" height=20 width=20>';
  134. if($isdel){
  135. $fstr .=' '.$rs['filename'].'';
  136. }else{
  137. $fstr .=' <s>'.$rs['filename'].'</s>';
  138. }
  139. $fstr .=' <span style="color:#aaaaaa;font-size:12px">('.$rs['filesizecn'].')</span>';
  140. $filenum = arrvalue($rs,'filenum');
  141. //if(!isempt($filenum)){
  142. $strd = 'href="javascript:;" onclick="js.fileopt('.$id.', 1)"';//下载的链接
  143. //}
  144. if($lx>=2){
  145. if($isdel){
  146. $fstr .= ' <a temp="clo" '.$strd.' class="blue">下载</a>';
  147. if($isimg || $this->isoffice($ext) || $this->isyulan($ext))
  148. $fstr .= '&nbsp; <a temp="clo" '.$str.' class="blue">预览</a>';
  149. if($this->isbianju($ext) && $lx==3)$fstr .='`'.$rs['id'].'`'; //用于编辑
  150. }else{
  151. $fstr .= ' <span style="color:#aaaaaa;font-size:12px">已删除</span>';
  152. }
  153. }
  154. return $fstr;
  155. }
  156. public function getfiles($mtype, $mid)
  157. {
  158. $rows = $this->getall("`mtype`='$mtype' and `mid`='$mid' order by `id`");
  159. foreach($rows as $k=>$rs){
  160. $rows[$k]['status'] = 4;
  161. }
  162. return $rows;
  163. }
  164. public function getfilepath($mtype, $mid)
  165. {
  166. $rows = $this->getfiles($mtype, $mid);
  167. $str = '';
  168. $nas = '';
  169. $st1 = '';
  170. foreach($rows as $k=>$rs){
  171. $path = $rs['filepath'];
  172. $outu = arrvalue($rs, 'filepathout');
  173. if(isempt($outu)){
  174. if(!isempt($path) && (file_exists($path) || substr($path,0,4)=='http') ){
  175. $str .= ','.$path.'';
  176. $nas .= ','.$rs['filename'].'';
  177. }
  178. }else{
  179. if($st1!='')$st1.='<br>';
  180. $st1.=''.$rs['filename'].'('.$rs['filesizecn'].')&nbsp;<a target="_blank" href="'.$outu.'">下载</a>';
  181. }
  182. }
  183. if($str!=''){
  184. $str = substr($str, 1);
  185. $nas = substr($nas, 1);
  186. }
  187. return array($str, $nas, $st1);
  188. }
  189. public function copyfile($mtype, $mid)
  190. {
  191. $rows = $this->getall("`mtype`='$mtype' and `mid`='$mid' order by `id`");
  192. $arr = array();
  193. foreach($rows as $k=>$rs){
  194. $inuar = $rs;
  195. if(isempt($rs['filepath']) || (substr($rs['filepath'],0,4)!='http' && !arrvalue($rs,'filepathout') && !file_exists($rs['filepath'])))continue;
  196. unset($inuar['id']);
  197. $oid = $rs['id'];
  198. $inuar['adddt'] = $this->rock->now;
  199. $inuar['optid'] = $this->adminid;
  200. $inuar['optname'] = $this->adminname;
  201. $inuar['downci'] = '0';
  202. $inuar['mtype'] = '';
  203. $inuar['mid'] = '0';
  204. $inuar['oid'] = $oid;
  205. $ids = (int)$this->getmou('id','oid='.$oid.' and `mid`=0');
  206. if($ids==0){
  207. $this->insert($inuar);
  208. $inuar['id'] = $this->db->insert_id();
  209. }else{
  210. $inuar['id'] = $ids;
  211. }
  212. $inuar['status'] = 4;
  213. $arr[] = $inuar;
  214. }
  215. return $arr;
  216. }
  217. public function delfiles($mtype, $mid)
  218. {
  219. $where = "`mtype`='$mtype' and `mid`='$mid'";
  220. $this->delfile('', $where);
  221. }
  222. public function delfile($sid='', $where='')
  223. {
  224. if($sid!='')$where = "`id` in ($sid)";
  225. if($where=='')return;
  226. $rows = $this->getall($where);
  227. foreach($rows as $k=>$rs){
  228. $path = $rs['filepath'];
  229. if(!$this->isempt($path) && substr($path,0,4)!='http' && file_exists($path))unlink($path);
  230. $path = $rs['thumbpath'];
  231. if(!$this->isempt($path) && substr($path,0,4)!='http' && file_exists($path))unlink($path);
  232. $path = $rs['pdfpath'];
  233. if(!$this->isempt($path) && substr($path,0,4)!='http' && file_exists($path))unlink($path);
  234. if(!isempt($rs['filenum']))c('rockqueue')->push('flow,uptodelete', array('filenum'=>$rs['filenum']));//发送同步删除
  235. }
  236. $this->delete($where);
  237. }
  238. public function fileheader($filename,$ext='xls', $size=0)
  239. {
  240. $mime = $this->getmime($ext);
  241. $filename = $this->iconvutf8(str_replace(' ','',$filename));
  242. header('Content-type:'.$mime.'');
  243. header('Accept-Ranges: bytes');
  244. header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
  245. header('Pragma: no-cache');
  246. if($size>0)header('Content-Length:'.$size.'');
  247. header('Expires: 0');
  248. header('Content-disposition:attachment;filename='.$filename.'');
  249. header('Content-Transfer-Encoding: binary');
  250. }
  251. //渣渣IE才需要转化,真是醉了
  252. public function iconvutf8($text) {
  253. if(contain($this->rock->web,'IE')){
  254. return iconv('utf-8','gb2312', $text);
  255. }else{
  256. return $text;
  257. }
  258. }
  259. public function show($id,$qx=false)
  260. {
  261. if($id==0)exit('Sorry!');
  262. $rs = $this->getone($id);
  263. if(!$rs)exit('504 Not find files');
  264. if(!$qx && !$this->isdownfile($rs))exit('404 No permission download');
  265. $this->update("`downci`=`downci`+1", $id);
  266. $this->addlogs($id, 1);
  267. $filepath = $rs['filepath'];
  268. $filename = $rs['filename'];
  269. $filesize = $rs['filesize'];
  270. $fileext = $rs['fileext'];
  271. $filepathout= $rs['filepathout'];
  272. if($this->rock->contain($filepath,'http')){
  273. header('location:'.$filepath.'');
  274. }else{
  275. //2018-07-18只能下载upload/images下的文件
  276. $ielx = substr($filepath,0,strlen(UPDIR));
  277. $ielx1 = substr($filepath,0,6);
  278. if($ielx!=UPDIR && $ielx1!='upload' && $ielx1!='images')exit('无效操作1');
  279. if(!file_exists($filepath)){
  280. if(!isempt($filepathout))header('location:'.$filepathout.'');
  281. exit('404 Not find files');
  282. }
  283. if(!contain($filename,'.'.$fileext.''))$filename .= '.'.$fileext.'';
  284. $filesize = filesize($filepath);
  285. $this->fileheader($filename, $fileext, $filesize);
  286. if(substr($filepath,-4)=='temp'){
  287. $content = file_get_contents($filepath);
  288. echo base64_decode($content);
  289. }else{
  290. if($this->rock->iswebbro(0) && $this->rock->iswebbro(5)){
  291. header('location:'.$filepath.'');
  292. return;
  293. }
  294. if($filesize > 10*1024*1024 && 1==1){
  295. header('location:'.$filepath.'');
  296. }else{
  297. //echo file_get_contents($filepath);
  298. ob_clean();flush();readfile($filepath);
  299. }
  300. }
  301. }
  302. }
  303. //这个是下载temp文件的
  304. public function download($id)
  305. {
  306. if($id==0)exit('Sorry!');
  307. $rs = $this->getone($id);
  308. if(!$rs)exit('504 Not find files');
  309. if(!$this->isdownfile($rs))exit('No permission download');
  310. $filepath = $rs['filepath'];
  311. $ielx = substr($filepath,0,strlen(UPDIR));
  312. $ielx1 = substr($filepath,0,6);
  313. if($ielx!=UPDIR && $ielx1!='upload' && $ielx1!='images')exit('无效操作2');
  314. if(!file_exists($filepath))exit('404 Not find files');
  315. $this->update("`downci`=`downci`+1", $id);
  316. $this->addlogs($id, 1);
  317. $filename = $rs['filename'];
  318. $filesize = $rs['filesize'];
  319. if(substr($filepath,-4)=='temp'){
  320. Header("Content-type: application/octet-stream");
  321. header('Accept-Ranges: bytes');
  322. Header("Accept-Length: ".$filesize);
  323. Header("Content-Length: ".$filesize);
  324. header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
  325. header('Pragma: no-cache');
  326. header('Expires: 0');
  327. $content = file_get_contents($filepath);
  328. echo base64_decode($content);
  329. }else{
  330. }
  331. }
  332. //判断是否有下载文件的权限
  333. private function isdownfile($rs)
  334. {
  335. //return true; //如果不想权限判断就去掉注释直接返回true
  336. $uid = $this->adminid;
  337. if(arrvalue($rs,'optid')==$uid)return true;
  338. $table = arrvalue($rs,'mtype');
  339. $mid = (int)arrvalue($rs,'mid','0');
  340. if(!isempt($table) && $mid>0){
  341. $to = m('reads')->rows("`table`='$table' and `mid`='$mid' and `optid`='$uid'");
  342. if($to>0)return true;
  343. }
  344. $mknum = arrvalue($rs,'mknum');
  345. if(!isempt($mknum)){
  346. $mknuma = explode('|', $mknum);
  347. $num = $mknuma[0];
  348. $mid = (int)arrvalue($mknuma, 1, $mid);
  349. if($mid>0){
  350. $flow = m('flow')->initflow($num, $mid, false);
  351. if($flow->isreadqx(1))return true;
  352. }
  353. }
  354. if($table=='im_mess'){
  355. $ors = m($table)->getone($mid);
  356. if($ors){
  357. $receuid = $ors['receuid'];
  358. if(contain(','.$receuid.',',','.$uid.','))return true;
  359. }
  360. }
  361. if($table=='word'){
  362. $ors = m('word')->getone("`fileid`='".$rs['id']."'");
  363. if($ors){
  364. $cid = $ors['cid'];
  365. $flow = m('flow')->initflow('worc', $cid, false);
  366. if($flow->isreadqx(1))return true;
  367. $flow = m('flow')->initflow('word', $ors['id'], false);
  368. if($flow->isreadqx(1))return true;
  369. }
  370. }
  371. return false;
  372. }
  373. }
粤ICP备19079148号