37

I'm trying to pass in an API key through the URL parameters in my GET request.

However, I notice that Axios encodes the characters in my API key when sending the request. This causes the API to reject my request as it couldn't recognise my key.

How can I prevent Axios from encoding my GET parameters?

Carven
  • 14,988
  • 29
  • 118
  • 161

2 Answers2

30

You can use a custom param serializer as follows:

axios.get('https://foobar.com/api', {
  paramsSerializer: function(params) {
    var result = '';
    // Build the query string 
    return result;
  }
});

paramsSerializer can be set at the instance level:

var instance = axios.create({ paramsSerializer: function(params) { /* ... */ } })

or at the global level:

axios.defaults.paramsSerializer = function(params) { /* ... */ };

Another option is to directly add the api key to the URL:

axios.get('https://foobar.com/api?api_key=' + key);

You can add additional parameters using the `params' config option:

axios.get('https://foobar.com/api?api_key=' + key, {
  params: {
    foo: 'bar'
  }
});
Nick Uraltsev
  • 24,607
  • 4
  • 25
  • 14
2

In case you are using qs library (or similar encoding lib) you can also do

import qs from 'qs';

axios.get('https://foobar.com/api', {
    params,
    paramsSerializer: (params) => qs.stringify(params, { encode: false }),
});
marko424
  • 3,839
  • 5
  • 17
  • 27
  • This solution no longer seems to work AxiosError: options must be an object. paramsSerializer seems to require encode and serialize keys now. – ykonda Mar 10 '23 at 22:04