如何在运行查询后直接转到另一个页面

时间:2015-08-23 06:16:22

标签: php html mysql

运行查询后我可以创建类似的内容吗?

if($query)
{
  succes.php;
}
else
{
  fail.php;
}

试过这个,但也没有用......

$url = '../modul_produk/index.php';
$url2 = '../modul_produk/index2.php';
if($query)
{
    header('Location: ' . $url);
}
else
{
 header('Location: ' . $url2);
}

我收到此错误

  

注意:未定义的变量:第148行的> C:\ xampp \ htdocs \ Payang \ modul_daftar \ index4.php中的查询

     

警告:无法修改标头信息 - 已经由> C:\ xampp \ htdocs \ Payang \ modul_daftar中的(输出>从C:\ xampp \ htdocs \ Payang \ modul_daftar \ index4.php:126开始)发送的标头第153行上的\ index4.php

第126行是指?php

第148和153行都引用$url和标题..

我不明白为什么?php认为是标题?我怎样才能解决这个问题?尝试了所有提及的答案,似乎问题出现在第{126行的错误中提到?php

对于ref,这是完整的代码:

<!DOCTYPE html>
<html lang="en">
<head>
        <meta charset="UTF-8"/>
        <title>Sistem Laporan Bersepadu</title>
        <meta charset="utf-8">
		<meta name="viewport" content="width=device-width, initial-scale=1">
		<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootswatch/3.3.5/darkly/bootstrap.min.css">
		<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
		<script src="http://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
		<script>
		function uploadImage(oForm) {
		var _validFileExtensions = [".jpg", ".jpeg", ".gif", ".png"];
		var oInput = document.getElementById("image");
		var sFileName = oInput.value;
		var size = oInput.files[0].size;			
		
		var oFReader = new FileReader();
		oFReader.readAsDataURL(document.getElementById("image").files[0]);
		oFReader.onload = function(oFREvent) {
			document.getElementById("uploadPreview").src = oFREvent.target.result;
		};
		
		if (sFileName.length > 0) {
			var blnValid = false;
			for (var j = 0; j < _validFileExtensions.length; j++) {
				var sCurExtension = _validFileExtensions[j];
				if (sFileName.substr(sFileName.length - sCurExtension.length, sCurExtension.length).toLowerCase() == sCurExtension.toLowerCase()) {
					blnValid = true;
					break;
				}
			}				
			if (!blnValid) {
				document.getElementById("alert").innerHTML="<span class='label label-danger'>Tidak Sah</span>";
				document.getElementById("submitBtn").disabled = true;
				return false;
			}
		}			
		if(size > 4294967295){
			document.getElementById("alert").innerHTML="<span class='label label-danger'>Tidak Sah</span>";
			document.getElementById("submitBtn").disabled = true;
			return false;
		}else {			
			document.getElementById("alert").innerHTML="<span class='label label-success'>Sah</span>.";
			document.getElementById("submitBtn").disabled = false;
			return true;				
		}
		}
		</script>	
</head>
<body>
	<div class="container">
	<div class="row">
		<div class="col-sm-2">
		</div>
		<div class="col-sm-8">
			<h2>Borang Pendaftaran</h2>
			<h5>Sila Isi Semua Maklumat</h2>
			
			<div class="panel panel-primary">
			<div class="panel-heading"><span class="glyphicon glyphicon-paperclip"></span> Borang untuk pelapor</div>
				<div class="panel-body">
					<form id="produkForm" action="../modul_kemaskini/index.php" class="form-horizontal" method="post" enctype="multipart/form-data">		
						<fieldset>										
																		
							
							<div class="form-group">
								<label for="inputKodProduk" class="col-lg-2 control-label">Kod Produk</label>
								<div class="col-lg-10">
									<input type="text" class="form-control" name="inputKodProduk" id="inputKodProduk" placeholder="KodProduk">
								</div>
							</div>
							
							<div class="form-group">
								<label for="inputNamaProduk" class="col-lg-2 control-label">Nama Produk</label>
								<div class="col-lg-10">
									<input type="text" class="form-control" name="inputNamaProduk" id="inputNamaProduk" placeholder="NamaProduk">
								</div>
							</div>
							
							<div class="form-group">
								<label for="inputSpesifikasi" class="col-lg-2 control-label">Spesifikasi</label>
								<div class="col-lg-10">
									<input type="text" class="form-control" name="inputSpesifikasi" id="inputSpesifikasi" placeholder="Spesifikasi">
								</div>
							</div>
						
									
							<div class="form-group">
									<label for="selectJenis" class="col-lg-2 control-label">Jenis</label>
									<div class="col-lg-10">
										<select class="form-control" id="selectJenis" name="selectJenis">
											<option value="silapilih">Sila Pilih</option>
											<option value="Telefon">Telefon</option>
											<option value="Tv">Tv</option>
											<option value="Laptop">Laptop</option>
										</select>
									</div>
							</div>
							
							<div class="form-group">
								<label for="inputHarga" class="col-lg-2 control-label">Harga</label>
								<div class="col-lg-10">
									<input type="text" class="form-control" name="inputHarga" id="inputHarga" placeholder="RM">
								</div>
							</div>
							
							<div class="form-group">
								<label for="image" class="col-lg-2 control-label">Gambar</label>
								<div class="col-lg-10">
									<img src="" id="uploadPreview" class="img-responsive" style="height: 100px;" />
									<input type="file" name="image" id="image" onchange="uploadImage(this)">
								</div>
							</div>
							
							
							
							<div class="form-group">
									<div class="col-lg-10 col-lg-offset-2">	
										
										<input type="submit" name="submit" value="Save" />
									<div id="alert"></div>								
								</div>
							</div>
							
							<?php	
							if (isset($_POST['submit']))
							{	   
								include '../include/conn.php';
                
								$kod=$_POST['inputKodProduk'] ;
								$namaproduk= $_POST['inputNamaProduk'] ;					
								$spesifikasi=$_POST['inputSpesifikasi'] ;
								$jenis=$_POST['selectJenis'] ;
								$harga=$_POST['inputHarga'] ;
								$image= addslashes($_FILES['image']['tmp_name']);
								$name= addslashes($_FILES['image']['name']);
								$image= file_get_contents($image);
								$image= base64_encode($image);
					
								$query = mysql_query("INSERT INTO `produk2`
								(product_code,product_name,product_desc,product_type,product_price,product_img,product_img_name) 
								VALUES ('$kod','$namaproduk','$spesifikasi','$jenis','$$harga','$image','$name')");
							}
							if($query)
{
    $url = '../modul_produk/index.php';
}
else
{
    $url = '../modul_produk/index2.php';
}

header('Location: ' . $url);
exit();
								
								
			
				
			
							?>
							
							
						
				</div>
			</div>
		</div>
	</div>
	</div>

	
            
    
</fieldset>
</form>
</body>
</html>

5 个答案:

答案 0 :(得分:0)

错误是因为您在同一文件中发送了header两次。尝试使用条件语句将URL存储在变量中,而只设置一次头。这样的事情可能有用:

if($query)
{
    $url = '../modul_produk/index.php';
}
else
{
    $url = '../modul_produk/index2.php';
}

header('Location: ' . $url);
exit();

答案 1 :(得分:0)

您所指的网址是指互联网上的内部网页还是外部网页?如果它是一个外部页面,那么我同意@Rino Raj,但如果它是一个内部页面,你只需要标题(&#39;位置:thepage.php&#39;);

答案 2 :(得分:0)

尝试以下代码

$url = '../modul_produk/index.php';
$url2 = '../modul_produk/index2.php';
if($query)
{
    header("Location: ${url}");
}
else
{
 header("Location: ${url2}");
}

您需要对代码进行一些更改,移动

if($query)...

里面的

if(isset($_POST['session']))

答案 3 :(得分:0)

首先在148检查你的代码什么是未定义的,请定义它,如果不可能,只需在文件顶部执行一个ob_start(),这应该禁止缓冲区头已经发送警告,并且应该重定向你想要的页面。

并且还请在标题位置代码之后添加exit()或die()。

答案 4 :(得分:0)

我相信有两个问题。

  1. 调用header()函数会发送HTTP标头。这些包含有关服务器请求的一些元数据,并指示浏览器如何处理响应,在您的情况下显示不同的页面。他们在回复中must be sent as the first thing,否则浏览器解释它们为时已晚。

    在您的情况下,服务器首先发送<!DOCTYPE html>...,然后发送标头为时已晚。您必须在输出之前调用header() 。这包括发送HTML,调用echo ...甚至发送错误消息(Notice: ...在您的案例中)

    该怎么办?最简单的解决方案是在脚本中先前调用header()。把

       <?php    
           if (isset($_POST['submit'])) {      
              include '../include/conn.php';
    
              $kod=$_POST['inputKodProduk'] ;
              //....
              $query = mysql_query("INSERT INTO `produk2`
                (product_code,product_name,product_desc,product_type,product_price,product_img,product_img_name) 
                VALUES ('$kod','$namaproduk','$spesifikasi','$jenis','$$harga','$image','$name')");
              if($query) {}
                $url = '../modul_produk/index.php';
              } else {
                $url = '../modul_produk/index2.php';
              }
              header('Location: ' . $url);
              exit();
           }
      ?>
    

    作为脚本中的第一件事。可以找到如何处理此问题的综合说明here

  2. 另一个问题是Notice: Undefined variable: query错误。如果isset($_POST['submit']))被评估为false,则不会初始化变量$query。您可能希望移动if($query) if if(isset($_POST['submit'])))块中的块,如上面给出的示例中所示。否则通知消息将被发送到浏览器,它也可能搞乱发送标题。