Create a file called log.js
or anything like that and put it in the "root" of the publish folder (public_html
or www
, depends on your system)
Then create a file called log.php
also at the root
Now on the log.js
add this:
note: (new Date().getTime())
is only to avoid caching
(function (d) {
function trigger() {
var oReq = new XMLHttpRequest();
//Defina como true
oReq.open("GET", "/log.php?_=" + (new Date().getTime()), true);
//Envia a requisição, mas a resposta fica sendo aguardada em Background
oReq.send(null);
}
//Verifica se a página já foi carregada
if (/^(interactive|complete)$/i.test(d.readyState)) {
trigger();
} else {
d.addEventListener('DOMContentLoaded', trigger);
}
})(document);
In the log.php
add to your mysql instructions:
<?php
//Conecta
$mysqli = new mysqli("localhost", "usuario", "senha", "banco");
if (mysqli_connect_errno()) {
printf("Erro de conexão: %s\n", mysqli_connect_error());
exit;
}
$ip = $_SERVER['REMOTE_ADDR'];
$result = $mysqli->query('INSERT INTO `logs` (`data`, `ip`) VALUES (now(), \'' . $ip . '\')');
if ($result) {
$result->close();
}
$mysqli->close();
Now on all HTML pages add
<script src="/log.js"></script>
Ajax solves, doesn’t it? You could inject an Ajax that would require a single PHP that would do this.
– Guilherme Nascimento
Hello William, resolve yes. Could you give me an example? because I don’t know much Ajax.
– user24136
Fox, see if you can understand the answer
– Guilherme Nascimento