<目次>
(1) LinkedIn APIの使い方について(PythonでAPIコール疎通させるまで)
(1-1) STEP1:【任意】企業・団体ページの作成
(1-2) STEP2:Appの作成
(1-3) STEP3:AppのVerify
(1-4) STEP4:Appの「Auth」タブの確認/設定
(1-5) STEP5:Appの「Products」タブの確認/設定
(1-6) STEP6:認証コードの取得(Python)
(1-7) STEP7:API疎通チェック(Python)
(1) LinkedIn APIの使い方について(PythonでAPIコール疎通させるまで)
LinkedIn APIの使い方という事で、Python言語でAPIコールを疎通させるまでに必要なステップをご紹介します。
(1-1) STEP1:【任意】企業・団体ページの作成
data:image/s3,"s3://crabby-images/a491c/a491c9fecf4fb2a940583b42772b5ec24244aa94" alt=""
data:image/s3,"s3://crabby-images/7ea2d/7ea2d80de54f0aa383d21363df4b555e2a8d20e5" alt=""
data:image/s3,"s3://crabby-images/70bde/70bde8218db1a76d0e0e50d2891b340fce64e0e5" alt=""
data:image/s3,"s3://crabby-images/28472/28472c365507d49ceec957a5e7bdc42e71d3a692" alt=""
(1-2) STEP2:Appの作成
data:image/s3,"s3://crabby-images/31058/310584379f1878c63f036415092d0d1de9fe9335" alt=""
data:image/s3,"s3://crabby-images/33620/3362015e30ae0e981991be6f893cc4feb6dbc8de" alt=""
data:image/s3,"s3://crabby-images/a685b/a685beed82e1fcb7acbca9986f50a347c9129c17" alt=""
data:image/s3,"s3://crabby-images/b4ac2/b4ac2ac56038e5aef4d6baf58fea896f7dcdcc7c" alt=""
data:image/s3,"s3://crabby-images/5d486/5d48641edc65380173fb840ab5918642f7c80f09" alt=""
(1-3) STEP3:AppのVerify
data:image/s3,"s3://crabby-images/a48ce/a48ce8e912996edd268fb5ef4e708814182018b1" alt=""
data:image/s3,"s3://crabby-images/74614/7461424b510c757d5d419d40a37d66eb8ba0bb5f" alt=""
data:image/s3,"s3://crabby-images/c3156/c3156834c056247e04fad856c80d269a82ce5d5b" alt=""
data:image/s3,"s3://crabby-images/13d5f/13d5fe411b7afd9a1d1fe61efef6b56f8a70877f" alt=""
↓
data:image/s3,"s3://crabby-images/cfe7f/cfe7f602f0e202d7d50f69ce0cff68517fdf2e09" alt=""
data:image/s3,"s3://crabby-images/b6a33/b6a333f175ee87e90b46c3fcfb1d79de04a7c7a9" alt=""
↓
data:image/s3,"s3://crabby-images/19b70/19b70e5e859dd083b0bf6280d9401d2cd6d6dcc0" alt=""
(1-5) STEP5:Appの「Products」タブの確認/設定
data:image/s3,"s3://crabby-images/8f2f2/8f2f2a42f8295d73f74e530043ca87e1f92707d1" alt=""
data:image/s3,"s3://crabby-images/73b65/73b650d53a787e39ed88d89975d3ea25452537b6" alt=""
data:image/s3,"s3://crabby-images/383f0/383f0f35b7adf675a2c084e5dbe61e83ecc82150" alt=""
data:image/s3,"s3://crabby-images/2aa98/2aa9845333794af6fe314df87962f80d42650f58" alt=""
data:image/s3,"s3://crabby-images/d272d/d272d50f9769e6839e5ac563cdca6e815a4c779f" alt=""
(1-6) STEP6:認証コードの取得(Python)
●STEP6-1:コード(code)の取得
data:image/s3,"s3://crabby-images/867c5/867c51a76758b94d289bf641f30682ab13d1cb05" alt=""
(サンプルプログラム)
# 必要なパッケージ: python -m pip install requests import requests, secrets url = requests.Request( 'GET', 'https://www.linkedin.com/oauth/v2/authorization', params = { 'response_type': 'code', # Always should equal to fixed string "code" # ご自身のAppのClientID 'client_id': 'XXXXXX', # ログインしたユーザーが認証後にリダイレクトされるURIを指定 # (備考) # ・この値は「OAuth 2.0 Authorized Redirect URLs」の値のいずれかと一致する必要あり # ・ご自身で所有するローカルやリモートのサーバ等を指定します。 'redirect_uri': 'http://localhost:8000', # 一意なランダム文字列を指定。 # サーバ側で現在の認証リクエストを識別するために使用します。 # もし値を何にするか困った場合、例えば「secrets.token_hex(8).upper()」のようなモジュールで生成するものありです。 # このstateをサーバで保持する事で、認証済のセッションを識別します。 #'state': secrets.token_hex(8).upper(), 'state' : 'XXXXXX', # リクエストする権限を指定。 # 下記は一例のため、必要に応じて変更。 # ↓付与可能な権限の一覧はこちら # https://docs.microsoft.com/en-us/linkedin/shared/references/migrations/default-scopes-migration#scope-to-consent-message-mapping #'scope': '%20'.join(['r_liteprofile', 'r_emailaddress', 'w_member_social']), 'scope': 'r_liteprofile' }, ).prepare().url # ここまで来たら、サーバ⇒クライアントにURLを送ってOK # 今回はローカル実行のため、サーバ⇒クライアントにURLを送る import webbrowser webbrowser.open(url)
data:image/s3,"s3://crabby-images/13c28/13c28d6847a6b7d6e004340c8e2251a30c8f4688" alt=""
data:image/s3,"s3://crabby-images/d70e1/d70e1fc6fd106d2df7925acd23c14c9e3894a916" alt=""
data:image/s3,"s3://crabby-images/f79c4/f79c47033e1b2a7c8e33a0323994d127cd7482a2" alt=""
http://localhost:8000/?code=XXXXXXXXXXXX&state=DCEeFWf45A53sdfKef424
●STEP6-2:「access_token」の取得
・①「access_tokenを取得するための下記Pythonプログラムをローカル実行
data:image/s3,"s3://crabby-images/1b528/1b52851b4a34a4b7614840490e8b42b0e643d360" alt=""
(サンプルプログラム)
import requests access_token = requests.post( 'https://www.linkedin.com/oauth/v2/accessToken', params = { 'grant_type': 'authorization_code', # 前の手順で取得したcodeをセット 'code': 'XXXXX', # 前の手順のPythonコード中の'redirect_uri'と同じ値にする 'redirect_uri': 'http://localhost:8000', # ご自身のAppのClient ID 'client_id': 'XXXXX', # ご自身のAppのClient Secret 'client_secret': 'XXXXXX', }, ).json()['access_token'] print(access_token)
(1-7) STEP7:API疎通チェック(Python)
data:image/s3,"s3://crabby-images/ac674/ac674a4c52cf61327b72310c21fa42dec1d49046" alt=""
import requests import os import oauth2 as oauth from requests.auth import HTTPBasicAuth def main(): response = requests.get( 'https://api.linkedin.com/v2/me', params = { # APIパラメータがあれば追記 }, headers = { 'Authorization': 'Bearer ' + 'XXXXX', # HTTPヘッダーがあれば追記 }, ) res_json = response.json() print(res_json) return res_json if __name__ == "__main__": main()
{'localizedLastName': 'xxxx', 'profilePicture': {'displayImage': 'urn:li:digitalmediaAsset:C5603AQG8r0KSOzwwaA'}, 'firstName': {'localized': {'ja_JP': ' xxxx '}, 'preferredLocale': {'country': 'JP', 'language': 'ja'}}, 'lastName': {'localized': {'ja_JP': 'xxxx'}, 'preferredLocale': {'country': 'JP', 'language': 'ja'}}, 'id': 'XXXXXX', 'localizedFirstName': 'xxxx'}