Tính phí vận chuyển

Tính phí cho 1 đơn

  • /api/shipping/fee: Tính năng này dùng để tính phí vận chuyển cho một đơn hàng. Mỗi khi khách hàng vào trang Giỏ hàng, hoặc ở bước thanh toán, website của bạn có thể call API này để tính phí vận chuyển cho đơn hàng và hiển thị chi tiết tổng tiền của đơn hàng bao gồm cả phí vận chuyển và phí thu tiền hộ (nếu khách hàng chọn hình thức thanh toán khi nhận hàng).

Request

Param
Data type (Max-length)
Required
Description
fromCityName
string
Yes
Tên thành phố của kho gửi hàng (Lấy từ /api/shipping/location)
fromDistrictName
string
Yes
Tên quận huyện của kho gửi hàng (Lấy từ /api/shipping/location)
toCityName
string
Yes
Tên thành phố của khách nhận hàng (Lấy từ /api/shipping/location)
toDistrictName
string
Yes
Tên quận huyện của khách nhận hàng (Lấy từ /api/shipping/location)
codMoney
int
No
Giá trị tiền cần thu hộ của đơn hàng (Tổng giá nhân số lượng sản phẩm trong đơn hàng), set 0 nếu đơn hàng này không cần thu tiền hộ (VD tình huống khách đã chuyển khoản trước)
shippingWeight
int
No
Tổng trọng lượng các sản phẩm của đơn hàng tính bằng gram. Hiện tại Nhanh.vn hỗ trợ đơn hàng tối đa 100000 gr (100 kg).
productIds
array
No
Danh sách các ID sản phẩm được đồng bộ từ Nhanh.vn sang website của bạn (idNhanh), dùng để tính khối lượng đơn hàng theo giá trị sản phẩm khai báo bên Nhanh (Truyền biến này thì không cần truyền shippingWeight), cấu trúc: [productId1 => quantity, productId2 => quantity, ...], hệ thống sẽ lấy quantity nhân với khối lượng sản phẩm khai báo trên Nhanh.vn để tính tổng khối lượng của đơn hàng
carrierIds
array
No
Dùng để giới hạn các hãng vận chuyển muốn dùng (Lấy từ /api/shipping/carrier). VD: [5,7,8,9]
length
int
No
Chiều dài gói hàng tính theo cm.
width
int
No
Chiều rộng gói hàng tính theo cm.
height
int
No
Chiều cao gói hàng tính theo cm.
Chú ý: API này có 2 tình huống:
  • Nếu các sản phẩm được đồng bộ từ Nhanh.vn sang website của bạn (Nhanh.vn đã có thông tin shippingWeight của các sản phẩm này): website của bạn có thể gửi sang 1 mảng productIds, Nhanh.vn sẽ tự tính toán tổng trọng lượng của đơn hàng này.
  • Website của bạn tự tính tổng trọng lượng shippingWeight của đơn hàng này.
    Nếu bạn có truyền sang các tham số length, width, height: Nhanh.vn sẽ tính toán trọng lượng của đơn hàng theo công thức quy ra kg: A = dài * rộng * cao / 6000 (so sánh số A và shippingWeight tham số nào lớn hơn sẽ lấy theo tham số đó để tính toán cước phí) và trả về kết quả đánh dấu nếu gói hàng thuộc loại hàng cồng kềnh.

Response

  • JSON decode the response to get the structure:
