Contents
初めに
REST API連携に関しては既に以下の記事があります。
Salesforce API連携入門(SF→外部システム編):Salesforceから外部システムのAPIをApex Calloutを用いて叩く記事
Salesforce API連携入門(外部システム→SF編):外部からRESTでSF標準のAPIを叩いてレコードをPOSTする記事
前書き
本記事ではPostmanを利用してSOAP APIでSalesforceのAPIを叩いてみたいと思います。
認証にはユーザ名とパスワードを利用した方法を用いる予定です。
皆さんお馴染み(?)の「データローダ(DataLoader)」はSOAP APIで動作しており、背後の仕組みは今回ご紹介する内容とほぼ同一です。
手順
- Postmanの準備
- セキュリティトークンの取得
- SFにPOSTリクエストを投げてセッションIDを取得
- セッションIDを利用したSFへのリクエスト
Postmanの準備
1.ここからPostmanをダウンロードして起動
2.起動後、画面左側のCollectionsタブから「+ New Collection」をクリック
data:image/s3,"s3://crabby-images/81056/8105683c71b1129a8547c2b1f63130878db460e9" alt=""
3.任意のNameを入力し「Create」をクリック
data:image/s3,"s3://crabby-images/37b92/37b929e71a603c030445fa92919bb717d95535c8" alt=""
4.作成したCollectionの設定ボタンから「Add Request」を選択
data:image/s3,"s3://crabby-images/ec756/ec756533890afd9cb5d3802cc368c4b495b9ce5e" alt=""
5.適当な名前を付けて保存(セッションID取得用のリクエストをここで書きます)
data:image/s3,"s3://crabby-images/b6dbb/b6dbb83314539a861b8345a14b006a41b61486d0" alt=""
6.同一手順でもう一つREQUESTを作成(SFのAPIをガンガン叩いていくリクエストです)
data:image/s3,"s3://crabby-images/a0ae7/a0ae796d7d8771d26e7e8e3e6e6f9b6a61235a51" alt=""
セキュリティトークンの取得
1.画面右上のアイコン>設定の順にクリック
data:image/s3,"s3://crabby-images/8d298/8d298b104f284b6636426fb93af8d1d9b5363fbe" alt=""
2.私のセキュリティトークンのリセット>セキュリティトークンのリセットの順にクリック
data:image/s3,"s3://crabby-images/001b7/001b79b44c4a1c555c728b5e8f442b8cfc003ba9" alt=""
3.自分のメアド宛てに届いたセキュリティトークンをGET(いえい)
SFにPOSTリクエストを投げてセッションIDを取得
1.HTTPメソッドをPOSTに変更し、下記のURLを記載
https://login.salesforce.com/services/Soap/c/49.0
data:image/s3,"s3://crabby-images/bb74a/bb74a4b06c794930f1683d0e59022b017acad900" alt=""
2.Headerに下記をセット。上のURLもそうですが、大文字と小文字ミスると後でエラー出るの注意してください。
KEY | VALUE |
SOAPAction | ” |
Content-type | text/xml |
data:image/s3,"s3://crabby-images/85126/85126a91e600d121a5dca96e0ee76c2a84fca300" alt=""
3.Bodyの種別をnoneからrawに変更。形式がXMLになっていることを確認したうえで、Bodyに下記を記載。
<?xml version="1.0" encoding="utf-8" ?>
<env:Envelope xmlns:xsd="http://www.w3.org/2001/XMLSchema"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:env="http://schemas.xmlsoap.org/soap/envelope/">
<env:Body>
<n1:login xmlns:n1="urn:enterprise.soap.sforce.com">
<n1:username>ユーザ名</n1:username>
<n1:password>パスワードセキュリティトークン</n1:password>
</n1:login>
</env:Body>
</env:Envelope>
data:image/s3,"s3://crabby-images/10248/10248ea997e1cff6ea4382e3232c97ac36927ca1" alt=""
4.「Send」をクリックし、レスポンスBodyからセッションIDをGET(いえい)
data:image/s3,"s3://crabby-images/26490/264907392d726878b8dc60c636bb789157cc1b2e" alt=""
セッションIDを利用したSFへのリクエスト
1.HTTPメソッドをPOSTに変更し、下記のURLを記載
https://私のドメイン.my.salesforce.com/services/Soap/c/49.0
data:image/s3,"s3://crabby-images/7da47/7da4745442b478ffcd9475295379c15ffe1eca58" alt=""
2.Headerに下記をセット。先ほどと同じく、大文字と小文字ミスると後でエラー出るの注意。
KEY | VALUE |
SOAPAction | ” |
Content-type | text/xml |
data:image/s3,"s3://crabby-images/d8c25/d8c250fb2b1c4f13f62f7a44a05f48e980c4b60a" alt=""
3.Bodyの種別をnoneからrawに変更。形式がXMLになっていることを確認したうえで、Bodyに下記を記載。
<?xml version="1.0" encoding="utf-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:urn="urn:enterprise.soap.sforce.com">
<soapenv:Header>
<urn:SessionHeader>
<urn:sessionId>セッションID</urn:sessionId>
</urn:SessionHeader>
</soapenv:Header>
<soapenv:Body>
<urn:query>
<urn:queryString>SELECT id,Name FROM Opportunity</urn:queryString>
</urn:query>
</soapenv:Body>
</soapenv:Envelope>
data:image/s3,"s3://crabby-images/74374/74374c270f4b07d706d37d5518924a12f00c5dba" alt=""
4.「Send」をクリックし、レスポンスBodyから必要な情報をGET(いえい)
data:image/s3,"s3://crabby-images/6c18b/6c18bb1b601396dd0ccf454d0323b7a66fb30016" alt=""
INSERTの場合
レコードをINSERTしたい場合は下記のbodyに書き換えます。
<?xml version="1.0" encoding="utf-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:urn="urn:enterprise.soap.sforce.com"
xmlns:urn1="urn:sobject.enterprise.soap.sforce.com"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<soapenv:Header>
<urn:SessionHeader>
<urn:sessionId>セッションID</urn:sessionId>
</urn:SessionHeader>
<urn:MruHeader>
<urn:updateMru>false</urn:updateMru>
</urn:MruHeader>
</soapenv:Header>
<soapenv:Body>
<urn:create>
<urn:sObjects xsi:type="urn1:Account">
<Name> Neko Company </Name>
<Phone> 0120345678 </Phone>
</urn:sObjects>
<urn:sObjects xsi:type="urn1:Account">
<Name> Cat Company </Name>
<Phone> 1203456789 </Phone>
</urn:sObjects>
<urn:sObjects xsi:type="urn1:Account">
<Name> Dog Company </Name>
<Phone> 2034567890 </Phone>
</urn:sObjects>
</urn:create>
</soapenv:Body>
</soapenv:Envelope>
※updateMruの値をTrueにすると「Recently Viewed」リストビュー一覧に最初から表示されます。
複数オブジェクトのレコードを同時にINSERTしたい場合は以下のようなbodyを指定します。
<?xml version="1.0" encoding="utf-8"?>
<soapenv:Envelope xmlns:soapenv="http://schemas.xmlsoap.org/soap/envelope/"
xmlns:urn="urn:enterprise.soap.sforce.com"
xmlns:urn1="urn:sobject.enterprise.soap.sforce.com"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
<soapenv:Header>
<urn:SessionHeader>
<urn:sessionId>セッションID</urn:sessionId>
</urn:SessionHeader>
<urn:MruHeader>
<urn:updateMru>false</urn:updateMru>
</urn:MruHeader>
</soapenv:Header>
<soapenv:Body>
<urn:create>
<urn:sObjects xsi:type="urn1:Account">
<Name>Neko Company</Name>
<Phone>0120345678</Phone>
</urn:sObjects>
<urn:sObjects xsi:type="urn1:CustomObject__c">
<Name__c>Dog</Name__c>
<CustomField__c>Wan</CustomField__c>
</urn:sObjects>
<urn:sObjects xsi:type="urn1:CustomObject__c">
<Name__c>Cat</Name__c>
<CustomField__c>Nyan</CustomField__c>
</urn:sObjects>
</urn:create>
</soapenv:Body>
</soapenv:Envelope>