실습 설정 안내 및 요구사항
계정과 진행 상황을 보호하세요. 이 실습을 실행하려면 항상 시크릿 브라우저 창과 실습 사용자 인증 정보를 사용하세요.

Apigee X를 사용한 API 개발 및 보호: 챌린지 실습

실습 2시간 30분 universal_currency_alt 크레딧 5개 show_chart 중급
info 이 실습에는 학습을 지원하는 AI 도구가 통합되어 있을 수 있습니다.
이 콘텐츠는 아직 휴대기기에 최적화되지 않음
최상의 경험을 위해 데스크톱 컴퓨터에서 이메일로 전송된 링크를 사용하여 방문하세요.

GSP363

Google Cloud 사용자 주도형 실습 로고

개요

챌린지 실습에서는 특정 시나리오와 일련의 작업이 주어집니다. 단계별 안내를 따르는 대신, 과정의 실습에서 배운 기술을 사용하여 스스로 작업을 완료하는 방법을 알아내 보세요. 이 페이지에 표시되어 있는 자동 채점 시스템에서 작업을 올바르게 완료했는지 피드백을 제공합니다.

챌린지 실습을 진행할 때는 새로운 Google Cloud 개념에 대한 정보가 제공되지 않습니다. 학습한 기술을 응용하여 기본값을 변경하거나 오류 메시지를 읽고 조사하여 실수를 바로잡아야 합니다.

100점을 받으려면 시간 내에 모든 작업을 성공적으로 완료해야 합니다.

이 실습은 Apigee X를 사용한 API 개발 및 보안 과정의 실습을 완료한 학습자에게 권장됩니다. 챌린지에 도전할 준비가 되셨나요?

설정

실습 시작 버튼을 클릭하기 전에

다음 안내를 확인하세요. 실습에는 시간 제한이 있으며 일시중지할 수 없습니다. 실습 시작을 클릭하면 타이머가 시작됩니다. 이 타이머는 Google Cloud 리소스를 사용할 수 있는 시간이 얼마나 남았는지를 표시합니다.

실무형 실습을 통해 시뮬레이션이나 데모 환경이 아닌 실제 클라우드 환경에서 실습 활동을 진행할 수 있습니다. 실습 시간 동안 Google Cloud에 로그인하고 액세스하는 데 사용할 수 있는 새로운 임시 사용자 인증 정보가 제공됩니다.

이 실습을 완료하려면 다음을 준비해야 합니다.

  • 표준 인터넷 브라우저 액세스 권한(Chrome 브라우저 권장)
참고: 이 실습을 실행하려면 시크릿 모드(권장) 또는 시크릿 브라우저 창을 사용하세요. 개인 계정과 학습자 계정 간의 충돌로 개인 계정에 추가 요금이 발생하는 일을 방지해 줍니다.
  • 실습을 완료하기에 충분한 시간(실습을 시작하고 나면 일시중지할 수 없음)
참고: 이 실습에는 학습자 계정만 사용하세요. 다른 Google Cloud 계정을 사용하는 경우 해당 계정에 비용이 청구될 수 있습니다.

챌린지 시나리오

여러분은 전국적인 소매업체인 Cymbal Shops의 클라우드 엔지니어입니다. Cymbal Shop은 글로벌 영업에 주력하고 있으며, 번역 서비스는 글로벌 비즈니스 확장에 도움이 되는 핵심 도구입니다. 여러분은 번역 API의 첫 번째 버전을 만들어야 합니다.

이러한 작업에 필요한 기술과 지식을 보유하고 있어야 하며, 단계별 안내는 제공되지 않습니다.

챌린지

프로젝트의 Apigee 조직에서 새 Apigee API 프록시와 기타 리소스를 만들어야 합니다. 각 작업 설명을 읽고 필요한 기능을 만드세요.

저장 오류

API 프록시의 변경사항을 저장할 때 Could not save new revision 오류가 발생할 수 있습니다. 저장 드롭다운 버튼(저장 드롭다운 버튼)을 사용한 다음 새 버전으로 저장을 선택하면 잘못된 항목을 알려주는 오류 메시지가 표시됩니다.

작업 1. Cloud Translation API 프록시

Cymbal Shops는 Google Cloud의 Translation API를 API 프록시의 백엔드 서비스로 사용하기로 했습니다.

