一般来说,PHP做商品添加,表单的其他数据和图片的上传都是一起来提交的,而如果你要检查图片是否上传成功来决定是否提交其他表单数据的话,可以这样设计:
一、你现在的这个表单不用改,只需要在最下面的那个“确定”按钮上加个JS判断,判断一下上面的图片是否上传成功(如果图片上传这里成功上传了图片,你返回一个图片的保存路径及图片名称到一个隐藏的文本框里面,然后在“确定”按钮的JS代码里去取这个隐藏的文本框的值,如果有值就可以判定这个图片是上传成功的了,否则失败则整个表单的数据都不能提交)
二、图片上传框这里,确实因为表单不能嵌套,所以这个位置你就要采用一个iframe来加载另一个上传图片的页面(这个上传图片的页面代码很简单,就是那个图片上传框(当然你得加一些权限判断不然就会是一个上传漏洞了),然后写相应的上传代码把图片上传上去最后返回上传后的图片路径及文件名等信息,使用
parent.表单名.隐藏文本框名.value='xxxx.jpg'
这个JS语句来实现把你上传的图片信息保存到你的隐藏文本框里。
上面这句parent...语句的详解如下:
a.由于你的图片上传页面是放在iframe里的,因此你要把iframe里的页面的内容保存到上一层页面(即你这个添加商品的页面,也就是这个加了iframe代码的页面)
举例个吧:
你添加商品的页面文件名是a.php,在a.php的表单里你加了一个<iframe src="b.php"></iframe>
这里面的b.php就是你的上传图片的页面(在b.php中就是你正常的上传图片的表单),另外你接收上传及处理上传的程序都是在这个iframe里面完成的。。
这样应该明白了吧。既然你的上传后的返回值是在iframe里的页面中的,那要想把它保存到a.php这个页面的一个隐藏文本框里,就要使用parent了。。。
所以上面那个js语句是:parent.表单名....
b.这个js语句parent.表单名.隐藏文本框名.value='xxx'中的“表单名”、“隐藏文本框名”,是指的a.php这个页面的表单名哦。
比如你a.php的表单是<form name="addpro_form" method="post">,那么这个JS语句中的表单名也就是addpro_form。隐藏文本框同理。
这样,你明白了吧?
我写个简单的实例你看看:
a.php的代码:
<form name="addpro_form" method="post" action="a.php?act=save">
商品名称:<input type="text" name="pro_name" /><br />
商品价格:<input type="text" name="pro_price" /><br />
商品图片:<input type="hidden" name="pro_img" />
<iframe width="500" height="50" src="b.php"></iframe><br />
商品说明:<textarea name="pro_intro"></textarea><br />
<input type="submit" value="确定" />
</form>
以上是a.php的代表,也就是整个表单,其中表单名是addpro_form,隐藏文本框名是pro_img。
接着写b.php的:
<form name="upfile_form" method="post" action="upload.php" enctype="multipart/form-data">
<input type="file" name="upimages"><input type="submit" value="上传">
</form>
b.php的页面很简单就是一个上传表单而已
然后upload.php是用来接收上传的图片并返回值的:
<?php
//以下是PHP上传图片的代码(我就不写了)
......
//假设上传后得到图片名称
$imgname="111.jpg"
?>
<script type="text/javascript">
window.onload=parent.addpro_form.pro_img.value='<?php echo $imgname?>'
</script>
好了,upload.php的代码也写完了,上面一段php代码是上传图片最后得到上传后的图片名称,接着用一段js代码把图片名称返回到上一页去。
$mysqlhost='localhost'$mysqluser='root'
$mysqlpassword='root'
$conn=mysql_connect($mysqlhost,$mysqluser,$mysqlpassword)
mysql_select_db('数据库名称',$conn)
$sql = "select * from tb_type"
$result = mysql_query($sql) or die ('数据库查询失败1')
$sum = mysql_now_rows($result)//记录总商品数
if(sum>0)
{
$pagesize=10//每页显示10个商品
$total=ceil($sum/$pagesize) //算出总页数(向上取整)
$page=(isset($_GET['page']))?(int)$_GET['page']:1//如果在URL中用page则赋值,否则$page为1
if($page<1 or $page>$total)//如果$page不合法则$page为1
$page=1
$start=($page-1)*$pagesize//第一条记录所在行数
$sql .="order by id desc limit $start,$pagesize"//按商品ID倒序排列后选择返回$start开始的$pagesize条记录数
$result = mysql_query($sql) or die ('数据库查询失败2')
while($row=mysql_fetch_array($result))
{
echo '商品id'.$row['id'].'<br />'
}
//分页栏显示,此处略去
}else echo '页面不存在或已删除!'
多个图片可以同样放在你的image下,图片与图片之间用一个符号隔开,比如1.jpg|2.jpg|33.jpg读取记录之后可以用比如
12string str="1.jpg|2.jpg|33.jpg"string[] arr=str.Split('|')
这样arr中就是单个图片路径了,当然这仅仅只是一种方法。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)