✒️ABAP Los módulos de funciones RFC
ABAP Los módulos de funciones RFC
- Consiste en una llamada a un módulo de funciones que existen un sistema SAP o no SAP, distinto al sistema del programa en donde se realiza la llamada del módulo de funciones. Es decir en un programa abap llamamos a un módulo de funciones que no existe en el sistema donde nos encontramos sino que existen otros sistemas SAP o no SAP con el que nos comunicamos.
- Su objetivo principal es acceder a otros ambientes del sistema para obtener datos. La comunicación puede darse entre sistemas SAP o entre un sistema SAP y otro sistema que no sea SAP
- Para llamar a un modo de funciones RFC se debe agregar la cláusula destination al momento de declarar el módulo de funciones
- El módulo de funciones RFC llamado no existe en el sistema origen pero sí debe existir en el sistema destino
- SM59: Configuración de las conexiones RFC) Nos permite en SAP, realizar la configuración de las conexiones remotas RFC (Remote Function Call). Se pueden crear, borrar y modificar Conexiones R/3, Conexiones internas, Destinos lógicos, Conexiones TCP/IP y conexiones con driver ABAP.
Ejemplo:
En el ambiente DTR creamos el módulo de funciones RFC.
FUNCTION ZOBTENER_CLIENTES
"LEEMOS EL REGISTRO DEL CLIENTE.
ENDFUNCTION.
En el ambiente DCR llamamos al módulo de funciones RFC:
CALL FUNCTION 'ZOBTENER_CLIENTES'
Destination | V_DCR |
Exporting | KUNNR=V_CLIENTE |
Tables | CUSTOMER=TI_CLIENTES |
Exceptions | NO_RECORD_FOUND=01 |
- Si se produjera un error en la ejecución de un módulo de funciones RFC Entonces los mensajes de error serán devueltos por el sistema remoto y alojados en las siguientes variables de sistema:
- SY-MSGID
- SY-MSGTY
- SY-MSGNO
- SY-MSGV1
- SY-MSGV2
- SY-MSGV3
- SY-MSGV4
¿Cómo crear un módulo de funciones RFC?
- Se creó de la misma manera que se crea un módulo de funciones normal.
- Debemos acceder a la biblioteca de funciones correspondiente a la transacción estándares de 37 y completar los mismos parámetros que se completaron para crear un módulo de funciones normal, a excepción de que se debe seleccionar en la solapa atributos la opción módulo de acceso remoto.
- Los parámetros que se crean en un módulo de funciones RFC no se pueden pasar por referencia, sino que deben pasarse por valor Esto se logra tildando el check transportar valores para cada parámetro en las solapas import, export y changing.
- Los módulos de funciones creados como RFC pueden ser utilizados como módulos de funciones normales Esto se logra de dos maneras diferentes: Utilizando la declaración CALL FUNCTION DESTINATION 'NONE' , utilizando la declaración de un módulo de función normal, sin el agregado de la cláusula DESTINATION.
Tipos de módulos de funciones RFC.
- Sincrónicos: en donde ambos sistemas coman es decir el sistema origen y el sistema de destino deben estar disponibles al momento de la llamada del módulo de funciones. Estos módulos de funciones RFC están basados en una comunicación sincrónica punto Generalmente utilizaremos el tipo de módulos de funciones rfc sincrónico para la mayoría de nuestros desarrollos en ABAP
- Transaccionales: en donde los sistemas de origen y de destino no necesitan estar disponibles al momento de la llamada al módulo de funciones. Un único ID de transacciones generado y los programas llamados son almacenados en el sistema junto con los datos punto de funciones debemos utilizar el sufijo in background task. El sistema deja un log con el pedido de la llamada remota en las tablas base de datos estándar de SAP ARFCSSTATE Y ARFCSDATA con todos los valores de los parámetros pasados en ejecución.
- TABLAS ARFCSSTATE Y ARFCSDATA: son tablas bases de datos estándar de sistemas app que almacenan información relacionada a la llamada de módulos de funciones RFC transaccionales en el sistema. Para visualizar el log utilizaremos la transacción estándar sm58
- Tx SM58 : transacción estándar de sistemas app que nos permite visualizar el log de errores de los módulos de funciones rfc transaccionales que se ejecutaron en el sistema
- Cuando el programa que ejecuta el módulo de funciones RFC se ejecuta la sentencia commit work, Entonces es cuando la llamada remota es enviada al sistema remoto para su ejecución
- Utilizaremos el tipo de módulo de funciones 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 la sentencia commit work.
- Asincrónicos: en donde el programa llamador llama al módulo de funciones RFC e inmediatamente después termina su procesamiento luego el módulo de funciones RFC se ejecuta independientemente del programa llamador punto para crear un módulo de funciones RFC asíncrono debemos utilizar el sufijo starting new task.
- No es posible debuggear una llamada de otro sistema, sin embargo se puede utilizar para monitorear el módulo de funciones RFC.
 
 
 
Sobre el autor
Publicación académica de Alejandra Daniela Naranjo Belmonte, en su ámbito de estudios para la Carrera Consultor ABAP.
Alejandra Daniela Naranjo Belmonte
Profesión: Analista/desarrollador de Software - Mexico - Legajo: ON48V
✒️Autor de: 63 Publicaciones Académicas
🎓Egresado del módulo:
Certificación Académica de Alejandra Naranjo