✒️ABAP Los módulos de funciones RFC
ABAP Los módulos de funciones RFC
Lección 4: Módulos de Función RFC
1.- Que es un modulo de función RFC
Consiste en una llamada a una función que existe en un sistema distinto al del programa que la llama.
El objetivo principal de las RFC es acceder a otros ambientes para obtener datos.
La comunicación puede darse entre sistemas SAP o entre un sistema SAP y otro que no sea SAP
Para llamar a una función RFC se debe agregar la clausula DESTINATION al momento de declarar la función, como vemos en este ejemplo.
DEF:La RFC llamada no existe en el sistema origen, pero si debe existir en el sistema destino.
Si quisiéramos leer un registro de un cliente del sistema o ambiente DTR a través de un programa ABAP existente en otro ambiente DCR, crearíamos una RFC en DTR que devuelva los registros de clientes.
En el sistema DTR, creo la RFC
FUNCTION ZOBTENERCLIENTES.
…”Leo el registro de cliente”
ENDFUNCTION.
En el sistema DCR, llamo a la RFC
CALLFUNCTION ZOBTENER_CLIENTES
Si se produce un error en la ejecución de una RFC los mensajes de error son devueltos por el sistema remoto y alojados en variables del sistema SY-MSGID, SY-MSGTY, SY-MSGNO, SY-MSGV1 (V2,V3,V4)
2.- Como crear una RFC
Una función RFC se crea de la misma manera que una función. Se accede a la transacción SE37 y se completan los datos igual, a excepción de la solapa Atributos la opción Modulo de acceso Remoto.
Los parámetros que se crean en una función RFC, no se pueden pasar por referencia, deben pasarse por valor.
Esto se logra tildando el check Transportar valores (pass values) para cada parámetro en las solapas IMPORT, EXPORT, CHANGING
A su vez, las funciones creadas como RFC pueden ser utilizadas como modulos de función normales. Se logra de las dos maneras diferentes:
* Utilizando la declaración CALL FUNCTION DESTINATION ‘NONE’.
* Utilizando la declaración de un modulo de función normal, sin el agradado DESTINATION.
3.-Tipos de RFC
Existen tres tipo de RFC.
· Sincrónicas, ambos sistemas debe estar disponibles al momento de la llamada de la función. Estas RFC están basadas en una comunicación sincrónica
· Transaccionales, Los sistemas no necesitan estar disponibles al momento de la llamada a la función. Un único ID de transacción es generado y los programas son almacenados en el sistema junto con los datos. Para crear una RFC transaccional debe utilizar el sufijo IN BACKGRUND TASK como el este ejemplo:
CALL FUNCIOTN ‘RFC_FUNCTION_N’
IN BACKGRPOUND TASK
DESTINATION ‘DEST’
EXPORTING…..
TABLES…..
En las RFC transaccionales, el sistema deja un log con el pedido de la llamada remota en las tablas estándar de SAP ARFCSSTATE y ARFCSDATA.
Para visualizar este log, utilizamos la transacción SM58
Cuando el programa que ejecuta la RFC ejecuta la sentencia COMMIT WORK entonces es cuando la llamada remota es enviada al sistema remoto para si ejecución.
· Asincrónicas, el programa llamador, llama a la función RFC, e inmediatamente después termina su procesamiento. Luego la función RFC se ejecuta independientemente del programa llamador. Para crear una RFC asincrónica debe utilizar el sufijo STARTING NEW TASK ej.
CALL FUNCTION RemoteFunction STARTING NEW TASK taskname
Destination…
EXPORTING…
TABLES…
EXCEPTIONS…
 
 
 
Sobre el autor
Publicación académica de Juan Hern?ndez, en su ámbito de estudios para la Carrera Consultor ABAP.
Juan Hern?ndez
Profesión: Programador Inform?tico - Espa?a - Legajo: XQ15K
✒️Autor de: 125 Publicaciones Académicas
🎓Egresado de los módulos:
Disponibilidad Laboral: PartTime
Certificación Académica de Juan Hern?ndez