요건

  1. Google Cloud 콘솔API 라이브러리에서 Cloud Translation API가 사용 설정되어 있는지 확인합니다.
  2. apigee-proxy라는 API 프록시의 서비스 계정을 만들고 로깅 > 로그 작성자를 선택하여 로그 작성자 역할을 부여합니다.
  3. Google Cloud 콘솔의 탐색 메뉴에서 Apigee를 선택하여 Apigee UI를 열고 API 프록시를 만듭니다.
  4. API 프록시는 기본 경로가 /translate/v1이며 이름이 translate-v1리버스 프록시여야 합니다.
  5. API 프록시의 타겟은 Cloud Translation API 기본 버전의 HTTP URL(https://translation.googleapis.com/language/translate/v2)입니다.
  6. 프록시 마법사의 일반 정책 페이지를 사용하여 승인, CORS 또는 할당량을 추가해선 안 됩니다.
  7. 요약 페이지에서 설정을 기본값으로 두고 API 프록시를 만듭니다.
  8. 기본 TargetEndpoint인증 섹션을 추가하여 모든 백엔드 요청에 액세스 토큰이 함께 전송되게 합니다. 범위https://www.googleapis.com/auth/cloud-translationGoogleAccessToken 요소를 사용합니다.
참고: 프록시를 수정하고 개발 탭의 대상 엔드포인트 섹션에서 default.xml 파일을 수정합니다.
  1. 다음 Cloud Shell 스크립트를 사용하여 Apigee 런타임이 완전히 설치되었는지 확인합니다.
export INSTANCE_NAME=eval-instance; export ENV_NAME=eval; export PREV_INSTANCE_STATE=; echo "waiting for runtime instance ${INSTANCE_NAME} to be active"; while : ; do export INSTANCE_STATE=$(curl -s -H "Authorization: Bearer $(gcloud auth print-access-token)" -X GET "https://apigee.googleapis.com/v1/organizations/${GOOGLE_CLOUD_PROJECT}/instances/${INSTANCE_NAME}" | jq "select(.state != null) | .state" --raw-output); [[ "${INSTANCE_STATE}" == "${PREV_INSTANCE_STATE}" ]] || (echo; echo "INSTANCE_STATE=${INSTANCE_STATE}"); export PREV_INSTANCE_STATE=${INSTANCE_STATE}; [[ "${INSTANCE_STATE}" != "ACTIVE" ]] || break; echo -n "."; sleep 5; done; echo; echo "instance created, waiting for environment ${ENV_NAME} to be attached to instance"; while : ; do export ATTACHMENT_DONE=$(curl -s -H "Authorization: Bearer $(gcloud auth print-access-token)" -X GET "https://apigee.googleapis.com/v1/organizations/${GOOGLE_CLOUD_PROJECT}/instances/${INSTANCE_NAME}/attachments" | jq "select(.attachments != null) | .attachments[] | select(.environment == \"${ENV_NAME}\") | .environment" --join-output); [[ "${ATTACHMENT_DONE}" != "${ENV_NAME}" ]] || break; echo -n "."; sleep 5; done; echo "***ORG IS READY TO USE***";

스크립트에서 ORG IS READY TO USE를 반환하면 다음 단계를 진행해도 됩니다.

참고: 런타임이 설치되기를 기다리는 동안 내용을 미리 읽어 작업 2의 진행을 계획해도 됩니다.
  1. 다음 서비스 계정을 사용하여 translate-v1 프록시를 eval 환경에 저장하고 배포합니다.
apigee-proxy@{{{ project_0.project_id | PROJECT }}}.iam.gserviceaccount.com
  1. API 프록시를 테스트합니다.

Apigee 조직의 eval 환경은 호스트 이름 eval.example.com을 사용하여 호출할 수 있습니다. 이 DNS 항목은 내부 네트워크에서만 사용할 수 있으므로 여러분을 위해 생성된 VM을 사용해야 합니다.

  1. Cloud Shell에서 apigeex-test-vm에 대한 SSH 연결을 엽니다.
TEST_VM_ZONE=$(gcloud compute instances list --filter="name=('apigeex-test-vm')" --format "value(zone)") gcloud compute ssh apigeex-test-vm --zone=${TEST_VM_ZONE} --force-key-file-overwrite
  1. 승인을 요청하는 메시지가 나타나면 승인을 클릭합니다. gcloud 명령어에서 묻는 각 질문에 대해 Enter 또는 Return을 클릭하여 기본 입력을 지정합니다.

  2. 작업 1을 완료하면 다음 curl 명령어로 텍스트를 번역할 수 있습니다.

curl -i -k -X POST "https://eval.example.com/translate/v1" -H "Content-Type: application/json" -d '{ "q": "Translate this text!", "target": "es" }'

응답은 다음과 유사합니다.

{ "data": { "translations": [ { "translatedText": "¡Traduce este texto!", "detectedSourceLanguage": "en" } ] } } 참고: API 프록시가 완전히 배포될 때까지 몇 분 동안 502 오류 응답이 수신될 수 있습니다.

내 진행 상황 확인하기를 클릭하여 목표를 확인합니다. Cloud Translation API 프록시

참고: 녹색 체크표시가 표시되지 않는 경우 오른쪽 상단에서 펼쳐지는 점수 메뉴를 클릭한 후 해당하는 단계에서 내 진행 상황 확인하기를 클릭하세요. 팝업 상자에 도움말이 표시됩니다.

작업 2. API 요청 및 응답 변경

Cymbal Shops는 Translation API에서 제공하는 인터페이스와 다른 API를 만들고 싶어 합니다. Translation API 호출 두 개를 수정해야 합니다.

첫 번째 호출은 유효한 언어 목록을 가져옵니다.

Cloud Translation API 요청

REQUEST: POST https://translation.googleapis.com/language/translate/v2/languages Authorization: Bearer ACCESSTOKEN Content-Type: application/json { "target": "en" }

Cloud Translation API 응답

Content-Type: application/json { "data": { "languages": [ { "language": "af", "name": "Afrikaans" }, { "language": "sq", "name": "Albanian" }, ... ] } }

translate-v1 요청

GET https://eval.example.com/translate/v1/languages

translate-v1 응답

Content-Type: application/json [{"language":"af","name":"Afrikaans"},{"language":"sq","name":"Albanian"}, ... ]

API 프록시는 GET을 POST로 바꾸고 datalanguages 응답 필드를 삭제하며 속성 세트에서 도착어 코드를 가져와야 합니다. 액세스 토큰은 작업 1의 인증 섹션에서 자동으로 추가되었습니다.

두 번째 호출은 텍스트를 지정된 언어로 번역합니다.

Cloud Translate API 요청

POST https://translation.googleapis.com/language/translate/v2 Authorization: Bearer ACCESSTOKEN Content-Type: application/json { "q": "Hello world!", "target": "de" }

Cloud Translate API 응답

Content-Type: application/json { "data": { "translations": [ { "translatedText": "Hallo Welt!", "detectedSourceLanguage": "en" } ] } }

translate-v1 요청

POST https://eval.example.com/translate/v1?lang=de Content-Type: application/json { "text": "Hello world!" }

translate-v1 응답

Content-Type: application/json { "translated": "Hallo Welt!" }

API 프록시는 lang 쿼리 파라미터에서 도착어를 가져와 수신 및 번역된 텍스트의 필드 이름을 변경해야 합니다. lang 쿼리 파라미터는 translate-v1 요청에서 선택적으로 생략할 수 있으며, 이 경우 도착어는 속성 세트의 속성에서 가져옵니다.

참고: Translation API는 'q' 필드에 단일 문자열 또는 문자열 배열을 허용합니다. 내 API는 단일 문자열만 지원해야 합니다.

요건

  1. API 프록시 내에서 language.properties라는 속성 세트를 만듭니다. 속성 세트에는 값이 esoutput과 값이 encaller라는 두 가지 속성이 있어야 합니다. caller 속성은 언어를 나열할 때 도착어(name 필드에 사용하는 언어)를 지정하는 데 사용됩니다. outputlang 쿼리 파라미터가 제공되지 않는 경우 사용할 기본 도착어를 지정합니다.

  2. 프록시 엔드포인트에서 POST / 리소스의 경로 및 동사 조건부 흐름을 만듭니다. 이름을 translate로 지정합니다.

  3. 프록시 엔드포인트에서 /languages 리소스의 경로(동사 없음) 조건부 흐름을 만듭니다. 이름을 getLanguages로 지정합니다. 동사는 포함하지 마세요. 나중에 요청의 동사를 GET(프록시 입력용)에서 POST(백엔드에 필요)로 수정해야 합니다. 조건에 동사를 포함하면 request.verb가 더 이상 GET과 같지 않으므로 흐름의 응답 정책이 실행되지 않습니다.

  4. AM-BuildTranslateRequest라는 AssignMessage 정책을 만들어 translate 조건부 흐름에 사용되는 백엔드 요청을 만듭니다.

정책은 다음과 같이 설정해야 합니다.

  • 나중에 로깅된 메시지에서 사용할 변수를 만드는 템플릿이 있는 AssignVariable을 포함해야 합니다. text라는 변수는 jsonPath 메시지 템플릿 함수를 사용하여 요청에서 text 필드를 추출해야 합니다.

  • language라는 변수는 firstnonnull 메시지 템플릿 함수를 사용하여 만들어야 합니다. 이 변수는 lang 쿼리 파라미터값이 있는 경우 이를 포함해야 하며, lang 쿼리 파라미터가 지정되지 않은 경우에는 도착어에 대한 언어 속성 세트의 output 속성을 포함해야 합니다.

  • Set 섹션은 백엔드 서비스에 필요한 JSON 페이로드를 설정하는 데 사용해야 합니다. 생성한 두 변수는 모두 페이로드에 사용됩니다.

  • [AssignTo] 요소는 기존 요청 메시지를 사용해야 합니다.

    AssignMessage 정책의 AssignVariable 섹션은 다음과 유사합니다.

    <AssignVariable> <Name>...</Name> <Template>...</Template> <AssignVariable>
  1. translate 조건부 흐름에 AM-BuildTranslateResponse라는 AssignMessage 정책을 만들어 Translation API 응답을 사용하여 호출자의 응답을 만듭니다.

정책은 다음과 같이 설정해야 합니다.

  • translated라는 변수를 만들어 Translation API 응답에서 translatedText 필드를 추출하는 jsonPath 템플릿이 있는 AssignVariable를 포함해야 합니다. 힌트: 이 필드를 추출하는 JSONPath 표현식은 $.data.translations[0].translatedText입니다.

  • createNew를 참으로 설정합니다.

  • 새 JSON 페이로드는 translated 변수를 사용합니다.

    AssignMessage 정책의 AssignVariable 섹션은 다음과 유사합니다.

    <AssignVariable> <Name>...</Name> <Template>...</Template> <AssignVariable>
  1. AM-BuildLanguagesRequest라는 AssignMessage 정책을 만들어 getLanguages 조건부 흐름에 사용되는 백엔드 요청을 만듭니다.

정책은 다음과 같이 설정해야 합니다.

  • Set를 사용하여 백엔드 요청에 올바른 동사와 페이로드를 설정합니다.

  • language 속성 세트의 caller 속성은 백엔드 페이로드의 target 필드에 사용해야 합니다.

  • createNew를 참으로 설정합니다.

  • 콘텐츠 유형이 application/json이 되도록 백엔드 요청 페이로드를 설정합니다.

    AssignMessage 정책의 AssignVariable 섹션은 다음과 유사합니다.

    <AssignVariable> <Name>...</Name> <Set> ... </Set> </AssignVariable>
  1. getLanguages 조건부 흐름에 JS-BuildLanguagesResponse라는 JavaScript 정책을 만들어 호출자의 응답을 만듭니다. JavaScript 코드의 경우 다음 단계를 따라야 합니다.
  • context.getVariable을 사용하여 response.content 변수를 가져옵니다.
  • JSON.parse를 사용하여 response.content JSON을 객체로 변환합니다.
  • JSON.stringify를 사용하여 객체의 data.languages 필드를 JSON으로 변환합니다.
  • context.setVariable을 사용하여 response.content를 3단계의 JSON으로 바꿉니다.

JavaScript 코드는 다음과 비슷하게 표시됩니다.

var payload = ...; var payloadObj = JSON.parse(...); var newPayload = JSON.stringify(...); context.setVariable(...); 참고: 올바른 조건부 흐름에서 원하는 정책을 만들고 해당 .xml 파일에서 정책 구성을 수정해야 합니다.
  1. API를 테스트합니다. apigeex-test-vm 가상 머신에서 다음 curl 명령어를 사용하여 위에 표시된 예시를 테스트합니다.
  • 언어 목록

    curl -i -k -X GET "https://eval.example.com/translate/v1/languages"
  • 지정된 언어(독일어)로 번역

    curl -i -k -X POST "https://eval.example.com/translate/v1?lang=de" -H "Content-Type:application/json" -d '{ "text": "Hello world!" }'
  • 기본 언어(스페인어)로 번역

    curl -i -k -X POST "https://eval.example.com/translate/v1" -H "Content-Type:application/json" -d '{ "text": "Hello world!" }'

내 진행 상황 확인하기를 클릭하여 목표를 확인합니다. API 요청 및 응답 변경

참고: 녹색 체크표시가 표시되지 않는 경우 오른쪽 상단에서 펼쳐지는 점수 메뉴를 클릭한 후 해당하는 단계에서 내 진행 상황 확인하기를 클릭하세요. 팝업 상자에 도움말이 표시됩니다.

작업 3. API 키 확인 및 할당량 적용 추가

이 API에 대한 액세스는 승인된 애플리케이션으로 제한해야 하므로, 요청 수를 제한하는 할당량 정책을 VerifyAPI 키 정책과 함께 추가합니다.

요건

  1. 이름과 표시 이름이 translate-productAPI 제품을 만듭니다. 이 API 제품은 공개 액세스 권한이 있어야 하고, 액세스 요청을 자동으로 승인해야 하며, eval 환경에서 사용할 수 있어야 합니다.

  2. translate-product API 제품에 작업을 추가합니다. 작업은 translate-v1 프록시에 대한 액세스를 허용하고 / 경로를 사용해야 합니다. 이 경로는 /를 포함한 모든 요청에 대한 액세스를 허용합니다. 허용되는 메서드는 GETPOST입니다. 1분당 요청을 10회로 제한하는 작업 할당량 설정을 추가합니다.

  3. 이메일이 joe@example.com인 개발자를 만듭니다. 이름, 성, 사용자 이름은 원하는 대로 선택합니다.

  4. translate-app이라는 앱을 만들고 해당 앱에 대해 translate-product API 제품을 사용 설정합니다. 나중에 joe@example.com 개발자와 연결해야 합니다.

  5. VA-VerifyKey라는 VerifyAPIKey 정책을 프록시 엔드포인트 PreFlow에 추가합니다. API 키는 모든 요청에 필요하며 Key 헤더를 사용하여 전송해야 합니다.

  6. Q-EnforceQuota라는 할당량 정책을 프록시 엔드포인트 PreFlow에 추가합니다.

정책에는 다음 단계가 포함되어야 합니다.

  • calendar 유형을 사용합니다. calendar 유형에는 StartTime 요소가 필요합니다.
  • UseQuotaConfigInAPIProduct를 지정하여 API 제품에서 할당량 설정을 지정하지 않는 경우 기본 할당량이 시간당 요청 5회인 API 제품 할당량을 사용합니다.
  • DistributedSynchronous를 참으로 설정하고 AsynchronousConfiguration 요소를 삭제합니다.

이러한 변경사항이 적용되면 Key 헤더에 유효한 API 키가 지정되지 않은 경우 요청에서 오류가 반환됩니다.

  1. apigeex-test-vm 가상 머신에서 다음 curl 명령어를 사용하여 API 키 기능을 테스트합니다.
  • 실패(API 키 없음)

    curl -i -k -X POST "https://eval.example.com/translate/v1?lang=de" -H "Content-Type:application/json" -d '{ "text": "Hello world!" }'
  • 실패(잘못된 API 키)

    curl -i -k -X POST "https://eval.example.com/translate/v1?lang=de" -H "Content-Type:application/json" -H "Key: ABC123" -d '{ "text": "Hello world!" }'
  • 성공(KEY 변수가 유효한 API 키로 설정된 경우 KEY=<get this from the earlier step when setting up a Developer App>)

    curl -i -k -X POST "https://eval.example.com/translate/v1?lang=de" -H "Content-Type:application/json" -H "Key: $KEY" -d '{ "text": "Hello world!" }'

내 진행 상황 확인하기를 클릭하여 목표를 확인합니다. API 키 확인 및 할당량 적용 추가

참고: 녹색 체크표시가 표시되지 않는 경우 오른쪽 상단에서 펼쳐지는 점수 메뉴를 클릭한 후 해당하는 단계에서 내 진행 상황 확인하기를 클릭하세요. 팝업 상자에 도움말이 표시됩니다.

작업 4. 메시지 로깅 추가

번역 서비스가 사용되는 방식을 파악하기 위해 MessageLogging 정책이 번역된 모든 메시지를 로깅합니다.

요건

  1. translate 조건부 흐름에 ML-LogTranslation이라는 MessageLogging 정책을 추가합니다. 정책은 AM-BuildTranslateResponse 단계 후에 실행되어야 합니다.
참고: PostClientFlow에 추가해선 안 됩니다. 로그는 번역 작업에 대해서만 생성되기 때문입니다.
  1. 정책은 Cloud Logging에 로깅되어야 됩니다. 이 정책 문서를 참고하세요.
  • LogName 값은 다음과 같아야 합니다.

    projects/{organization.name}/logs/translate
  • 로깅된 메시지의 contentTypetext/plain이며 메시지 콘텐츠는 다음과 같아야 합니다.

    {language}|{text}|{translated}

이 메시지에는 AM-BuildTranslateRequestAM-BuildTranslateResponse 정책에서 생성된 language, text, translated 변수가 필요합니다.

  1. 로깅된 메시지를 Google Cloud 콘솔의 Logging 페이지에서 검증합니다. 번역된 로그만 표시되도록 logName : "translate" 쿼리를 사용합니다.

  2. MessageLogging 정책이 성공적으로 추가되면 다음 curl 명령어를 사용합니다.

curl -i -k -X POST "https://eval.example.com/translate/v1?lang=de" -H "Content-Type:application/json" -H "Key: $KEY" -d '{ "text": "Hello world!" }'
  • 이 curl 명령어는 다음 콘텐츠가 포함된 로그 메시지를 생성해야 합니다.

    de|Hello world!|Hallo Welt!
참고: 로깅된 메시지가 로그에 표시될 때 약간의 지연이 발생합니다.

내 진행 상황 확인하기를 클릭하여 목표를 확인합니다. 메시지 로깅 추가

참고: 녹색 체크표시가 표시되지 않는 경우 오른쪽 상단에서 펼쳐지는 점수 메뉴를 클릭한 후 해당하는 단계에서 내 진행 상황 확인하기를 클릭하세요. 팝업 상자에 도움말이 표시됩니다.

작업 5. 백엔드 오류 메시지 다시 작성

Translation API에 전송된 target 파라미터가 유효하지 않으면 400 잘못된 요청 오류 메시지가 반환됩니다.

{ "error": { "code": 400, "message": "Invalid Value", "errors": [ { "message": "Invalid Value", "domain": "global", "reason": "invalid" } ] } }

이 오류 메시지는 호출자에 혼란을 줄 수 있으므로 오류 메시지를 다시 작성합니다.

요건

  1. default 대상 엔드포인트에 FaultRules 섹션을 추가합니다. 백엔드에서 400 응답을 반환하면 해당 응답이 대상 엔드포인트에서 일치하는 오류 규칙을 자동으로 평가합니다.
참고: 왼쪽의 UI 탐색기 메뉴를 사용하여 FaultRules 섹션을 추가할 수는 없습니다. 대상 엔드포인트의 XML 구성에 추가해야 합니다.
  1. FaultRules 섹션에 FaultRule을 추가합니다. 이 FaultRule의 Conditionfault.nameErrorResponseCode인 경우 실행되도록 설정해야 합니다.

  2. AM-BuildErrorResponse라는 AssignMessage 정책을 만들고 FaultRule에 연결합니다. 다음 정책 구성을 사용합니다.

<AssignMessage name="AM-BuildErrorResponse"> <Set> <Payload contentType="application/json">{ "error": "Invalid request. Verify the lang query parameter." }</Payload> </Set> </AssignMessage>

정책이 연결되면 대상 엔드포인트의 FaultRules 섹션이 다음과 같이 표시됩니다.

<FaultRules> <FaultRule name="..."> <Step> <Name>...</Name> </Step> <Condition>...</Condition> </FaultRule> </FaultRules> 참고: 대상 엔드포인트 XML을 수동으로 수정해야 합니다(ProxyEndpoint가 아닌 TargetEndpoint인지 확인).
  1. API를 테스트합니다.
  • 다음과 같은 유효한 요청은 여전히 작동해야 합니다.

    curl -i -k -X POST "https://eval.example.com/translate/v1?lang=de" -H "Content-Type:application/json" -H "Key: $KEY" -d '{ "text": "Hello world!" }'
  • 다음과 같이 언어 쿼리 파라미터가 잘못된 경우 다시 작성된 오류 메시지가 반환됩니다.

    curl -i -k -X POST "https://eval.example.com/translate/v1?lang=invalid" -H "Content-Type:application/json" -H "Key: $KEY" -d '{ "text": "Hello world!" }'

내 진행 상황 확인하기를 클릭하여 목표를 확인합니다. 백엔드 오류 메시지 다시 작성

참고: 녹색 체크표시가 표시되지 않는 경우 오른쪽 상단에서 펼쳐지는 점수 메뉴를 클릭한 후 해당하는 단계에서 내 진행 상황 확인하기를 클릭하세요. 팝업 상자에 도움말이 표시됩니다.

수고하셨습니다

이 챌린지 실습을 통해 Apigee X API 개발 및 보안에 대한 여러분의 지식을 확인했습니다.

Apigee X를 사용한 API 개발 및 보호 배지

다음 기술 배지 획득

이 사용자 주도형 실습은 Apigee X를 사용한 API 개발 및 보호 퀘스트의 일부입니다. 이 기술 배지 퀘스트를 완료하면 위의 배지를 획득하여 수료를 인증할 수 있습니다. 이력서 및 소셜 미디어 플랫폼에 배지를 공유하고 #GoogleCloudBadge 해시태그를 사용해 스스로 달성한 업적을 널리 알리세요.

이 기술 배지 퀘스트는 Google Cloud의 API 개발자 학습 과정의 일부입니다. Apigee X 배포 및 관리하기 퀘스트에 등록하여 학습 여정을 계속하세요.

Google Cloud 교육 및 자격증

Google Cloud 기술을 최대한 활용하는 데 도움이 됩니다. Google 강의에는 빠른 습득과 지속적인 학습을 지원하는 기술적인 지식과 권장사항이 포함되어 있습니다. 기초에서 고급까지 수준별 학습을 제공하며 바쁜 일정에 알맞은 주문형, 실시간, 가상 옵션이 포함되어 있습니다. 인증은 Google Cloud 기술에 대한 역량과 전문성을 검증하고 입증하는 데 도움이 됩니다.

설명서 최종 업데이트: 2024년 7월 10일

실습 최종 테스트: 2024년 7월 10일

Copyright 2025 Google LLC. All rights reserved. Google 및 Google 로고는 Google LLC의 상표입니다. 기타 모든 회사명 및 제품명은 해당 업체의 상표일 수 있습니다.

시작하기 전에

  1. 실습에서는 정해진 기간 동안 Google Cloud 프로젝트와 리소스를 만듭니다.
  2. 실습에는 시간 제한이 있으며 일시중지 기능이 없습니다. 실습을 종료하면 처음부터 다시 시작해야 합니다.
  3. 화면 왼쪽 상단에서 실습 시작을 클릭하여 시작합니다.

시크릿 브라우징 사용

  1. 실습에 입력한 사용자 이름비밀번호를 복사합니다.
  2. 비공개 모드에서 콘솔 열기를 클릭합니다.

콘솔에 로그인

    실습 사용자 인증 정보를 사용하여
  1. 로그인합니다. 다른 사용자 인증 정보를 사용하면 오류가 발생하거나 요금이 부과될 수 있습니다.
  2. 약관에 동의하고 리소스 복구 페이지를 건너뜁니다.
  3. 실습을 완료했거나 다시 시작하려고 하는 경우가 아니면 실습 종료를 클릭하지 마세요. 이 버튼을 클릭하면 작업 내용이 지워지고 프로젝트가 삭제됩니다.

현재 이 콘텐츠를 이용할 수 없습니다

이용할 수 있게 되면 이메일로 알려드리겠습니다.

감사합니다

이용할 수 있게 되면 이메일로 알려드리겠습니다.

한 번에 실습 1개만 가능

모든 기존 실습을 종료하고 이 실습을 시작할지 확인하세요.

시크릿 브라우징을 사용하여 실습 실행하기

이 실습을 실행하려면 시크릿 모드 또는 시크릿 브라우저 창을 사용하세요. 개인 계정과 학생 계정 간의 충돌로 개인 계정에 추가 요금이 발생하는 일을 방지해 줍니다.