カテゴリー
Google Maps API (旧Google Ajax API) からクライアント位置情報を取得する
※ 当ページには【広告/PR】を含む場合があります。
2019/12/17
Google Maps APIs
Google AJAX APIs
Google Maps API
誰でもどこでも使える
事前登録アリ
ともあれAPI KeyなしでAPIを叩いてみる
「今でもAPI Keyなし、事前登録なしで使える」
もうAPI Keyなしじゃ全然動かないよ
index.html
head
...
<head>
<!-- Global tag: (google) - Ex Google Ajax Api -->
<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<script type="text/javascript">
const initializeMap = () => {
const geocoder = new google.maps.Geocoder();
if(google.loader.ClientLocation) {
const latlng = new google.maps.LatLng(
google.loader.ClientLocation.latitude,
google.loader.ClientLocation.longitude
);
geocoder.geocode({'latitude_longitude': latlng}, (results, status) => {
if(status == google.maps.GeocoderStatus.OK) {
alert(results[0]['formatted_address']);
};
});
}
}
google.load("maps", "3", {
other_params: "sensor=false",
callback: initializeMap
});
</script>
https://www.google.com/jsapi
google.loader.ClientLocation
latitude
longitude
検証
data:image/s3,"s3://crabby-images/a29ff/a29ff3eed0b8693d096c8e2946f69141184f9071" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
NoApiKeys
ApiProjectMapError:
Either the provided API key or the API project with which it is associated, could not be resolved.
This error may be temporary.
If this error message persists you may need to get a new API key or create a new API project.
For more information, see Get Started with Google Maps Platform.
API Key
関連付けされたAPIプロジェクト
API Keyの取得
data:image/s3,"s3://crabby-images/23a20/23a207ecaff6c7179dfe737d699c099b52234a8a" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
APIプロジェクトの作成
data:image/s3,"s3://crabby-images/f83b1/f83b121ae12db6ff83c40b8f631ba655a7402805" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
data:image/s3,"s3://crabby-images/72a76/72a76f939e2d311fca51de11f838c9cd72628f60" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
APIとサービス > ダッシュボード
data:image/s3,"s3://crabby-images/abf70/abf7003ca70f43c64dae4e93cff60fd0fb3807d0" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
APIの有効化
data:image/s3,"s3://crabby-images/2eec7/2eec79c81792fdfd777b97e1902425ac46c16746" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
Maps Javascrtip API
data:image/s3,"s3://crabby-images/0720b/0720b109d4c4457de263354677b71eba2b66ad12" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
data:image/s3,"s3://crabby-images/2a28b/2a28b256ae6d10836e69594b40735e7d195db6e2" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
API Keyの作成
APIとサービス > 認証情報
API Key
data:image/s3,"s3://crabby-images/652f5/652f526b3a68cedd5cc6c8e1b7b4a584897f6800" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
data:image/s3,"s3://crabby-images/1aaf2/1aaf22d685765d394ae37b2ef481b7578838fd11" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
API Keyの保護
APIとサービス > ダッシュボード
Maps JavaScript API
Maps
認証
API Key
data:image/s3,"s3://crabby-images/1f528/1f528b757521e4857deba91abb6a7cb4d9089033" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
リファラの設定
data:image/s3,"s3://crabby-images/334ae/334ae930eb46ed8b028b474c91e7423a8dd4c426" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
Zone Apex(wwwとかを含まないドメイン名)
ターゲットAPIの設定
Maps Javascript API
data:image/s3,"s3://crabby-images/71a7b/71a7bba8a006af3a64e37b791b8b1ab3f902d58c" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
再度検証
API Key
index.html
head
...
<head>
<!-- Global tag: (google) - Ex Google Ajax Api -->
<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<script type="text/javascript">
const initializeMap = () => {
const geocoder = new google.maps.Geocoder();
if(google.loader.ClientLocation) {
const latlng = new google.maps.LatLng(
google.loader.ClientLocation.latitude,
google.loader.ClientLocation.longitude
);
geocoder.geocode({'latitude_longitude': latlng}, (results, status) => {
if(status == google.maps.GeocoderStatus.OK) {
alert(results[0]['formatted_address']);
};
});
}
}
google.load("maps", "3", {
'other_params': 'key=xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx', // Your API Key
});
google.setOnLoadCallback(initializeMap);
</script>
google.load
other_parames
key
data:image/s3,"s3://crabby-images/8e4c2/8e4c2118ffd388290a29e9082893887ca5f83f84" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
google.loader.ClientLocation
data:image/s3,"s3://crabby-images/ed5b6/ed5b6d3d10c72463abb28b7da28c805b0e8dc4dc" alt="合同会社タコスキングダム|蛸壺の技術ブログ"
google.loader.ClientLocation
GeoIP
まとめ
Google Maps Api
GeoIP
記事を書いた人
ナンデモ系エンジニア
主にAngularでフロントエンド開発することが多いです。 開発環境はLinuxメインで進めているので、シェルコマンドも多用しております。 コツコツとプログラミングするのが好きな人間です。
カテゴリー