Key
Data Type(Max-length)
Description
code
int
1 = success or 0 = failed
messages
array
is an array of error messages if code = 0
data
array
is an array of all supported shipping services
  • data is an array of all supported shipping services
    1
    [
    2
    // service 1
    3
    [
    4
    'carrierId': int // id hãng vận chuyển
    5
    'carrierName': string // tên hãng vận chuyển
    6
    'serviceId': int // id dịch vụ vận chuyển
    7
    'serviceName': string // tên dịch vụ vận chuyển
    8
    'serviceDescription': string // mô tả dịch vụ vận chuyển
    9
    'estimatedDeliveryTime': int // Thời gian dự kiến giao hàng
    10
    'shipFee': int // phí vận chuyển
    11
    'codFee': int // phí thu tiền hộ
    12
    'declaredFee': int // phí bảo hiểm (khi mua dịch vụ khai giá để đền bù trong tình huống hãng vận chuyển làm mất hàng)
    13
    'isBulkyGoods': 1 | 0 // Biến đánh dấu hàng cồng kềnh
    14
    ]
    15
    // service 2
    16
    // ...
    17
    ]
    Copied!
    Chú ý:
    • shipFeeDiscount là phí vận chuyển được chiết khấu, VD shipFee = 25.000, shipFeeDiscount = 7.000 thì shipFee thực tế của đơn hàng này sẽ chỉ = 18.000
    • codFeeDiscount là phí thu tiền hộ được chiết khấu, VD codFee = 15.000, codFeeDiscount = 3.000 thì codFee thực tế của đơn hàng này sẽ chỉ = 12.000

Tính phí cho nhiều đơn

  • /api/shipping/multifee: Tính năng này dùng để tính phí vận chuyển cho nhiều đơn hàng (thường dùng nếu website của bạn là mô hình sàn, cho phép khách mua từ nhiều shop khác nhau). Mỗi khi khách hàng vào trang Giỏ hàng, hoặc ở bước thanh toán, website của bạn có thể call API này để tính phí vận chuyển cho đơn hàng và hiển thị chi tiết tổng tiền của đơn hàng bao gồm cả phí vận chuyển.
    Chú ý: API này dùng cho các sàn thương mại điện tử, giỏ hàng hỗ trợ mua hàng từ nhiều gian hàng, mỗi gian hàng có 1 địa chỉ lấy hàng khác nhau. Nếu website của bạn chỉ hỗ trợ lấy hàng từ 1 địa chỉ, xin vui lòng sử dụng /api/shipping/fee.

Request

  • The structure of data array:
    1
    [
    2
    // Đơn hàng 1
    3
    [
    4
    "fromCityName" => "TP. HCM",
    5
    "fromDistrictName" => "Quận 1",
    6
    "toCityName" => "Hà nội",
    7
    "shippingWeight" => 800,
    8
    "toDistrictName" => "Hoàn Kiếm",
    9
    "codMoney" => 1250000
    10
    ],
    11
    // Đơn hàng 2
    12
    [
    13
    "fromCityName" => "TP. HCM",
    14
    "fromDistrictName" => "Quận 3",
    15
    "toCityName" => "Hà nội",
    16
    "shippingWeight" => 2000, // 2000 gr = 2 kg
    17
    "toDistrictName" => "Hoàn Kiếm",
    18
    "codMoney" => 4950000
    19
    ]
    20
    ]
    Copied!
