| タイトル | macrozheng mall latest master before fix Improper Authorization |
|---|
| 説明 | An improper authorization vulnerability exists in mall-portal order payment success handling.
The endpoint POST /order/paySuccess accepts user-controlled orderId and payType parameters and directly updates an unpaid order to paid status without verifying that the order belongs to the currently authenticated portal member and without validating a trusted payment-provider callback, transaction id, amount, or signature.
Source-level chain:
POST /order/paySuccess?orderId=<id>&payType=<type>
→ OmsPortalOrderController.paySuccess(orderId, payType)
→ OmsPortalOrderServiceImpl.paySuccess(orderId, payType)
→ update oms_order set status=1 where id=orderId and status=0 and delete_status=0
→ portalOrderDao.getDetail(orderId)
→ reduceSkuStock(...) for each order item
The missing ownership and payment-proof checks allow an authenticated portal member to force an unpaid order into paid/to-ship state and trigger inventory reduction. If the orderId belongs to another user, this also becomes a business-logic IDOR issue.
Impact includes unauthorized payment-state transition, order integrity compromise, and inventory reduction without verified payment. |
|---|
| ソース | ⚠️ https://github.com/macrozheng/mall |
|---|
| ユーザー | feng123123 (UID 95215) |
|---|
| 送信 | 2026年04月26日 07:34 (1 月 ago) |
|---|
| モデレーション | 2026年05月23日 16:06 (27 days later) |
|---|
| ステータス | 重複 |
|---|
| VulDBエントリ | 322183 [macrozheng mall 迄 1.0.3 /order/paySuccess orderId 特権昇格] |
|---|
| ポイント | 0 |
|---|