WordPress에서 마이그레이션

이 페이지

EmDash는 WordPress에서 콘텐츠를 마이그레이션합니다. 관리자 대시보드를 통해 게시물, 페이지, 미디어 및 분류를 가져오세요.

시작하기 전에

콘텐츠 내보내기

WordPress에서 도구 → 내보내기로 이동하여 전체 내보내기 파일(.xml)을 다운로드하세요.

사이트 백업

마이그레이션이 성공했는지 확인할 때까지 WordPress 사이트를 계속 실행하세요.

가져오기 방법

EmDash는 WordPress 콘텐츠를 가져오는 세 가지 방법을 지원합니다:

방법최적 사용처초안 포함인증 필요
WXR 파일 업로드완전한 마이그레이션아니오
WordPress.comWordPress.com 호스팅 사이트OAuth
REST API (프로브)내보내기 전 콘텐츠 확인아니오선택사항

WXR 파일 업로드는 대부분의 마이그레이션에 권장됩니다. 초안, 사용자 정의 필드 및 비공개 게시물을 포함한 모든 콘텐츠를 캡처합니다.

WXR 파일 가져오기

  1. WordPress에서 내보내기

    WordPress 관리자에서 도구 → 내보내기 → 모든 콘텐츠 → 내보내기 파일 다운로드로 이동하세요.

  2. 가져오기 마법사 열기

    EmDash에서 관리자 → 설정 → 가져오기 → WordPress로 이동하세요.

  3. 내보내기 파일 업로드

    .xml 파일을 드래그 앤 드롭하거나 클릭하여 찾아보세요. 파일은 브라우저에서 파싱됩니다.

  4. 감지된 콘텐츠 검토

    마법사가 발견된 내용을 표시합니다:

    Found in export:
    ├── Posts: 127 → posts [New collection]
    ├── Pages: 12  → pages [Add fields]
    └── Media: 89 attachments
  5. 매핑 구성

    가져올 게시물 유형을 토글하세요. EmDash는 자동으로:

    • 매핑되지 않은 게시물 유형에 대한 새 컬렉션 생성
    • 기존 컬렉션에 누락된 필드 추가
    • 필드 유형 충돌에 대해 경고
  6. 가져오기 실행

    콘텐츠 가져오기를 클릭하세요. 각 항목이 처리되면 진행 상황이 표시됩니다.

  7. 미디어 가져오기 (선택사항)

    콘텐츠 가져오기 후 미디어 파일 다운로드 여부를 선택하세요. EmDash는:

    • WordPress URL에서 다운로드
    • 콘텐츠 해시로 중복 제거
    • 콘텐츠의 URL을 자동으로 재작성

콘텐츠 변환

Gutenberg에서 Portable Text로

EmDash는 Gutenberg 블록을 구조화된 콘텐츠 형식인 Portable Text로 변환합니다.

Gutenberg 블록Portable Text참고사항
core/paragraphblock style=“normal”인라인 마크 보존
core/headingblock style=“h1-h6”블록 속성의 레벨
core/imageimage block미디어 참조 업데이트
core/listblock with listItem type순서 있음 및 순서 없음
core/quoteblock style=“blockquote”인용 포함
core/codecode block언어 속성 보존
core/embedembed blockURL 및 제공자 저장
core/gallerygallery block이미지 참조 배열
core/columnscolumns block중첩된 콘텐츠 보존
알 수 없는 블록htmlBlock검토를 위해 원시 HTML 보존

알 수 없는 블록은 원본 HTML 및 블록 메타데이터와 함께 htmlBlock으로 저장됩니다. 수동으로 검토하고 변환하거나 사용자 정의 Portable Text 구성 요소를 만들어 렌더링할 수 있습니다.

클래식 에디터 콘텐츠

클래식 에디터의 HTML은 Portable Text 블록으로 변환됩니다. 인라인 스타일(<strong>, <em>, <a>)은 스팬의 마크가 됩니다.

상태 매핑

WordPress 상태EmDash 상태
publishpublished
draftdraft
pendingpending
privateprivate
futurescheduled
trasharchived

분류 가져오기

카테고리와 태그는 계층 구조가 보존된 분류로 가져옵니다:

WordPress:                    EmDash:
├── Categories (hierarchical) ├── taxonomies table
│   ├── News                  │   ├── category/news
│   │   ├── Local             │   ├── category/local (parent: news)
│   │   └── World             │   ├── category/world (parent: news)
│   └── Sports                │   └── category/sports
└── Tags (flat)               └── content_taxonomies junction
    ├── featured                  ├── tag/featured
    └── breaking                  └── tag/breaking

