SAP ABAP - การออกจากผู้ใช้

การออกของผู้ใช้จะถูกใช้ในการแยกหากตัวแยก SAP มาตรฐานไม่ให้ข้อมูลที่คาดไว้หรือฟังก์ชันที่จำเป็นเช่นในการอนุญาตหรือการตรวจสอบเวลา การออกของผู้ใช้มักใช้ในโมดูลการขายและการกระจาย (SD) SAP มีทางออกมากมายในด้านการขายการขนส่งการขนส่งและการเรียกเก็บเงิน ทางออกของผู้ใช้ออกแบบมาเพื่อทำการเปลี่ยนแปลงบางอย่างเมื่อ SAP มาตรฐานไม่สามารถปฏิบัติตามข้อกำหนดทั้งหมดได้

เพื่อให้สามารถเข้าถึงทางออกที่มีอยู่ในแต่ละพื้นที่การขายไปที่ IMG โดยใช้เส้นทางนี้: IMG →การขายและการกระจาย→การปรับเปลี่ยนระบบ→การออกจากผู้ใช้ เอกสารสำหรับแต่ละทางออกในส่วนของ SD จะอธิบายอย่างละเอียด

ตัวอย่างเช่นหากคุณต้องการค้นหาการออกของผู้ใช้ในการประมวลผลเอกสารการขาย (สัญญาใบเสนอราคาหรือใบสั่งขาย) ให้ทำตามเส้นทางที่กล่าวถึงข้างต้นและดำเนินการต่อเพื่อขยายโหนด User Exits ใน Sales → User Exits คลิกที่ไอคอนเอกสารเพื่อดูการออกของผู้ใช้ทั้งหมดที่มีอยู่ใน Sales Document Processing

ส. การออกและคำอธิบายของผู้ใช้
1

USEREXIT_FIELD_MODIFICATION

ใช้เพื่อแก้ไขแอตทริบิวต์ของหน้าจอ

2

USEREXIT_SAVE_DOCUMENT

ช่วยในการดำเนินการเมื่อผู้ใช้กดบันทึก

3

USEREXIT_SAVE_DOCUMENT_PREPARE

มีประโยชน์มากในการตรวจสอบช่องป้อนข้อมูลใส่ค่าใด ๆ ในฟิลด์หรือแสดงป๊อปอัปให้กับผู้ใช้และเพื่อยืนยันเอกสาร

4

USEREXIT_MOVE_FIELD_TO_VBAK

ใช้เมื่อมีการย้ายการเปลี่ยนแปลงส่วนหัวของผู้ใช้ไปยังพื้นที่ทำงานส่วนหัว

5

USEREXIT_MOVE_FIELD_TO_VBAP

ใช้เมื่อการเปลี่ยนแปลงไอเท็มผู้ใช้ถูกย้ายไปยังพื้นที่ทำงานของไอเท็ม SAP

การออกจากผู้ใช้มีจุดประสงค์เดียวกับการออกของลูกค้า แต่จะพร้อมใช้งานสำหรับโมดูล SD เท่านั้น ทางออกถูกนำไปใช้เป็นการเรียกใช้โมดูลฟังก์ชัน User Exits คือการแก้ไขโปรแกรมมาตรฐาน SAP

ตัวอย่าง

REPORT ZUSEREXIT1. 
TABLES:   
   TSTC, TSTCT,
   TADIR, TRDIR, TFDIR, ENLFDIR,
   MODSAPT, MODACT. 
	
DATA:   
   JTAB LIKE TADIR OCCURS 0 WITH HEADER LINE,
   field1(30),
   v_devclass LIKE TADIR-devclass. 
	
PARAMETERS:
   P_TCODE LIKE TSTC-tcode OBLIGATORY. 
	
SELECT SINGLE *
   FROM TSTC
   WHERE tcode EQ P_TCODE. 
	
IF SY-SUBRC EQ 0.
   SELECT SINGLE *
   FROM TADIR
	
   WHERE pgmid = 'R3TR' AND 
         object = 'PROG' AND
         obj_name = TSTC-pgmna.
		
   MOVE TADIR-devclass TO v_devclass.
	
   IF SY-SUBRC NE 0.
   SELECT SINGLE * 
      FROM TRDIR
      WHERE name = TSTC-pgmna.
		
   IF TRDIR-subc EQ 'F'.
      SELECT SINGLE *
         FROM TFDIR
         WHERE pname = TSTC-pgmna.
			
      SELECT SINGLE *
         FROM ENLFDIR 
         WHERE funcname = TFDIR-funcname.
			
      SELECT SINGLE * 
         FROM TADIR
         WHERE pgmid = 'R3TR' AND
               object = 'FUGR' AND 
               obj_name EQ ENLFDIR-area.
         MOVE TADIR-devclass TO v_devclass.
      ENDIF.
   ENDIF.
	
   SELECT *
      FROM TADIR
      INTO TABLE JTAB
		
      WHERE pgmid = 'R3TR' AND
            object = 'SMOD' AND
            devclass = v_devclass.
			
   SELECT SINGLE *
      FROM TSTCT
      WHERE sprsl EQ SY-LANGU AND
            tcode EQ P_TCODE.
			
   FORMAT COLOR COL_POSITIVE INTENSIFIED OFF.
   WRITE:/(19) 'Transaction Code - ', 
      20(20) P_TCODE,
      45(50) TSTCT-ttext.
   SKIP.
	
   IF NOT JTAB[] IS INITIAL.
      WRITE:/(95) SY-ULINE.
      FORMAT COLOR COL_HEADING INTENSIFIED ON.
		
      WRITE:/1 SY-VLINE, 
            2 'Exit Name',
            21 SY-VLINE , 
            22 'Description',
            95 SY-VLINE.
			
      WRITE:/(95) SY-ULINE.
      LOOP AT JTAB.
         SELECT SINGLE * FROM MODSAPT
         WHERE sprsl = SY-LANGU AND
               name = JTAB-obj_name.
				
         FORMAT COLOR COL_NORMAL INTENSIFIED OFF.
         WRITE:/1 SY-VLINE,
               2 JTAB-obj_name HOTSPOT ON,
               21 SY-VLINE ,
               22 MODSAPT-modtext,
               95 SY-VLINE.
      ENDLOOP.
		
      WRITE:/(95) SY-ULINE.
      DESCRIBE TABLE JTAB.
      SKIP.
      FORMAT COLOR COL_TOTAL INTENSIFIED ON.
      WRITE:/ 'No of Exits:' , SY-TFILL.
		
   ELSE.
      FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.
      WRITE:/(95) 'User Exit doesn’t exist'.
   ENDIF. 
ELSE.

   FORMAT COLOR COL_NEGATIVE INTENSIFIED ON.
   WRITE:/(95) 'Transaction Code Does Not Exist'. 
ENDIF.
 
AT LINE-SELECTION.
   GET CURSOR FIELD field1.
   CHECK field1(4) EQ 'JTAB'.
   SET PARAMETER ID 'MON' FIELD sy-lisel+1(10).
   CALL TRANSACTION 'SMOD' AND SKIP FIRST SCREEN.

ขณะดำเนินการให้ป้อนรหัสธุรกรรม 'ME01' แล้วกดปุ่ม F8 (ดำเนินการ) รหัสด้านบนสร้างผลลัพธ์ต่อไปนี้ -