场景:
因业务规范需求,不允许跨月报工及取消报工。
常见处理方案 :
1、BADI:WORKORDER_CONFIRM~AT_SAVE - Confirm Order, Time: Dialog;
2、出口增强:CONFPP05 - PP定单确认:储存时的客户特殊增强。
正常情况下(前台事务码操作),在这两处增强均可直接写校验逻辑,不过如果集成外围系统,通过接口报工时,在这两处写类似 MESSAGE ... TYPE 'E' ,都会直接中断,关键是SAP端没有任何异常记录。

遇到此类问题(前台可以,后台不行),实际工作中常见两种处理方法:
1、最简单的方法就是在接口(后台)逻辑中增加校验逻辑,提前避免;
2、正向研究,探索新报错方式或增强方案。
在这里,第一种方案当然不考虑,直接跳过。我们主要研究了正向如何处理,形成通用方案。
刚开始,先研究了报错方式,比如,更换报错方式、抛异常,可惜都不行。继而研究其他增强点,通过多次测试验证,将报工和取消报工的增强独立开,分别在 CONFPP02 和 WORKORDER_CONFIRM~AT_CANCEL_CHECK 完美解决问题(受以前逻辑影响,走了弯路)。
报工校验点:
SMOD:CONFPP02 - PP Order Confirmation: Customer-Specific Input Check Without Change

正常返回报错:


取消报工检查点:
WORKORDER_CONFIRM~AT_CANCEL_CHECK - Confirm Order, Time: Check if Cancellation is Possible

正常返回报错:


完美解决!
~~~~~~~~~~~~~~~~~~填坑路上一去不复返~~~~~~~~~~~~~~~~~~