2024 Aug 08 9:47 AM - edited 2024 Aug 08 10:19 AM
I have an API that contains a request that uses x-www-form-urlencoded as body data type .. i noticed that when i use set_body_data the client proxy automaticly set the content-type to json so that won't work .. so i had to remove the request body before the execute and use the mo_http_client to set the custom content type and set_form_fields but that also didn't work .. any ideas how to send POST request with x-www-form-urlencoded data using client_proxy ?
as an example
data(lo_request) = mo_http_client->request.
lo_request->set_content_type( 'application/x-www-form-urlencoded' ).
lo_request->set_form_fields( value #( ( name = 'grant_type' value = 'password' ) ) ).
mo_client_proxy->create_resource( zaf_if_types=>gcs_resource_names-pets
)->create_request( /iwbep/if_v4_rest_types=>gcs_http_method-post
)->execute()
Notice : The used framework is iwbep client proxy rest
abap client proxy
abap odata client proxy samples
One example :
DATA: lv_form_data TYPE string,
lv_key TYPE string,
lv_value TYPE string.
lv_key = 'key1'.
lv_value = 'value1'.
lv_form_data = lv_key && '=' && cl_http_utility=>escape_url( lv_value ).
lv_key = 'key2'.
lv_value = 'value2'.
lv_form_data = lv_form_data && '&' && lv_key && '=' && cl_http_utility=>escape_url( lv_value ).
lo_http_client->request->set_cdata( lv_form_data ).
This method should be preferred over using set_body_data with x-www-form-urlencoded content, as set_body_data is typically used for raw data, and the content type can get overridden.
also
lo_http_client->request->set_header_field(
name = 'Content-Type'
value = 'application/x-www-form-urlencoded' ).
Ensure that all key-value pairs are properly URL-encoded.
Setting the content type to application/x-www-form-urlencoded is crucial, as the default content type might be JSON, which is why the previous approach might not have worked.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
User | Count |
---|---|
70 | |
8 | |
8 | |
7 | |
7 | |
6 | |
6 | |
6 | |
6 | |
6 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.