使用SAP API portal進行SAP SuccessFactors的API測試

i042416發表於2020-02-28

登入api.sap.com, 根據關鍵字SuccessFactors找到對應的API目錄:

使用SAP API portal進行SAP SuccessFactors的API測試

找到foundation/Platform級別的API,進入之後,

使用SAP API portal進行SAP SuccessFactors的API測試

選擇User Management:

使用SAP API portal進行SAP SuccessFactors的API測試

點選Logon,以使用API控制檯自帶的控制功能:

使用SAP API portal進行SAP SuccessFactors的API測試

點選Try Out, 就可以像使用postman一樣,使用這個API控制檯自帶的測試功能了:

使用SAP API portal進行SAP SuccessFactors的API測試

$filter string裡可以測試這個OData API的filter操作:

使用SAP API portal進行SAP SuccessFactors的API測試

從測試結果可以發現,firstName為Sami的user,在這個sandbox系統裡的user ID為50004:

使用SAP API portal進行SAP SuccessFactors的API測試 使用SAP API portal進行SAP SuccessFactors的API測試


點選Show API Key,拿到一個API key,這樣就能在該API控制檯以外的地方呼叫API.

使用SAP API portal進行SAP SuccessFactors的API測試 使用SAP API portal進行SAP SuccessFactors的API測試


點選Code Snipet,可以把自動生成的API呼叫程式碼複製下來,直接貼上到應用裡使用。

使用SAP API portal進行SAP SuccessFactors的API測試

點選Curl,獲得使用工具curl進行測試的命令列:

使用SAP API portal進行SAP SuccessFactors的API測試

> curl --request GET --url " sandbox.api.sap.com/suc " --header "APIKey: e9ZLBOfexchhHN" --header "Accept: application/json" --header "Content-Type: application/json"



> curl --request GET --url " sandbox.api.sap.com/suc " --header "APIKey: e9ZLBOkMUexchhHN" --header "Accept: application/json" --header "Content-Type: application/json"


#API endpoint for API sandbox

#Optional query parameters: "$top" , "$skip"

#To view the complete list of query parameters, see its API definition.

#Available API Endpoints

# api2.successfactors.eu/

# apisalesdemo2.successfactors.eu

# api2preview.sapsf.eu/od

# api4.successfactors.com

# apisalesdemo4.successfactors.com

# api4preview.sapsf.com/o

# api5.successfactors.eu/

# api8.successfactors.com

# apisalesdemo8.successfactors.com

# api8preview.sapsf.com/o

# api10.successfactors.com

# api10preview.sapsf.com/

# api012.successfactors.eu

# apirot.successfactors.eu

# api12preview.sapsf.eu/o

# api15.sapsf.cn/odata/v2

# api16.sapsf.eu/odata/v2

# api17preview.sapsf.com/

# api17.sapsf.com/odata/v

# api18preview.sapsf.com/

# api18.sapsf.com/odata/v

使用SAP API portal進行SAP SuccessFactors的API測試

得到的結果:

使用SAP API portal進行SAP SuccessFactors的API測試 使用SAP API portal進行SAP SuccessFactors的API測試 使用SAP API portal進行SAP SuccessFactors的API測試




也可以透過select操作,讓API只返回firstName和lastName兩個欄位的值:

curl --request GET --url " sandbox.api.sap.com/suc

User,UserPermissions/User?%24top-5&%24select=firstName%2ClastName" --header 'APIKey: e9ZLBOXsAfkMUexchhHN' --header 'Accept: application/ison' --header "Content-Type: application/ison"



curl --request GET --url " sandbox.api.sap.com/suc " --header "APIKey: e9ZibykWXsAfkMUexchhHN" --header "Accept: application/json" --header "Content-Type: application/json"

使用SAP API portal進行SAP SuccessFactors的API測試

在SAP UI5應用裡消費API的程式碼:


```JavaScript

//Create JSON Model with URL
var oModel = new sap.ui.model.json.JSONModel();
//API Key for API Sandbox
var sHeaders = {"Content-Type":"application/json","Accept":"application/json","APIKey":"e9ZLBOfIplCOnibykWXsAfkMUexchhHN"};
//Available Security Schemes for productive API Endpoints
//Basic Authentication
//Basic Auth : provide username:password in Base64 encoded in Authorization header
//sending request
//API endpoint for API sandbox 
oModel.loadData(");
//Optional query parameters: "$top" , "$skip"
//To view the complete list of query parameters, see its API definition.
//Available API Endpoints
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//
//You can assign the created data model to a View and UI5 controls can be bound to it. Please refer documentation available at the below link for more information.
//
//The below code snippet for printing on the console is for testing/demonstration purpose only. This must not be done in real UI5 applications.
oModel.attachRequestCompleted(function(oEvent){
    var oData = oEvent.getSource().oData;
    console.log(oData);
});

```

使用SAP API portal進行SAP SuccessFactors的API測試

在SAP雲平臺ABAP程式設計環境裡消費API的ABAP程式碼:


```ABAP

TRY.
"create http destination by url; API endpoint for API sandbox 
DATA(lo_http_destination) = 
     cl_http_destination_provider=>create_by_url( ').
  "alternatively create HTTP destination via destination service
    "cl_http_destination_provider=>create_by_cloud_destination( i_name = '<...>'
     "                            i_service_instance_name = '<...>' )
    "SAP Help: SAP Help Portal
"Available API Endpoints
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"
"create HTTP client by destination
DATA(lo_web_http_client) = cl_web_http_client_manager=>create_by_http_destination( lo_http_destination ) .
"adding headers with API Key for API Sandbox
DATA(lo_web_http_request) = lo_web_http_client->get_http_request( ).
lo_web_http_request->set_header_fields( VALUE #( 
(  name = 'Content-Type' value = 'application/json' )
(  name = 'Accept' value = 'application/json' )
(  name = 'APIKey' value = 'e9ZLBOfIplCOnibykWXsAfkMUexchhHN' )
 ) ).
"Available Security Schemes for productive API Endpoints
"Bearer and Basic Authentication
"lo_web_http_request->set_authorization_bearer( i_bearer = '<...>' ).
"lo_web_http_request->set_authorization_basic( i_username = '<...>' i_password = '<...>' ).
"set request method and execute request
DATA(lo_web_http_response) = lo_web_http_client->execute( if_web_http_client=>GET ).
DATA(lv_response) = lo_web_http_response->get_text( ).
CATCH cx_http_dest_provider_error cx_web_http_client_error cx_web_message_error.
    "error handling
ENDTRY.
"uncomment the following line for console output; prerequisite: code snippet is implementation of if_oo_adt_classrun~main
"out->write( |response:  { lv_response }| ).

```


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/24475491/viewspace-2677577/,如需轉載,請註明出處,否則將追究法律責任。

相關文章