분리후 첫 Crawling 성공 모델

This commit is contained in:
2026-02-22 22:59:21 +09:00
parent 171aaf6115
commit 4e006a5a5f
208 changed files with 613035 additions and 0 deletions

View File

@@ -0,0 +1,24 @@
<div class="card border-danger">
<div class="card-header bg-danger text-white">System Engineering - Discovery Mode</div>
<div class="card-body">
<h5>1. 하니웰 자산 모델 탐사 (Crawler)</h5>
<p class="text-muted">서버의 모든 노드를 훑어 CSV 파일을 생성합니다. (시간이 오래 걸릴 수 있음)</p>
<button id="btnRunCrawler" class="btn btn-danger" onclick="runCrawler()">🚀 탐사 및 CSV 생성 시작</button>
<hr>
<h5>2. DB 동기화 (CSV to Database)</h5>
<p class="text-muted">생성된 Honeywell_FullMap.csv 파일을 읽어 DB에 일괄 저장합니다.</p>
<button id="btnImportCsv" class="btn btn-warning" onclick="importCsvToDb()">📥 CSV 데이터를 DB로 가져오기</button>
</div>
</div>
<script>
function runCrawler() {
if(!confirm("전체 노드 탐사를 시작하시겠습니까? 하니웰 서버에 부하가 갈 수 있습니다.")) return;
// API 호출: /Engineering/RunCrawler
}
function importCsvToDb() {
// API 호출: /Engineering/ImportCsv
}
</script>

View File

@@ -0,0 +1,51 @@
@{
ViewData["Title"] = "Honeywell Engineering";
}
<div class="container mt-5">
<div class="card border-success shadow">
<div class="card-header bg-success text-white">
<strong>✅ Connection Verified (Ready to Crawl)</strong>
</div>
<div class="card-body text-center">
<h5 class="mb-4">하니웰 서버 탐사 준비 완료</h5>
<button type="button" onclick="startHoneywellCrawler()" class="btn btn-success btn-lg px-5 fw-bold">
🚀 Run Honeywell Crawler
</button>
<div id="debugLog" class="mt-4 p-3 bg-light text-start small border" style="display:none; max-height: 200px; overflow-y: auto;">
<strong>로그:</strong> <div id="logContent"></div>
</div>
</div>
</div>
</div>
<script>
function startHoneywellCrawler() {
const logDiv = document.getElementById('debugLog');
const content = document.getElementById('logContent');
logDiv.style.display = 'block';
content.innerHTML += "<div>📡 서버에 탐사 신호를 보냅니다...</div>";
// curl -X POST와 동일한 동작
fetch('/Engineering/RunCrawler', {
method: 'POST'
})
.then(async res => {
const data = await res.json();
content.innerHTML += `<div>📥 서버 응답 (${res.status}): ${data.message || '완료'}</div>`;
if (res.ok) {
alert("성공! 우분투 터미널에서 탐사 진행 상황을 확인하세요.");
} else {
// 아까 curl에서 보셨던 인증서 에러가 여기 팝업으로 뜰 겁니다.
alert("서버 내부 로직 에러: " + (data.message || "알 수 없는 오류"));
}
})
.catch(err => {
content.innerHTML += `<div class="text-danger">❌ 통신 실패: ${err}</div>`;
alert("서버 연결 실패!");
});
}
</script>