PHP開發(fā)企業(yè)網(wǎng)站教程之修改產(chǎn)品
也是根據(jù)表單提交所帶的參數(shù) id 在數(shù)據(jù)庫進(jìn)行查詢
代碼如下所示:
<?php require_once('conn.php'); $id = $_GET['id']; $sql = "SELECT * from product where id= '$id'"; $res = mysql_query($sql); $info = mysql_fetch_array($res); ?> <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>修改產(chǎn)品</title> <style type="text/css"> #cnt{ width:400px; height:400px; margin-top:15px; margin-left: 15px; } iframe{border:0px;} </style> </head> <body> <div id="cnt"> <form method="post" action="modifyproduct.php?id=<?php echo $info['id']?>" enctype="multipart/form-data"> 產(chǎn)品名稱:<input type="text" name="title" id="title" value="<?php echo $info['title']?>"></br></br> <iframe src="file.php"></iframe> <input type="text" id="imgname" name="imgname" value="<?php echo $info['imgname'];?>"></br></br> 產(chǎn)品價(jià)格:<input type="text" name="price" value="<?php echo $info['price']?>"> </br></br> <input type="submit" value="修改產(chǎn)品"> </form> </div> </body> </html>
大家看到我們表單中有一個(gè)file.php 的文件
修改的時(shí)候,我們也許會(huì)重新上傳圖片,所以我用了一個(gè)iframe的標(biāo)簽,
我們來看下file.php的代碼:
<?php if(!empty($_POST['go']) && $_POST['go']==1){ //接受文件,臨時(shí)文件信息 $fileinfo=$_FILES["myFile"];//降維操作 $filename=$fileinfo["name"]; $tmp_name=$fileinfo["tmp_name"]; $size=$fileinfo["size"]; $error=$fileinfo["error"]; $type=$fileinfo["type"]; //服務(wù)器端設(shè)定限制 $maxsize=10485760;//10M,10*1024*1024 $allowExt=array('jpeg','jpg','png','gif');//允許上傳的文件類型(拓展名 $ext=pathinfo($filename,PATHINFO_EXTENSION);//提取上傳文件的拓展名 //目標(biāo)存放文件夾 $path="../uploads"; if (!file_exists($path)) { //當(dāng)目錄不存在,就創(chuàng)建目錄 mkdir($path,0777,true);//創(chuàng)建目錄 chmod($path, 0777);//改變文件模式,所有人都有執(zhí)行權(quán)限、寫權(quán)限、度權(quán)限 } //得到唯一的文件名!防止因?yàn)槲募嗤a(chǎn)生覆蓋 $uniName=md5(uniqid(microtime(true),true)).".$ext"; //md5加密,uniqid產(chǎn)生唯一id,microtime做前綴 //目標(biāo)存放文件地址 $destination=$path."/".$uniName; //當(dāng)文件上傳成功,存入臨時(shí)文件夾,服務(wù)器端開始判斷 if ($error==0) { if ($size>$maxsize) { exit("上傳文件過大!"); } if (!in_array($ext, $allowExt)) { exit("非法文件類型"); } if (!is_uploaded_file($tmp_name)) { exit("上傳方式有誤,請(qǐng)使用post方式"); } //判斷是否為真實(shí)圖片(防止偽裝成圖片的病毒一類的 if (!getimagesize($tmp_name)) {//getimagesize真實(shí)返回?cái)?shù)組,否則返回false exit("不是真正的圖片類型"); } //move_uploaded_file($tmp_name, "uploads/".$filename); if (@move_uploaded_file($tmp_name, $destination)) {//@錯(cuò)誤抑制符,不讓用戶看到警告 echo "<script>parent.document.all.imgname.value = '$destination';</script>文件".$filename."上傳成功!"; }else{ echo "文件".$filename."上傳失敗!"; } }else{ switch ($error){ case 1:echo "超過了上傳文件的最大值,請(qǐng)上傳2M以下文件";break; case 2:echo "上傳文件過多,請(qǐng)一次上傳20個(gè)及以下文件!";break; case 3:echo "文件并未完全上傳,請(qǐng)?jiān)俅螄L試!";break; case 4:echo "未選擇上傳文件!";break; case 7:echo "沒有臨時(shí)文件夾";break; } } } ?> <!DOCTYPE html> <html> <head> <title></title> </head> <body> <form method="post" action="?" enctype="multipart/form-data"> 上傳文件:<input type="file" name="myFile"></br></br> <input type="hidden" value="1" name="go"> <input type="submit" value="上傳"></br></br> </form> </body> </html>
在本頁面進(jìn)行對(duì)上傳的文件進(jìn)行處理
我們接著往下看modifyproduct.php文件的代碼
<?php require_once('conn.php'); $id = $_GET['id']; $title = $_POST['title']; $imagename = $_POST['imgname']; $price = $_POST['price']; $goodtime = time(); $sql = "UPDATE product SET title='$title',imgname='$imagename',price='$price',goodtime='$goodtime' where id='$id'"; $res = mysql_query($sql); if($res){ echo "<script>alert('修改產(chǎn)品成功');location.href='product.php'</script>"; }else{ echo "<script>alert('修改產(chǎn)品失敗');history.go(-1);</script>"; } ?>
綜合上述代碼我們就完成了產(chǎn)品修改的功能