SHT30 온습도 모니터링 시스템 전체 소스(서버 PHP, STM32 펌웨어, SQL, 테스트). 전체 코드리뷰에서 도출된 보안 하드닝 10건 반영: - 요청 서명 HMAC-SHA256 전환(펌웨어 sig.c/서버 config.php/호스트 패리티 동시) - 재전송 방어 + 기본 API_KEY fail-closed + 디바이스 문자열 정제(api/sensor_data.php) - 오프라인 SMS 중복 발송 경합 제거(cron_heartbeat.php, 원자적 선점) - CSV 수식 주입 방지(monthly_report.php), 감사로그 회전 락(retention_cleanup.php) - 브루트포스 카운터 원자화(login.php), 예시 TOTP 비밀키 무효화, 마이그레이션 멱등화 _backup/(하드코딩 실 비밀값 포함)·config.local.php·런타임 상태는 .gitignore 제외.
24 lines
736 B
PHP
24 lines
736 B
PHP
<?php
|
|
// =============================================================================
|
|
// setup_hash.php - 관리자 비밀번호 bcrypt 해시 생성 도구 (v2605)
|
|
//
|
|
// 사용법:
|
|
// php setup_hash.php "새비밀번호"
|
|
//
|
|
// 출력된 값을 config.local.php의 ADMIN_PASSWORD_HASH에 넣습니다.
|
|
// =============================================================================
|
|
|
|
if (php_sapi_name() !== 'cli') {
|
|
http_response_code(403);
|
|
header('Content-Type: text/plain; charset=utf-8');
|
|
echo "Forbidden\n";
|
|
exit;
|
|
}
|
|
|
|
$password = $argv[1] ?? '';
|
|
if ($password === '') {
|
|
fwrite(STDERR, "Usage: php setup_hash.php \"new-password\"\n");
|
|
exit(1);
|
|
}
|
|
|
|
echo password_hash($password, PASSWORD_DEFAULT) . PHP_EOL;
|