✒️ABAP Los módulos de funciones RFC
ABAP Los módulos de funciones RFC
MÓDULOS 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 pude darse entre sistemas SAP y otro sistema que no sea SAP. Para llamar a una función 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 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 el ambiente DCR, crearíamos una RFC en DTR que devuelva los registros de los clientes. Luego llamaríamos a esta función en el ambiente DCR, utilizando un destino que previamente hemos creado a través de la transacción SM59.
Si se produjera un error en la ejecución 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 función RFC se crea de la misma manera que se crea una función. Se accede a la transacción SE37 y se completan los mismo parámetros que completamos para crear una función a excepción de que se debe seleccionar en la solapa de Atributos la opción Modulo de acceso remoto (Remoto Enabled Module).
Los parámetros que se crean en una función RFC no se pueden pasar por Referencia, deben pasarse por valor. Esto se logra tildanso el check Transportar valores (pass value) para cada parámetro en las solapas IMPORT, EXPORT y CHANGING.
Una vez, las funciones creadas como RFC, pueden ser utilizadas como módulos de funciones normales. Esto se logra de dos maneras diferentes:
· Utilizando la declaración de un módulo de función normal, sin el agregado de la cláusula DESTINATION.
TIPOS DE RFC
Existen tres tipos de RFC.
· 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 llamados son almacenados en el sistema junto con los datos. Para crear una RFC transaccional debo utilizar el sufijo IN BACKGROUND TASK.
Transacción SM58
Transacción estándar del sistema SAP que nos permite visualizar el log de errores de las RFC transacciones que se ejecutan en el sistema.
Cuando el programa que ejecuta la RFC ejecuta la sentencia COMMIT WORK, entonces es cuando la llamada remota es enviada al sistema remoto para su ejecución.
Utilizaremos el tipo de RFC transaccional para ciertos casos específicos 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.
No es posible debaguear una función remota de otro sistema sin embargo cuando estamos probando una llamada o una RFC desde un sistema SAP a otro sistema SAP podemos utilizar el debugging para monitorear la ejecución de la función RFC en el sistema remoto. Con la llamadas remotas el debugging ABAP se ejecuta en el sistema local, los valores de los datos y otra información de ejecución de la función remota son pasados al sistema remoto.
 
 
 
Sobre el autor
Publicación académica de Jean Carlos Lopez Uzcategui, en su ámbito de estudios para la Carrera Consultor ABAP.
Jean Carlos Lopez Uzcategui
Profesión: Sistemas - Venezuela - Legajo: HS82J
✒️Autor de: 53 Publicaciones Académicas
🎓Egresado del módulo:
Disponibilidad Laboral: FullTime
Certificación Académica de Jean Lopez