| 标题 | 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分 (2 月前) |
|---|
| 管理 | 2026-05-23 16時06分 (27 days later) |
|---|
| 状态 | 重复 |
|---|
| VulDB条目 | 322183 [macrozheng mall 直到 1.0.3 /order/paySuccess orderId 权限提升] |
|---|
| 积分 | 0 |
|---|