我在PHP上有这个Web模块,我们刚刚从5.3迁移到PHP 7.2。我们也开始使用该学说,并且一切正常。突然,Web模块开始显示随机500个错误。甚至没有采取相同的行动。我仍然不知道为什么,但是我可以每次使用原理的 lastInsertId 来触发它。每次它传递该函数时,都会引发一个通用的500错误(即使我在php.ini上激活了错误,我也没有得到关于该错误的任何详细信息)。
Ajax呼叫:
function listaCandidatos() {
$('#' + GLOBAL_ID).find('#candidates-button').click(function () {
var btn = this,
url = BASE_URL + 'actualizacion-candidatos.php',
numInv = $('#' + GLOBAL_ID).find('#num_inventario').val();
$(btn).attr('disabled', 'disabled');
$.post(url, {numInv: numInv}, function (response) {
if (response.success) {
enableScannerForm();
$('#' + GLOBAL_ID).find('#master_id').val(response.masterId);
$('#' + GLOBAL_ID).find('#last_master_id').val(response.masterId);
loadListScanner();
} else {
alert(response.message);
$(btn).removeAttr('disabled');
}
}, 'json');
});
}
PHP操作:
public function candidatos()
{
ILogger::info('ACTUALIZACION DE INVENTARIO OBTENER CANDIDATOS (INICIO)');
$result = array('success' => true, 'message' => '');
if (!Request::isAjax()) {
$result['success'] = false;
$result['message'] = 'No ajax request';
} else {
$pa_idpais = $_SESSION['pa_idpais'];
$estacion = $_SESSION['estacion'];
$modulo = $_SESSION['modulo'];
$login = $_SESSION['login'];
$mModel = new InventarioMaster();
$dModel = new InventarioDetalle();
$tModel = new InventarioDetalleTemp();
$hModel = new InventarioHistorial();
ILogger::info('EJECUCION DE QUERY OBTENER CANDIDATOS (INICIO)');
$candidates = $dModel->getCandidates();
ILogger::info('EJECUCION DE QUERY OBTENER CANDIDATOS (FIN)');
$result['masterId'] = 0;
if (count($candidates) > 0) {
IDBConnection::getInstance()->beginTransaction();
try {
$dataMaster = array(
'num_folio' => time(),
'id_courier' => 0,
'pa_idpais' => $pa_idpais,
'est_idestacion' => $estacion,
'mod_idmodulo' => $modulo,
'usu_login' => $login,
'inv_fecha_ingreso' => "CONVERT(datetime, DATEADD(hh, " . $_SESSION['pa_zona'] . ", GETUTCDATE()), 103)",
'inv_tipo' => 'ACT'
);
ILogger::info('EJECUCION DE QUERY REGISTRAR INVENTARIO_MASTER (INICIO)');
**$masterId = $mModel->register($dataMaster);**
ILogger::info('EJECUCION DE QUERY REGISTRAR INVENTARIO_MASTER (FIN)');
$tmpData = array(
'id_inv_master' => $masterId,
'id_inv_detalle' => '',
'gui_idguia' => '',
'pid' => null,
'inv_actual_checkpoint' => 'CC',
'temp_fecha_actual_registro' => "CONVERT(datetime, DATEADD(hh, " . $_SESSION['pa_zona'] . ", GETUTCDATE()), 103)",
'inv_status' => 'SE'
);
foreach ($candidates as $item) {
$tmpData['id_inv_detalle'] = $item['id_inv_detalle'];
$tmpData['gui_idguia'] = $item['gui_idguia'];
$tmpData['pid'] = $item['pid'];
if ($item['inv_checkpoint'] == 'SA') {
$tmpData['inv_actual_checkpoint'] = $item['inv_checkpoint'];
}
if ($item['det_tipo_ingreso'] == 'COU' && in_array($item['inv_status'], array('IN', 'AC'))) {
$tmpData['inv_actual_checkpoint'] = 'CC';
}
ILogger::info('EJECUCION DE QUERY REGISTRAR INVENTARIO_DETALLE_TEMP (INICIO)');
$tModel->register($tmpData);
ILogger::info('EJECUCION DE QUERY REGISTRAR INVENTARIO_DETALLE_TEMP (FIN)');
$dataHistory = array(
'id_inv_master' => $masterId,
'id_inv_detalle' => $item['id_inv_detalle'],
'his_checkpoint' => $item['inv_checkpoint'],
'his_checkpoint_candidato' => $item['inv_checkpoint'],
'his_fecha_registro' => $tmpData['temp_fecha_actual_registro'],
'his_comentario' => 'Sin escanear',
'usu_login' => $login,
'inv_status' => 'SE',
'his_evento' => 'ACT'
);
ILogger::info('EJECUCION DE QUERY REGISTRAR INVENTARIO_HISTORIAL (INICIO)');
$hModel->register($dataHistory);
ILogger::info('EJECUCION DE QUERY REGISTRAR INVENTARIO_HISTORIAL (FIN)');
}
IDBConnection::getInstance()->commitTransaction();
$result['masterId'] = $masterId;
$queueData = array(
'detalleIds' => '',
'lastGuia' => '',
'lastId' => '',
'lastMasterId' => $masterId,
'lastNumInv' => '0',
'lastRequestType' => '',
'lastRequestValue' => '',
'masterId' => $masterId,
'fromMasterId' => '',
'numInv' => '',
'numPiezas' => ''
);
ScannerData::setId('inventarios_scanner_actualizacion');
ScannerData::saveData($queueData);
} catch (Exception $ex) {
IDBConnection::getInstance()->rollbackTransaction();
$result['success'] = false;
$result['message'] = utf8_encode($ex->getMessage());
$result['masterId'] = null;
}
}
}
ILogger::info('ACTUALIZACION DE INVENTARIO OBTENER CANDIDATOS (FIN)');
echo json_encode($result);
return;
}
在寄存器功能中发生错误:
$masterId = $mModel->register($dataMaster);
这是哪个:
public function register($data = array())
{
$sql = "
INSERT INTO
inventario_master
(
num_folio,
id_courier,
pa_idpais,
est_idestacion,
mod_idmodulo,
usu_login,
inv_fecha_ingreso,
inv_tipo
)
VALUES
(
'" . $data['num_folio'] . "',
'" . $data['id_courier'] . "',
'" . $data['pa_idpais'] . "',
'" . $data['est_idestacion'] . "',
'" . $data['mod_idmodulo'] . "',
'" . $data['usu_login'] . "',
" . $data['inv_fecha_ingreso'] . ",
'" . $data['inv_tipo'] . "'
)
";
$this->db->executeQuery($sql);
return $this->db->lastInsertId();
}
lastInsertId只是调用了同名的学说函数。
我尝试捕获错误,但未能成功。 register函数实际上发生了,我确实通过函数获得了ID,但是ajax调用每次都会返回错误。我尝试从Ajax中读取错误消息,但它为空。这也适用于我的本地计算机IIS。这可能与该服务器配置有关,但我不确定。
引发错误的服务器是Windows Server 2016版本1607和IIS版本10.0.14393.0,并且我们将Microsoft SQL Server 2016用于数据库。
谢谢。