Chú ý: Hỗ trợ tối đa tính phí cho 10 đơn hàng cùng lúc.
Param
Data type (Max-length)
Required
Description
fromCityName
string
Yes
Tên thành phố của kho gửi hàng (Lấy từ /api/shipping/location)
fromDistrictName
string
Yes
Tên quận huyện của kho gửi hàng (Lấy từ /api/shipping/location)
toCityName
string
Yes
Tên thành phố của khách nhận hàng (Lấy từ /api/shipping/location)
toDistrictName
string
Yes
Tên quận huyện của khách nhận hàng (Lấy từ /api/shipping/location)
codMoney
int
No
Giá trị của đơn hàng (Tổng giá nhân số lượng sản phẩm trong đơn hàng) dùng để tính phí thu tiền hộ, set 0 nếu đơn hàng này không cần thu tiền hộ (VD tình huống khách đã chuyển khoản trước)
shippingWeight
int
No
Tổng trọng lượng của đơn hàng tính bằng gram (Tổng toàn bộ shipping weight của các sản phẩm trong đơn hàng). Hiện tại Nhanh.vn hỗ trợ đơn hàng tối đa 100000 gr (100 kg).
productIds
array
No
Danh sách các ID sản phẩm được đồng bộ từ Nhanh.vn sang website của bạn (idNhanh), dùng để tính khối lượng đơn hàng theo giá trị sản phẩm khai báo bên Nhanh.vn.
carrierIds
array
No
Dùng để giới hạn các hãng vận chuyển muốn dùng (Lấy từ /api/shipping/carrier). VD: [5,7,8,9]
length
int
No
Chiều dài gói hàng tính theo cm (Dùng cho hàng cồng kềnh, có kích thước >= 30cm).
width
int
No
Chiều rộng gói hàng tính theo cm (Dùng cho hàng cồng kềnh, có kích thước >= 30cm).
height
int
No
Chiều cao gói hàng tính theo cm (Dùng cho hàng cồng kềnh, có kích thước >= 30cm).
API này có 2 tình huống:
  • Website của bạn tự tính tổng trọng lượng shippingWeight của đơn hàng này.
  • Nếu các sản phẩm được đồng bộ từ Nhanh.vn sang website của bạn (Nhanh.vn đã có thông tin shippingWeight của các sản phẩm này): website của bạn có thể gửi sang 1 mảng productIds, Nhanh.vn sẽ tự tính toán tổng trọng lượng của đơn hàng này.
    Chú ý: nếu bạn có truyền sang các tham số length, width, height: Nhanh.vn sẽ tính toán trọng lượng của đơn hàng theo công thức quy ra kg: A = dài rộng cao / 6000 (so sánh số A và shippingWeight tham số nào lớn hơn sẽ lấy theo tham số đó để tính toán cước phí) và trả về kết quả đánh dấu nếu gói hàng thuộc loại hàng cồng kềnh.
Key
Data Type(Max-length)
Description
code
int
1 = success or 0 = failed
messages
array
is an array of error messages if code = 0
data
array
is an array of all supported shipping services

Response

  • The response: JSON decode the response to get the structure:
    1
    [
    2
    // kết quả tính phí cho đơn hàng 1
    3
    [
    4
    "carrierId": int // id hãng vận chuyển
    5
    "carrierName": string // tên hãng vận chuyển
    6
    "serviceId": int // id dịch vụ vận chuyển
    7
    "serviceName": string // tên dịch vụ vận chuyển
    8
    "serviceDescription": string // mô tả dịch vụ vận chuyển
    9
    "estimatedDeliveryTime": int // Thời gian dự kiến giao hàng
    10
    "shipFee": int // phí vận chuyển
    11
    "codFee": int // phí thu tiền hộ
    12
    "declaredFee": int // phí bảo hiểm (khi mua dịch vụ khai giá để đền bù trong tình huống hãng vận chuyển làm mất hàng)
    13
    "isBulkyGoods": 1 | 0 // Biến đánh dấu hàng cồng kềnh
    14
    ],
    15
    // kết quả tính phí cho đơn hàng 2
    16
    [
    17
    "carrierId": int // id hãng vận chuyển
    18
    "carrierName": string // tên hãng vận chuyển
    19
    "serviceId": int // id dịch vụ vận chuyển
    20
    "serviceName": string // tên dịch vụ vận chuyển
    21
    "serviceDescription": string // mô tả dịch vụ vận chuyển
    22
    "estimatedDeliveryTime": int // Thời gian dự kiến giao hàng
    23
    "shipFee": int // phí vận chuyển
    24
    "codFee": int // phí thu tiền hộ
    25
    "declaredFee": int // phí bảo hiểm (khi mua dịch vụ khai giá để đền bù trong tình huống hãng vận chuyển làm mất hàng)
    26
    "isBulkyGoods": 1 | 0 // Biến đánh dấu hàng cồng kềnh
    27
    // ...
    28
    ]
    29
    // kết quả tính phí cho các đơn hàng tiếp theo
    30
    ]
    Copied!
Last modified 25d ago