【发布时间】:2013-10-23 19:09:35
【问题描述】:
我真的被困在这里了。我有一个在 Firefox 上运行两次的插入语句,但(正确地)在 IE 中只运行一次。
什么可能导致 Firefox 运行两次插入语句?它只运行此查询两次,而不是页面上的其他查询。除了我在下面发布的内容之外,我还注释掉了所有其他代码,它仍然在 Firefox 中插入了两次。
if((isset($_GET['stepNum']))&&(isset($_GET['idNum']))){
$stepNum = $_GET['stepNum'];
$idNum = $_GET['idNum'];
$startCycleNum = 1;
$startCycleStatus = 1;
$cycleGo = true;
}//end isset if statement
try {
if ($cycleGo == true) {
$stmtC = $db->prepare('INSERT INTO mytable (cycleNum, cycleStatus, processID) VALUES (:cycleNum, :cycleStatus, :processID)');
$stmtC->execute(array(':cycleNum' => $startCycleNum, ':cycleStatus' => $startCycleStatus, ':processID' => $idNum));
$cycleGo = false;
$newCycle = $db->lastInsertId();
}
}//end try
catch (PDOException $ex) {
echo '<h5>There was an error saving the new cycle. Please try again.</h5>';
}//end catch
任何想法将不胜感激。我尝试在 Firefox 中清除缓存无济于事。
编辑:提交表单getsteps.php的代码
if ($stepNum != 'none') {
echo '<form name="addNewForm" action="createcycleone?idNum='.$idNum.'stepNum='.$stepNum.'" method="post">
<table width = "100%" id="formfields">';
//form inputs
echo '<tr><td colspan="2"> </td></tr>
<tr><td colspan="2" style="text-align:center"><input type="submit" value="Save and Create Cycle"></input></td></tr>
</table>
</form> ';
}
编辑:调用 getSteps.php 的 php 页面中的代码以加载正确数量的步骤(字段)
//get the stepNum
if((isset($_GET['nid']))&&(isset($_GET['idNum']))){
$stepNum = $_GET['nid'];
$idNum = $_GET['idNum'];
}
<form id="stepsForm" name="stepsForm">
<table width ="100%" id="stepfield">
<tr><td><strong>Number of Steps:</strong></td>
<td><select name="getSteps" id="getSteps" onchange="$('#formContainer1').load('../files/createUAT/getSteps.php?nid='+this.value+'&idNum='+<?php print $idNum; ?>);">
<option value="none">Select a Number</option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
<option value="5">5</option>
<option value="6">6</option>
<option value="7">7</option>
<option value="8">8</option>
</select>
</td></tr></table>
</form>
<div id ="formContainer1" class="formContainer1">
</div>
【问题讨论】:
-
我没有仔细研究你的代码,但除非涉及到一些 JS,否则我看不出浏览器有什么不同。
-
谁立即对此投反对票?这并不是说我在发布之前没有尝试过搜索...
-
是否有任何循环我看到 $cycleGo = false;并且想知道此代码之外还有其他内容。 PDOExecption 是否曾经触发过?
-
是的,问题很可能在于页面本身的提交方式(通过 Javascript 或其他方式)。最有可能的是,它是通过 AJAX 提交的,然后提交按钮事件也被触发(在不同的浏览器中,它的工作方式可能不同,具体取决于它的构造方式)。
-
由于它是服务器端代码(其中没有任何内容处理任何特定于浏览器的内容),因此无法回答您的问题 - 那么触发此脚本在第一名?可能有任何外部资源(脚本、图像等)嵌入到 HTML 文档中且 src/href 属性为空? (这些是“莫名其妙的”双重请求的常见原因。)Firebug 的网络面板中是否有任何内容表明对正在发出的脚本有两个请求?