Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Android™) Shopware 6 - Store API AuthenticationSee more Shopware 6 ExamplesEach sales channel has an accessKey, which can be generated in the administration or over the admin api. This accessKey is used for the authentication by providing it in the sw-access-key You can test the authentication by sending a request to the store-api/v1/context endpoint Note: This example only serves to test authentication. It returns a "token". This may lead you to believe that the returned token is what is required to authentication with subsequent Store API requests. This is NOT the case. The Store API requests simply authentication with the sw-access-key, just as this request does. The returned "token" is a context token which can be used to switch the different values of your current "session" like active language, currency or shipping location. Furthermore, Store API requests don't actually require an OAuth2 access token. The OAuth2 access token is needed for API requests (i.e. "/api/v3/..." as opposed to "/store-api/v3/...") For more information, see https://docs.shopware.com/en/shopware-platform-dev-en/store-api-guide/authentication?category=shopware-platform-dev-en/store-api-guide
// Important: Don't forget to include the call to System.loadLibrary // as shown at the bottom of this code sample. package com.test; import android.app.Activity; import com.chilkatsoft.*; import android.widget.TextView; import android.os.Bundle; public class SimpleActivity extends Activity { private static final String TAG = "Chilkat"; // Called when the activity is first created. @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkHttp http = new CkHttp(); boolean success; // Sends the following request // GET http://shopware.development/store-api/v3/context // --header sw-access-key SWSCYKQZODFVTVHJEHI0RFN0RG // // { // "includes": { // "sales_channel_context": ["token"] // } // } // Use this online tool to generate code from sample JSON: // Generate Code to Create JSON CkJsonObject json = new CkJsonObject(); json.UpdateString("includes.sales_channel_context[0]","token"); // Put the access token in the sw-access-key request header. http.SetRequestHeader("sw-access-key","<sales-channel-api-access-key>"); // The sales channel API access key is obtained from your Shopware 6 admin portal: String url = "https://my-shopware-6-shop.de/store-api/v3/context"; CkHttpResponse resp = http.PText("GET",url,json.emit(),"utf-8","application/json",false,false); if (http.get_LastMethodSuccess() == false) { Log.i(TAG, http.lastErrorText()); return; } CkStringBuilder sbResponseBody = new CkStringBuilder(); resp.GetBodySb(sbResponseBody); CkJsonObject jResp = new CkJsonObject(); jResp.LoadSb(sbResponseBody); jResp.put_EmitCompact(false); Log.i(TAG, "Response Body:"); Log.i(TAG, jResp.emit()); // If we get a 401 response, it may be that our access token expired and we need to fetch a new one. int respStatusCode = resp.get_StatusCode(); Log.i(TAG, "Response Status Code = " + String.valueOf(respStatusCode)); if (respStatusCode >= 400) { Log.i(TAG, "Response Header:"); Log.i(TAG, resp.header()); Log.i(TAG, "Failed."); return; } // Sample JSON response: // (Sample code for parsing the JSON response is shown below) // { // "token": "OCqj5ZEnpS0W9KgseOofPLqGArVjd5CE", // "apiAlias": "sales_channel_context" // ... // } // Sample code for parsing the JSON response... // Use the following online tool to generate parsing code from sample JSON: // Generate Parsing Code from JSON String token = jResp.stringOf("token"); String apiAlias = jResp.stringOf("apiAlias"); } static { System.loadLibrary("chilkat"); // Note: If the incorrect library name is passed to System.loadLibrary, // then you will see the following error message at application startup: //"The application <your-application-name> has stopped unexpectedly. Please try again." } } |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.