具有原则的最后插入ID导致500错误PHP

时间:2018-09-24 15:01:55

标签: php ajax doctrine-orm http-status-code-500

我在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用于数据库。

谢谢。

1 个答案:

答案 0 :(得分:-1)

错误500也可能导致文件中的BOOM。检查BOOM 您可以尝试返回的不是lastInsertId而是随机数-错误仍然存​​在吗?