summaryrefslogtreecommitdiff
path: root/pages/api/pdftron
diff options
context:
space:
mode:
authorjoonhoekim <26rote@gmail.com>2025-10-21 18:37:46 +0900
committerjoonhoekim <26rote@gmail.com>2025-10-21 18:37:46 +0900
commit9d0f0304b744f17c2c346ba5a52ee6745a9f51af (patch)
treeeba24f5df071d77af5c88a8879f0f0ad9ff5c26d /pages/api/pdftron
parentcf77558c0ccc5c0c1bc3cdd6edd9a0475e1970c8 (diff)
(김준회) fix: EDP 보고서 관리: 템플릿 파일 못찾는 문제 처리
Diffstat (limited to 'pages/api/pdftron')
-rw-r--r--pages/api/pdftron/createVendorDataReports.ts15
1 files changed, 13 insertions, 2 deletions
diff --git a/pages/api/pdftron/createVendorDataReports.ts b/pages/api/pdftron/createVendorDataReports.ts
index e145b5d5..f873bd50 100644
--- a/pages/api/pdftron/createVendorDataReports.ts
+++ b/pages/api/pdftron/createVendorDataReports.ts
@@ -90,12 +90,23 @@ function validateFileSize(size: number): { valid: boolean; error?: string } {
function validateDirectory(directory: string): { valid: boolean; error?: string } {
const normalizedDir = path.normalize(directory).replace(/^\/+/, '');
+ // 경로 탐색 공격 방지
if (normalizedDir.includes('..') || normalizedDir.includes('//')) {
return { valid: false, error: "안전하지 않은 디렉터리 경로입니다" };
}
- if (path.isAbsolute(directory)) {
- return { valid: false, error: "절대 경로는 사용할 수 없습니다" };
+ // 절대 경로 검증 (단, 허용된 웹 경로 패턴은 제외)
+ const allowedPatterns = [
+ /^\/api\/files\//, // 운영 환경: /api/files/vendorFormData/...
+ /^\/vendorFormData\//, // 개발 환경: /vendorFormData/...
+ /^\/[\w-]+\//, // 기타 상대 웹 경로: /directory/...
+ ];
+
+ const isAllowedWebPath = allowedPatterns.some(pattern => pattern.test(directory));
+
+ // Windows 절대 경로(C:\...) 또는 허용되지 않은 Unix 절대 경로 차단
+ if (path.isAbsolute(directory) && !isAllowedWebPath) {
+ return { valid: false, error: "절대 파일 시스템 경로는 사용할 수 없습니다" };
}
return { valid: true };