적응형 Forms에서 Geolocation API 사용

마지막 업데이트: 2023-05-20
  • 작성 대상:
  • Experienced
    Developer

이 문서에서는 Google의 지리적 위치 API를 사용하여 적응형 양식의 필드를 채우는 방법에 대해 살펴봅니다. 이 사용 사례는 일반적으로 양식의 현재 주소 필드를 채울 때 사용됩니다.

적응형 Forms에서 지리적 위치 API를 사용하려면 다음 단계를 따르십시오.

  1. API 키 가져오기 Google에서 Google 지도 플랫폼을 사용합니다. 1년 동안 사용할 수 있는 평가판 키를 얻을 수 있습니다.

  2. 현재 주소를 저장할 필드가 있는 적응형 양식 조각을 만들었습니다.

  3. 지리적 위치 API는 적응형 양식의 이미지 개체 클릭 이벤트에서 호출되었습니다

  4. API 호출에서 반환된 JSON 데이터를 구문 분석하고 이에 따라 적응형 양식 필드 값을 설정했습니다.

navigator.geolocation.getCurrentPosition(showPosition);
function showPosition(position)
{
console.log(" I am inside the showPosition in fragment");
console.log("Latitude: " + position.coords.latitude + "Longitude " + position.coords.longitude);
var url = "https://maps.googleapis.com/maps/api/geocode/json?latlng="+position.coords.latitude+","+position.coords.longitude+"&key=<your_api_key>";
  console.log(url);

  $.getJSON(url,function (data, textStatus){

    var location=data.results[0].formatted_address;
    console.log(location);

    for(i=0;i<data.results[0].address_components.length;i++)
        {
          if(data.results[0].address_components[i].types[0] == "street_number")
            {
              streetNumber.value = data.results[0].address_components[i].long_name;
            }
          if(data.results[0].address_components[i].types[0] == "route")
            {
              streetName.value = data.results[0].address_components[i].long_name;
            }
            if(data.results[0].address_components[i].types[0] == "postal_code")
            {

              zipCode.value = data.results[0].address_components[i].long_name;
            }
            if(data.results[0].address_components[i].types[0] == "locality")
            {

              city.value = data.results[0].address_components[i].long_name;
            }
          if(data.results[0].address_components[i].types[0] == "administrative_area_level_1")
            {

              state.value = data.results[0].address_components[i].long_name;
            }
        }

  });
}

geoloaction api로 필드 채우기

1행에서는 현재 위치를 가져오는 데 사용되는 지리적 위치 API HTML을 사용합니다. 현재 위치가 얻어지면 현재 위치를 showPosition 함수로 전달합니다.

showPosition 함수에서 Google API를 사용하여 주어진 위도와 경도에 대한 주소 세부 정보를 가져옵니다.

그런 다음 API에서 반환된 JSON을 구문 분석하여 적응형 양식 필드를 설정합니다.

노트

테스트 목적으로 URL에서 localhost와 함께 HTTP 프로토콜을 사용할 수 있습니다.

프로덕션 서버의 경우 이 기능을 사용하려면 AEM 서버에 SSL을 활성화해야 합니다.

이 문서와 관련된 샘플은 미국 주소로 테스트되었습니다. 다른 지리적 위치에서 이 기능을 사용하려면 JSON 구문 분석을 조정해야 할 수 있습니다.

서버에 이 기능을 사용하려면 다음 단계를 따르십시오

  • AEM Forms 서버를 설치하고 시작합니다.

!![NOTE] 이 기능은 AEM Forms 6.3 이상에서 테스트되었습니다

이 페이지의