✒️ABAP Los módulos de funciones RFC
ABAP Los módulos de funciones RFC
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.
Para llamar a una funcion RFC se debe agregar la cláusula DESTINATION al momento de declarar la función.
La RFC llamada no existe en el sistema origen pero sí debe existir en el sistema destino.
Cuándo usaríamos una RFC?
Si quisiéramos leer un registro de un cliente del sistema o ambiente DCR a través de un programa ABAP existente en el ambiente DTR crearíamos una RFC en DCR que devuelva los registros de los clientes.
Luego llamaríamos a esta funcion en el ambiente DTR usando un destino que previamente hemos creadoa través de la transaccion SM59.
DCR es un ej.puede ser un ambiente de Produccion y DCT el ambiente desarrollo.
Ejemplo:
En el sistema DTR, creo la RFC
CALL FUNCTION ZOBTENER_CLIENTES
DESTINATION V_DCR
EXPORTING KUNNR = V_CLIENTE
TABLES CUSTOMER = T_CLIENTES
EXCEPTIONS NO_RECORD_FOUND = 01
En el Sistema DCR, llamo a la RFC
FUNCTION ZOBTENERCLIENTES.
..."Leo el registro del cliente"
ENDFUNCTION.
Si se produjera un error en la ejecucion de una RFC, los mensajes de error son devueltos por el sistema remoto y alojados en las variables del sistema SY-MSGID, SY-MSGNO, SY-MSGV1, SY-MSGV2, SY-MSGV3 y SY-MSGV4.
Como crear una RFC?
Una funcion RFC se crea de la misma manera que se crea una función.
Se accede a la transaccion SE37 y se completan los mismos parámetros que completamos para crear una funcion a excepción de que se debe seleccionar en la solapa de Atributos la opción Módulo 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' para cada parámetro en las solapas IMPORT, EXPORT y CHANGING.
A su vez, las funciones creadas como RFC se pueden usar como modulo de funcion Normales de dos maneras diferentes:
-Usando la declaración CALL FUNCION DESTINATION 'NONE'
-Usando la declaración de un modulo de funcion normal, sin el agregado de la clausula DESTINATION.
Tipos de RFC
Hay tres tipos de RFC:
-Sincrónicas: ambos sistemas deben estar disponibles al momento de la llamada de la funcion. Estar RFC están basadas en una comunicación sincronica.
Generalmente usamos el tipo de RFC sincronico para la mayoría de nuestros desarrollos.
-Transaccionales: los sistemas no necesitan estar disponibles al momento de la llamada de la funcion. Se genera un único ID de transacción y los programas llamados son almacenados en el sistema junto con los datos. Para crear una RFC transaccional se debe usar el sufijo IN BACKGROUND TASK. Ejemplo:
CALL FUNCTION 'RFC_FUNCTION_N'
IN BACKROUND TASK
DESTINATION ' DEST '
EXPORTING ...
TABLES ... .
En las RFC transacciones el sistema deja un blog con el pedido de la llamada remota en las tablas estandar de SAP ARFCSSTATE y ARFCSDATA con todos los valores de los parametros pasados en la ejecucion.
Tablas ARFCSSTATE y ARFCSDATA: Son tablas estándar de SAP que almacenan informacion relacionada a la llamada de RFC transacciones en el sistema.
Transacción SM58: Permite visualizar el log de errores de las RFC transaccionales que se ejecutaron en el sistema.
Cuando el programa que ejecuta la RFC ejecuta la sentencia COMMIT WORK es cuando la llamada remota es enviada al sistema remoto para su ejecución.
Usaremos el tipo de RFC transaccional para ciertos casos especificos de actualizaciones donde no se requiera que dichas actualizaciones se realicen en forma inmediata sino recién cuando el programa llamador ejecuta un COMMIT WORK.
-Asincrónicas: el programa llamador, llama a la funcion RFC e inmediatamente después termina su procesamiento. Luego la funcion RFC se ejecuta independientemente del programa llamador. Para crear una RFC asincronica se debe usar el sufijo STARTING NEW TASK.
Ejemplo:
CALL FUNCTION RemoteFunction STARTING NEW TASK taskname
Destination ...
EXPORTING ...
TABLES ...
EXCEPTIONS ...
Audio Tips:
No es posible debuggear una llamada a una funcion remota de otro sistema, sin embargo, cuando estamos probando una llamada a una RFC desde un sistema SAP a otro sistema SAP podemos usar el debugger para monitorear la ejecución de la función RFC en el sistema remoto. Con las llamadas remotas el debugger ABAP se ejecuta en el sistema local, los valores de los datos y otra información de ejecución de la función remota pasan al sistema remoto.
 
 
 
Sobre el autor
Publicación académica de Carlos Alberto Carreira, en su ámbito de estudios para la Carrera Consultor ABAP.
Carlos Alberto Carreira
Profesión: Consultor Técnico en Jde W.s. - Argentina - Legajo: KC15G
✒️Autor de: 92 Publicaciones Académicas
🎓Cursando Actualmente: Consultor ABAP Nivel Inicial
🎓Egresado de los módulos:
Certificación Académica de Carlos Carreira