# Phần thân URL-Encoding

Theo mặc định, axios tuần tự hóa đối tượng Javascript thành JSON. Thay vào đó, để gửi dữ liệu theo định dạng application/x-www-form-urlencoded, bạn có thể sử dụng một trong các lựa chọn sau đây.

# Trình duyệt

Trong trình duyệt, bạn có thể sử dụng URLSearchParams (opens new window) API như sau:

const params = new URLSearchParams();
params.append('tham-số-1', 'giá-trị-1');
params.append('tham-số-2', 'giá-trị-2');
axios.post('/foo', params);

Lưu ý rằng không phải trình duyệt nào cũng hỗ trợ URLSearchParams (xem caniuse.com (opens new window)), nhưng có một polyfill (opens new window) sẵn dùng đây (hãy đảm bảo là polyfill cho môi trường toàn cục)

Hoặc là bạn có thể biên mã dữ liệu bằng thư viện qs (opens new window):

const qs = require('qs');
axios.post('/foo', qs.stringify({ 'bar': 123 }));

Hoặc là theo cách khác nữa (ES6),

import qs from 'qs';
const data = { 'bar': 123 };
const options = {
  method: 'POST',
  headers: { 'content-type': 'application/x-www-form-urlencoded' },
  data: qs.stringify(data),
  url,
};
axios(options);

# Node.js

# Query string

Trong node.js, bạn có thể sử dụng module querystring (opens new window) như sau:

const querystring = require('querystring');
axios.post('http://cái-gì-đó.com/', querystring.stringify({ foo: 'bar' }));

hoặc 'URLSearchParams' (opens new window) từ module 'url' (opens new window) như sau:

const url = require('url');
const params = new url.URLSearchParams({ foo: 'bar' });
axios.post('http://cái-gì-đó.com/', params.toString());

Bạn còn có thể sử dụng thư viện qs (opens new window).

LƯU Ý: Nếu bạn cần string-hóa các đối tượng lồng nhau thì tốt nhất hãy dùng thư viện qs, vì phương thức querystring có vấn đề đã ghi nhận đối với use case đó (https://github.com/nodejs/node-v0.x-archive/issues/1665).

# Form data

Trong node.js, bạn có thể sử dụng thư viện form-data (opens new window) như sau:

const FormData = require('form-data');
 
const form = new FormData();
form.append('field_của_tôi', 'giá trị của tôi');
form.append('buffer_của_tôi', new Buffer(10));
form.append('file_của_tôi', fs.createReadStream('/foo/bar.jpg'));

axios.post('https://example.com', form, { headers: form.getHeaders() })

Hoặc là sử dụng một bộ đón chặn:

axios.interceptors.request.use(config => {
  if (config.data instanceof FormData) {
    Object.assign(config.headers, config.data.getHeaders());
  }
  return config;
});
Last Updated: 2/24/2023, 9:22:20 AM