분리후 첫 Crawling 성공 모델
This commit is contained in:
24
OpcPksPlatform/OpcPks.Web/Views/Engineering/Admin.cshtml
Normal file
24
OpcPksPlatform/OpcPks.Web/Views/Engineering/Admin.cshtml
Normal 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>
|
||||
@@ -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>
|
||||
Reference in New Issue
Block a user