mirror of
https://github.com/Sucareto/ESP32-CardReader.git
synced 2024-11-12 01:30:52 +01:00
添加 OTA 更新用 php 脚本。
This commit is contained in:
parent
93f8ff505c
commit
64926f1e77
54
OTA/index.php
Normal file
54
OTA/index.php
Normal file
@ -0,0 +1,54 @@
|
||||
<?PHP
|
||||
|
||||
header('Content-type: text/plain; charset=utf8', true);
|
||||
|
||||
function check_header($name, $value = false)
|
||||
{
|
||||
if (!isset($_SERVER[$name])) {
|
||||
return false;
|
||||
}
|
||||
if ($value && $_SERVER[$name] != $value) {
|
||||
return false;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
function sendFile($path)
|
||||
{
|
||||
header($_SERVER["SERVER_PROTOCOL"] . ' 200 OK', true, 200);
|
||||
header('Content-Type: application/octet-stream', true);
|
||||
header('Content-Disposition: attachment; filename=' . basename($path));
|
||||
header('Content-Length: ' . filesize($path), true);
|
||||
header('x-MD5: ' . md5_file($path), true);
|
||||
readfile($path);
|
||||
}
|
||||
error_log(print_r($_SERVER, true));
|
||||
|
||||
if (!check_header('HTTP_USER_AGENT', 'ESP32-http-Update')) {
|
||||
header($_SERVER["SERVER_PROTOCOL"] . ' 403 Forbidden', true, 403);
|
||||
echo "only for ESP32 updater!\n";
|
||||
exit();
|
||||
}
|
||||
|
||||
if (
|
||||
!check_header('HTTP_X_ESP32_STA_MAC') ||
|
||||
!check_header('HTTP_X_ESP32_AP_MAC') ||
|
||||
!check_header('HTTP_X_ESP32_FREE_SPACE') ||
|
||||
!check_header('HTTP_X_ESP32_SKETCH_SIZE') ||
|
||||
!check_header('HTTP_X_ESP32_SKETCH_MD5') ||
|
||||
!check_header('HTTP_X_ESP32_CHIP_SIZE') ||
|
||||
!check_header('HTTP_X_ESP32_SDK_VERSION')
|
||||
) {
|
||||
header($_SERVER["SERVER_PROTOCOL"] . ' 403 Forbidden', true, 403);
|
||||
echo "only for ESP32 updater! (header)\n";
|
||||
exit();
|
||||
}
|
||||
|
||||
$localBinary = "./AimeESP32.ino.nodemcu-32s.bin";
|
||||
|
||||
if ($_SERVER["HTTP_X_ESP32_SKETCH_MD5"] != md5_file($localBinary)) {
|
||||
sendFile($localBinary);
|
||||
} else {
|
||||
header($_SERVER["SERVER_PROTOCOL"] . ' 304 Not Modified', true, 304);
|
||||
}
|
Loading…
Reference in New Issue
Block a user