Откуда прилетают запросы

в 15:52, , рубрики: oracle, php, метки: , ,

Чтобы в списке сессий на сервере Oracle видеть откуда с веба нам пришел запрос, достаточно добавить 7 строк кода в расширение PHP OCI8.

Откуда прилетают запросы

Файл

ext/oci8/oci8.c

В начале

#include "SAPI.h"

В функции php_oci_do_connect вставляем шесть строк

	if (!connection) {
		RETURN_FALSE;
	}

	char* hostname = sapi_getenv("HTTP_HOST", 100 TSRMLS_CC);
	char* uri = sapi_getenv("REQUEST_URI", 100 TSRMLS_CC);
	char* reqid = sapi_getenv("HTTP_X_REQUEST_ID", 32 TSRMLS_CC);
	PHP_OCI_CALL_RETURN(OCI_G(errcode), OCIAttrSet, ((dvoid *) connection->session, (ub4) OCI_HTYPE_SESSION, (dvoid *) hostname, (ub4) strlen(hostname), (ub4) OCI_ATTR_MODULE, OCI_G(err)));
	PHP_OCI_CALL_RETURN(OCI_G(errcode), OCIAttrSet, ((dvoid *) connection->session, (ub4) OCI_HTYPE_SESSION, (dvoid *) uri, (ub4) strlen(uri), (ub4) OCI_ATTR_ACTION, OCI_G(err)));
	PHP_OCI_CALL_RETURN(OCI_G(errcode), OCIAttrSet, ((dvoid *) connection->session, (ub4) OCI_HTYPE_SESSION, (dvoid *) reqid, (ub4) strlen(reqid), (ub4) OCI_ATTR_CLIENT_INFO, OCI_G(err)));

	RETURN_RESOURCE(connection->rsrc_id);

Module и action видны не только в V$SESSION, но и в V$SQLAREA. Кроме host и request_uri у себя мы пишем уникальный сквозной идентификатор запроса, который в дальнейшем можно отследить по логам nginx и apache.

Автор: woyager

* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js