@docs/index.html은 @docs/app/ @docs/reports/ @docs/security_checker/ 의 index.html 들로 연결하는 허브페이지야. 연결할 페이지들은 아래와 같아
docs/app/index.html 테스트용 Ruby on Rails 앱 Transcript docs/security_checker/index.html 화이트해커 Skill/Agent(s) Transcript docs/reports/index.html 보안점검 리포트
사용자가 docs/index.html을 만들어 달라고 합니다. 이 페이지는 세 개의 하위 페이지로 연결하는 Hub 페이지입니다:
먼저 reports/index.html을 만들고, 그 다음 메인 Hub 페이지를 만들겠습니다.
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>보안점검 리포트 - Security Test App</title>
<style>
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Noto Sans KR', sans-serif;
background: #f5f7fa;
color: #333;
line-height: 1.6;
}
.container {
max-width: 900px;
margin: 0 auto;
padding: 20px;
}
header {
background: linear-gradient(135deg, #1a1a2e 0%, #16213e 100%);
color: white;
padding: 40px 20px;
text-align: center;
margin-bottom: 30px;
}
header h1 {
font-size: 2rem;
margin-bottom: 10px;
}
header p {
opacity: 0.85;
}
.breadcrumb {
margin-bottom: 20px;
font-size: 0.9rem;
}
.breadcrumb a {
color: #667eea;
text-decoration: none;
}
.breadcrumb a:hover {
text-decoration: underline;
}
.card {
background: white;
border-radius: 12px;
padding: 24px;
margin-bottom: 20px;
box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}
.report-list {
list-style: none;
}
.report-item {
border: 1px solid #e0e0e0;
border-radius: 8px;
margin-bottom: 12px;
transition: all 0.2s;
}
.report-item:hover {
border-color: #667eea;
box-shadow: 0 4px 12px rgba(102, 126, 234, 0.15);
}
.report-item a {
display: block;
padding: 16px 20px;
text-decoration: none;
color: inherit;
}
.report-item-header {
display: flex;
justify-content: space-between;
align-items: center;
margin-bottom: 8px;
}
.report-item-title {
font-weight: 600;
color: #1a1a2e;
font-size: 1.1rem;
}
.report-item-date {
font-size: 0.85rem;
color: #666;
}
.report-item-desc {
color: #666;
font-size: 0.9rem;
}
.severity-badge {
display: inline-block;
padding: 2px 8px;
border-radius: 12px;
font-size: 0.75rem;
font-weight: 600;
margin-right: 6px;
}
.critical { background: #dc3545; color: white; }
.high { background: #fd7e14; color: white; }
.medium { background: #ffc107; color: #333; }
footer {
text-align: center;
padding: 20px;
color: #666;
font-size: 0.85rem;
}
</style>
</head>
<body>
<header>
<h1>보안점검 리포트</h1>
<p>Security Test App 모의해킹 결과 보고서</p>
</header>
<div class="container">
<div class="breadcrumb">
<a href="../index.html">Home</a> / 보안점검 리포트
</div>
<div class="card">
<h2 style="margin-bottom: 20px; color: #1a1a2e;">리포트 목록</h2>
<ul class="report-list">
<li class="report-item">
<a href="security_report_2026-01-18.html">
<div class="report-item-header">
<span class="report-item-title">보안 취약점 분석 보고서</span>
<span class="report-item-date">2026-01-18</span>
</div>
<div class="report-item-desc">
<span class="severity-badge critical">Critical 2</span>
<span class="severity-badge high">High 2</span>
<span class="severity-badge medium">Medium 1</span>
블랙박스 모의해킹 테스트 결과 - 5개 취약점 발견
</div>
</a>
</li>
</ul>
</div>
</div>
<footer>
<p>Security Test App - Penetration Testing Reports</p>
</footer>
</body>
</html>
File created successfully at: /Volumes/HDD/Studies/00_gpters/security-test-app/docs/reports/index.html
<!DOCTYPE html>
<html lang="ko">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Security Test App - Documentation Hub</title>
<style>
* { box-sizing: border-box; margin: 0; padding: 0; }
body {
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Noto Sans KR', sans-serif;
background: linear-gradient(135deg, #0f0c29 0%, #302b63 50%, #24243e 100%);
min-height: 100vh;
color: #333;
}
.container {
max-width: 1000px;
margin: 0 auto;
padding: 40px 20px;
}
header {
text-align: center;
color: white;
margin-bottom: 50px;
}
header h1 {
font-size: 2.5rem;
margin-bottom: 12px;
text-shadow: 0 2px 10px rgba(0,0,0,0.3);
}
header p {
font-size: 1.1rem;
opacity: 0.85;
}
.cards {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
gap: 24px;
}
.card {
background: white;
border-radius: 16px;
overflow: hidden;
box-shadow: 0 10px 40px rgba(0,0,0,0.2);
transition: transform 0.3s, box-shadow 0.3s;
}
.card:hover {
transform: translateY(-8px);
box-shadow: 0 20px 60px rgba(0,0,0,0.3);
}
.card a {
display: block;
text-decoration: none;
color: inherit;
}
.card-icon {
height: 120px;
display: flex;
align-items: center;
justify-content: center;
font-size: 3.5rem;
}
.card-app .card-icon {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}
.card-security .card-icon {
background: linear-gradient(135deg, #11998e 0%, #38ef7d 100%);
}
.card-reports .card-icon {
background: linear-gradient(135deg, #eb3349 0%, #f45c43 100%);
}
.card-content {
padding: 24px;
}
.card-content h2 {
font-size: 1.3rem;
margin-bottom: 8px;
color: #1a1a2e;
}
.card-content p {
color: #666;
font-size: 0.95rem;
line-height: 1.5;
margin-bottom: 16px;
}
.card-meta {
display: flex;
gap: 12px;
flex-wrap: wrap;
}
.badge {
display: inline-block;
padding: 4px 10px;
border-radius: 20px;
font-size: 0.75rem;
font-weight: 500;
}
.badge-rails { background: #cc0000; color: white; }
.badge-agent { background: #302b63; color: white; }
.badge-report { background: #dc3545; color: white; }
.badge-count { background: #f0f0f0; color: #333; }
footer {
text-align: center;
color: rgba(255,255,255,0.6);
margin-top: 50px;
font-size: 0.9rem;
}
footer a {
color: rgba(255,255,255,0.8);
}
.project-info {
background: rgba(255,255,255,0.1);
backdrop-filter: blur(10px);
border-radius: 12px;
padding: 20px;
margin-bottom: 40px;
color: white;
}
.project-info h3 {
margin-bottom: 12px;
font-size: 1.1rem;
}
.project-info ul {
list-style: none;
display: flex;
flex-wrap: wrap;
gap: 16px;
}
.project-info li {
display: flex;
align-items: center;
gap: 8px;
font-size: 0.9rem;
opacity: 0.9;
}
</style>
</head>
<body>
<div class="container">
<header>
<h1>Security Test App</h1>
<p>보안 테스트용 웹 애플리케이션 & 화이트해커 Agent 문서</p>
</header>
<div class="project-info">
<h3>프로젝트 개요</h3>
<ul>
<li>Ruby on Rails 7.1</li>
<li>PostgreSQL 15</li>
<li>Docker Compose</li>
<li>행정안전부 개발보안 가이드 기반</li>
</ul>
</div>
<div class="cards">
<!-- App Transcript -->
<div class="card card-app">
<a href="app/index.html">
<div class="card-icon">
<span>💻</span>
</div>
<div class="card-content">
<h2>테스트 앱 개발 Transcript</h2>
<p>보안 테스트용 Ruby on Rails 웹 애플리케이션 개발 과정 기록. 의도적인 취약점이 포함된 회원가입/로그인/회원목록 기능 구현.</p>
<div class="card-meta">
<span class="badge badge-rails">Ruby on Rails</span>
<span class="badge badge-count">13 prompts</span>
<span class="badge badge-count">3 pages</span>
</div>
</div>
</a>
</div>
<!-- Security Checker -->
<div class="card card-security">
<a href="security_checker/index.html">
<div class="card-icon">
<span>🛡</span>
</div>
<div class="card-content">
<h2>화이트해커 Agent 설계</h2>
<p>블랙박스 모의해킹을 수행하는 Claude Code Agent/Skill 설계 문서. 행정안전부 소프트웨어 개발보안 가이드 기반 49개 보안약점 매핑.</p>
<div class="card-meta">
<span class="badge badge-agent">Agent Design</span>
<span class="badge badge-count">7 Skills</span>
<span class="badge badge-count">4 Agents</span>
</div>
</div>
</a>
</div>
<!-- Reports -->
<div class="card card-reports">
<a href="reports/index.html">
<div class="card-icon">
<span>📄</span>
</div>
<div class="card-content">
<h2>보안점검 리포트</h2>
<p>Security Test App 대상 블랙박스 모의해킹 결과 보고서. 취약점 상세 분석, CVSS 점수, 권고 조치사항 포함.</p>
<div class="card-meta">
<span class="badge badge-report">Critical 2</span>
<span class="badge badge-report">High 2</span>
<span class="badge badge-count">5 취약점</span>
</div>
</div>
</a>
</div>
</div>
<footer>
<p>Security Test App Documentation | 2026-01-18</p>
<p><a href="https://github.com">GitHub Repository</a></p>
</footer>
</div>
</body>
</html>
File created successfully at: /Volumes/HDD/Studies/00_gpters/security-test-app/docs/index.html
Hub 페이지를 생성했습니다.
생성된 파일:
docs/index.html - 메인 Hub 페이지docs/reports/index.html - 보안점검 리포트 목록 페이지docs/ 구조:
docs/
├── index.html ← Hub 페이지 (NEW)
├── app/
│ └── index.html → 테스트 앱 Transcript
├── security_checker/
│ └── index.html → 화이트해커 Agent 설계
└── reports/
├── index.html ← 리포트 목록 (NEW)
└── security_report_2026-01-18.html
브라우저에서 확인:
open /Volumes/HDD/Studies/00_gpters/security-test-app/docs/index.html