?php
平樂(lè)網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),平樂(lè)網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為平樂(lè)上千多家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\成都外貿(mào)網(wǎng)站建設(shè)要多少錢(qián),請(qǐng)找那個(gè)售后服務(wù)好的平樂(lè)做網(wǎng)站的公司定做!
class FileAction extends Action {
public function Index()
{
//print_r(__URL__);
$file = M('file');
$list = $file-select();
$this-assign('filelist',$list);
$this-display();
}
public function upload()
{
//文件上傳的地址上傳給它,并且上傳完成后返回一個(gè)信息,讓其寫(xiě)入數(shù)據(jù)庫(kù)
//如果$_FILES為空的畫(huà),我就讓action給出一個(gè)錯(cuò)誤提示,告訴用戶必須選擇上傳文件。如果有上傳文件,則調(diào)用up方法
//$_FILES = $this-_post('file');
//print_r($_FILES);
if (empty($_FILES)) {
$this-error('必須選擇上傳文件');
}else {
$a = $this-Up();
//print_r($a);
if (isset($a)) {
//寫(xiě)入數(shù)據(jù)庫(kù)方法
if($this-c($a)) {
$this-success('上傳成功');
}else {
$this-error('寫(xiě)入數(shù)據(jù)庫(kù)失敗');
}
}else {
$this-error('上傳文件有異常請(qǐng)與系統(tǒng)管理員聯(lián)系');
}
}
}
private function c($data)
{
//print_r($data);
$file=M('file');
$num = '0';
for($i = 0; $i count($data)-1; $i++) {
$data['filename']=$data[$i]['savename'];
if( $file-data($data)-add())
{
$num++;
}
}
if($num==count($data)-1)
{
return true;
}else {
return false;
}
}
// private function c($data)
// {
// $file = M('file');
// $data['filename'] = $data[0]['savename'];
// if ($file-data($data)-add()) {
// return true;
// }else {
// return false;
// }
// }
//在這個(gè)方法當(dāng)中,完成與thinkphp相關(guān)的,文件上傳類(lèi)的調(diào)用
private function Up()
{
//echo '模擬上傳';
//基本上傳功能
//批量上傳功能
//生成圖片縮略圖
//自定義參數(shù)上傳
//上傳檢測(cè)(大小,后綴,mime類(lèi)型)
//支持覆蓋方式上傳
//上傳類(lèi)型,附件大小,上傳路徑定義
//支持hash或者日期子目錄保存上傳文件
//上傳圖片的安全性檢測(cè)
//對(duì)上傳文件的hash檢測(cè)
//上傳文件名自定義規(guī)范
import('@.ORG.UploadFile');
import('@.ORG.Image');
$upload = new UploadFile();
$upload-maxSize = '1000000'; //指上傳文件大小,默認(rèn)為-1,不限制大?。╞ytes)
$upload-savePath = './Public/'; //上傳保存到什么地方?路徑建議保存到入口文件平級(jí)或平級(jí)目錄的子目錄
$upload-saveRule = 'uniqid'; //上傳文件的文件名保存規(guī)則 time uniqid(默認(rèn)) com_create_guid
$upload-hashType = 'md5_file';
$upload-autoCheck = true; //是否自動(dòng)檢測(cè)附件 默認(rèn)true
$upload-uploadReplace = true; //如果存在同名文件是否進(jìn)行覆蓋
$upload-allowExts = array('jpg','jpeg','png','gif'); //允許上傳的文件后綴
$upload-allowPath = array('image/png','image/jpg','image/pjpeg','image/gif','image/jpeg'); //檢測(cè)mime類(lèi)型
$upload-thumb = true; // 是否開(kāi)啟圖片文件縮略
$upload-thumbMaxWidth = '300,500';//縮略圖最大寬度
$upload-thumbMaxHeight = '200,400';//最大高度
$upload-thumbPrefix = 's-,m-';//縮略圖文件前綴
//$upload-thumbSuffix = '_s,_m';//文件后綴
//$upload-thumbPath = '';//如果留空直接上傳至
//$upload-thumbFile 在數(shù)據(jù)庫(kù)中也存一個(gè)文件名即可
$upload-thumbRemoveOrigin = 1; //如果生成縮略圖,是否刪除原圖
//$upload-autoSub 是否使用子目錄進(jìn)行保存上傳文件
//$upload-subType='' 子目錄創(chuàng)建方式默認(rèn)為hash 也可以為date
//$upload-dateFormat 子目錄方式date的指定日期格式
//$upload-hashLevle
//upload() 如果上傳成功返回true,失敗返回false
if ($upload-upload()) {
$info = $upload-getUploadFileInfo();
return $info;
}else {
//是專門(mén)來(lái)獲取上傳的錯(cuò)誤信息的
$this-error($upload-getErrorMsg());
}
}
}
?
應(yīng)該是if (empty($record_arr))這個(gè)條件不成立造成的,不成立就會(huì)執(zhí)行else里的break,所以就提前結(jié)束了
rancard(10,'0123456789');這個(gè)函數(shù)可能會(huì)生成重復(fù)的密碼
所以$card_pwd有可能有相等的所以能查詢出東西,然后就會(huì)執(zhí)行else里的break
確保不重復(fù)的情況下 給這個(gè)鍵做索引 或者 在匹配步驟上將數(shù)據(jù)庫(kù)的所有數(shù)值分批次取出存入到緩存中 利用高IO去完成匹配。
另外 關(guān)于 7位數(shù)字的生成 可以以1000000為基礎(chǔ)去自增的形式生成。按照你的隨機(jī)數(shù)理念 越到后面count的效率越低。
首先創(chuàng)建html文件??梢砸詉d字段作為文件名,你如果嫌短的話,再加上time()。
如 $filename=$row[id].time."html";
然后以可寫(xiě)的形式打開(kāi)剛剛建立的文件,把讀出的數(shù)據(jù)內(nèi)容存放進(jìn)去。一個(gè)文件就建成了。如果建成批量的,在讀取數(shù)據(jù)表的時(shí)候,把代碼加到while循環(huán)里就好了。