複数のページを生成するスクリプトにフォーム変数を渡そうとすると、問題が発生しました。
My Formは、次のスクリプトに$ _POSTを使用して、郡名と言語を2つの別個のフィールドとして提供します。スクリプトは、クエリがハードコーディングされている場合、およびpage=1の場合は$_POSTを介して変数を渡すときにresults.phpページで機能します。ただし、後続のページでは$ _POST変数が失われ、この問題の解決策には$ _SESSIONコマンドが含まれることはわかっていますが、これを機能させることはできません:(。実際、パラメーターはに渡されますが、結果は表示されません。これらの機能。
これが私のコードです
<?php
$_SESSION['county']=$_POST['county'];
$_SESSION['language']=$_POST['language'];
$speak=$_POST['language'];
$area=$_POST['county']
?>
<table class="bda" width="100%" align = "center"><tr><td class="hrak">Open test db file on lcn</td></tr></table>
<?php
$conn = connect();
/*******************************************************************************************
The variable '$showrecs' refers to the number of rows on each page - this can be changed.
'$pagerange refers to blocks of records, again can be changed.
*******************************************************************************************/
$area=$_POST['county'];
$speak=$_POST['language'];
$showrecs = 20;
$pagerange = 10;
$page = @$_GET["page"];
if (!isset($page)) $page = 1;
select();
mysql_close($conn);
?>
<table class="bda" width="100%"><tr><td class="hrak">Powered by MySQL</td></tr></table>
</body>
</html>
<?php
/******************************************** - START OF FUNCTIONS *************************************/
?>
<?php function select()
{
global $a;
global $showrecs;
global $page;
$res = sql_select();
$count = sql_getrecordcount();
if ($count % $showrecs != 0) {
$pagecount = intval($count / $showrecs) + 1;
}
else {
$pagecount = intval($count / $showrecs);
}
$startrec = $showrecs * ($page - 1);
if ($startrec < $count) {mysql_data_seek($res, $startrec);}
$reccount = min($showrecs * $page, $count);
?>
<table class="bd" border="0" cellspacing="1" cellpadding="4" width="100%" align = "center">
<tr><td class="hrak" align="center" width="100%">Records shown <?php echo $startrec + 1 ?> - <?php echo $reccount ?> of <?php echo $count ?></td></tr>
</table>
<?php showpagenav($page, $pagecount); ?>
<br>
<table class="tbl" border="0" cellspacing="1" cellpadding="5"width="100%">
<tr>
<!- ***************************************
HEADER row of the table - HTML
**************************************** ->
<td>
</td>
</tr>
<?php
for ($i = $startrec; $i < $reccount; $i++)
{
$row = mysql_fetch_assoc($res);
$mem13 = ($row["title"]);
if ($mem13 == 'Mr')
{
$style = "dr";
$styler = "drr";
if ($i % 2 != 0)
{
$style = "sr";
$styler = "srr";
}
}
else
{
$style = "ndr";
$styler = "ndrr";
if ($i % 2 != 0)
{
$style = "nsr";
$styler = "nsrr";
}
}
?>
<tr>
<!-- *********************************************
This is where I populate the DATA rows of the table - HTML
********************************************** -->
<td class="<?php echo $style ?>"><?php echo htmlspecialchars($row["id"]) ?></td>
</tr>
<?php
}
/*** mysql_free_result($res); ***/
?>
</table>
<br>
<?php showpagenav($page, $pagecount); ?>
<?php } ?>
<?php function showpagenav($page, $pagecount)
{
?>
<table class="bd" border="0" cellspacing="1" cellpadding="4" >
<tr>
<?php if ($page > 1) { ?>
<!- /*************************************************************************
This generates 'results.php' and the sub pages results results.php?page=2...
*****************************************************************************/
-->
<td class="hrak1" align="center"><a href="results.php?page=<?php echo $page - 1 ? >"><< Prev</a> </td>
<?php } ?>
<?php
global $pagerange;
if ($pagecount > 1) {
if ($pagecount % $pagerange != 0) {
$rangecount = intval($pagecount / $pagerange) + 1;
}
else {
$rangecount = intval($pagecount / $pagerange);
}
for ($i = 1; $i < $rangecount + 1; $i++) {
$startpage = (($i - 1) * $pagerange) + 1;
$count = min($i * $pagerange, $pagecount);
if ((($page >= $startpage) && ($page <= ($i * $pagerange)))) {
for ($j = $startpage; $j < $count + 1; $j++) {
if ($j == $page) {
?>
<td><b><?php echo $j ?></b></td>
<?php } else { ?>
<!--
/*****************************************************************************************************
results.php?pagen so that the required page number is generated.
*****************************************************************************************************/
-->
<td class="hrak1" align="center"><a href="results.php?page=<?php echo $j ?>"><?php echo $j ?></a></td>
<?php } } } else { ?>
<td class="hrak1" align="center"><a href="results.php?page=<?php echo $startpage ?>"><?php echo $startpage ."..." .$count ?></a></td>
<?php } } } ?>
<?php if ($page < $pagecount) { ?>
<td class="hrak1" align="center"> <a href="results.php?page=<?php echo $page + 1 ?>">Next >></a> </td>
<?php } ?>
</tr>
</table>
<?php } ?>
<?php
/******************************************** - FUNCTION - SQL_SELECT *************************************/
function sql_select()
{
/******************************************************************************
SELECT statement for results to be displayed
******************************************************************************/
$area=$_POST['county'];
$speak=$_POST['language'];
global $conn;
$sql = "SELECT * FROM test2 WHERE language='$speak' AND county='$area' ORDER BY id";
$res = mysql_query($sql, $conn) or die(mysql_error());
return $res;
}
/******************************************** - FUNCTION - SQL_GETRECORDCOUNT *************************************/
function sql_getrecordcount()
{
$area=$_POST['county'];
$speak=$_POST['language'];
$sql = "SELECT COUNT(*) FROM test2 WHERE language='$speak' AND county='$area'";
$res = mysql_query($sql, $conn) or die(mysql_error());
$row = mysql_fetch_assoc($res);
reset($row);
return current($row);
}
/******************************************** - FUNCTION - CONNECT *************************************/
$ _POSTを使用せずにコードが機能してパラメーターを渡すことはわかっていますが、複数の結果ページ(results.php?page = n)でコードを機能させることはできません。私は何が欠けていますか?
よろしく、
ボブ