사용자 정의 필드 및 ACF

WordPress 게시물 메타 및 ACF 필드는 가져오기 중에 분석됩니다:

  1. 분석 단계

    마법사가 사용자 정의 필드를 감지하고 EmDash 필드 유형을 제안합니다:

    Custom Fields:
    ├── subtitle (string, 45 posts)
    ├── _yoast_wpseo_title → seo.title (string, 127 posts)
    ├── _thumbnail_id → featuredImage (reference, 89 posts)
    └── price (number, 23 posts)
  2. 필드 매핑

    내부 WordPress 필드(_edit_, _wp_로 시작)는 기본적으로 숨겨집니다. SEO 플러그인 필드는 seo 객체에 매핑됩니다.

  3. 유형 추론

    EmDash는 값에서 필드 유형을 추론합니다:

    • 숫자 문자열 → number
    • "1", "0", "true", "false"boolean
    • ISO 날짜 → date
    • 직렬화된 PHP/JSON → json
    • WordPress ID (예: _thumbnail_id) → reference

URL 리디렉션

가져오기 후 EmDash는 리디렉션 맵을 생성합니다:

{
	"redirects": [
		{ "from": "/?p=123", "to": "/posts/hello-world" },
		{ "from": "/2024/01/hello-world/", "to": "/posts/hello-world" },
		{ "from": "/category/news/", "to": "/categories/news" }
	],
	"feeds": [
		{ "from": "/feed/", "to": "/rss.xml" },
		{ "from": "/feed/atom/", "to": "/atom.xml" }
	]
}

이 리디렉션을 다음에 적용하세요:

  • Cloudflare 리디렉션 규칙
  • 호스팅 플랫폼의 리디렉션 구성
  • astro.config.mjs의 Astro redirects 옵션

개념 매핑 참조

WordPress 패턴을 EmDash에 적용할 때 이 표를 사용하세요:

WordPressEmDash참고사항
register_post_type()관리자 UI의 컬렉션대시보드 또는 API를 통해 생성
register_taxonomy()분류 또는 배열 필드복잡성에 따라 달라짐
register_meta()컬렉션 스키마의 필드타입 지정, 키-값 아님
WP_QuerygetCollection(filters)런타임 쿼리
get_post()getEntry(collection, id)항목 또는 null 반환
wp_insert_post()POST /_emdash/api/content/{type}REST API
the_content<PortableText value={...} />Portable Text 렌더링
add_shortcode()Portable Text 사용자 정의 블록사용자 정의 구성 요소 렌더러
register_block_type()Portable Text 사용자 정의 블록단축코드와 동일
add_menu_page()플러그인 관리자 페이지/_emdash/admin/ 아래
add_action/filter()플러그인 훅hooks.content:beforeSave
wp_optionsctx.kv키-값 저장소
wp_postmeta컬렉션 필드구조화됨, 키-값 아님
$wpdbctx.storage직접 스토리지 액세스
Categories/Tags분류계층 구조 지원 보존

API 가져오기 (고급)

WordPress 가져오기는 관리자 대시보드 및 REST API를 통해 사용할 수 있습니다. 최상의 경험을 위해 관리자 대시보드 가져오기 마법사를 사용하세요 — 필드 매핑, 충돌 해결 및 진행 상황 추적을 제공합니다.

가져오기 API 엔드포인트는 프로그래밍 방식 액세스를 위해 /_emdash/api/import/wordpress/ 아래에 있습니다.

문제 해결

”XML 파싱 오류”

내보내기 파일이 손상되었거나 불완전할 수 있습니다. WordPress에서 다시 내보내세요.

미디어 다운로드 실패

일부 이미지는 인증 뒤에 있거나 이동되었을 수 있습니다. 가져오기는 계속되며 실패한 URL은 수동 처리를 위해 기록됩니다.

필드 유형 충돌

기존 컬렉션에 호환되지 않는 유형의 필드가 있는 경우 가져오기 마법사가 충돌을 표시합니다. 다음 중 하나를 수행하세요:

  • EmDash 필드 이름 변경
  • WordPress 필드 매핑 변경
  • 컬렉션 삭제 및 재생성

대용량 내보내기

100MB가 넘는 내보내기의 경우 다음을 고려하세요:

  1. WordPress에서 게시물 유형을 별도로 내보내기
  2. 각 파일을 순차적으로 가져오기
  3. 안정성을 위해 CLI에서 --resume 사용

다음 단계