SAP调用Web Service全流程详解

在企业应用集成中,SAP系统经常需要与外部系统通过Web Service进行数据交互。本文将基于一份实际操作文档,详细讲解如何在SAP中调用外部Web Service,涵盖从代理类创建、逻辑端口配置到代码调用的完整流程。


一、概述

SAP调用外部Web Service通常分为三个核心步骤:

  1. 创建代理类 – 通过SE80事务码,基于WSDL生成SAP端的代理类
  2. 配置逻辑端口 – 使用LPCONFIG为代理类配置连接信息
  3. 编写调用代码 – 在ABAP程序中实例化代理类并调用方法

下面我们逐步展开说明。


二、SE80创建代理类

在这里插入图片描述


在这里插入图片描述

代理类(Proxy Class)是SAP内部对外部Web Service的本地映射,它封装了SOAP通信细节,使ABAP程序可以像调用本地类一样调用远程服务。

操作步骤:

  1. 进入SE80,选择“企业服务” → “服务创建” → “服务生成”
  2. 输入WSDL地址,系统将解析服务定义
  3. 选择需要生成的服务和操作
  4. 指定包和传输请求,生成代理类及相关结构

生成后的代理类包含:

  • 一个主代理类(如ZPSI_QLTCO_UPLOADER_SAP
  • 对应的输入/输出结构(如ZPSI_QLTUPLOAD_DATA_REQUEST
  • 异常类

三、LPCONFIG配置逻辑端口

在这里插入图片描述


在这里插入图片描述

逻辑端口(Logical Port)用于存储Web Service的终端地址、认证信息等连接配置,实现代理类与物理地址的解耦。

配置过程:

  1. 运行LPCONFIG事务码
  2. 选择“创建逻辑端口”
  3. 输入端口名称(如ZPSI_QLT_DEV),选择代理类
  4. 配置目标地址(URL)、认证方式等
  5. 保存激活

关键说明:

  • 逻辑端口可按环境(开发、测试、生产)分别配置
  • 若生产地址变更,只需修改或新建逻辑端口,无需重新生成代理类

四、ABAP调用示例

以下是一个典型的调用代码框架,包含异常处理和XML数据传输:

DATA: g_obj TYPE REF TO zpsi_qltco_uploader_sap, err_obj TYPE REF TO cx_ai_system_fault, err_meth TYPE REF TO cx_ai_system_fault, err_meth2 TYPE REF TO cx_ai_application_fault, err_tran TYPE REF TO cx_transformation_error. " 根据客户端选择逻辑端口 TRY. IF sy-mandt = '800'. " 生产机 ELSE. " 测试机 CREATE OBJECT g_obj EXPORTING logical_port_name = 'ZPSI_QLT_DEV'. ENDIF. CATCH cx_ai_system_fault INTO err_obj. " 处理创建异常 ENDTRY. " 使用ST(Simple Transformation)生成XML DATA: p_xml TYPE string. TRY . CALL TRANSFORMATION zpsif_qtl SOURCE root = pt_trans[] RESULT XML p_xml OPTIONS xml_header = 'no'. CATCH cx_transformation_error INTO err_tran. " 处理转换异常 ENDTRY. " 添加XML头部 CONCATENATE '<?xml version="1.0" encoding="UTF-8"?>' p_xml INTO p_xml. " 准备输入参数并调用Web Service DATA: lv_input TYPE zpsi_qltupload_data_request, lv_res TYPE zpsi_qltupload_data_response. lv_input-xml_data = p_xml. TRY. CALL METHOD g_obj->upload_data EXPORTING upload_data_request = lv_input IMPORTING upload_data_response = lv_res. CATCH cx_ai_system_fault INTO err_meth. " 处理系统异常 CATCH cx_ai_application_fault INTO err_meth2. " 处理应用异常 ENDTRY. 

五、关键注意事项

  1. 环境隔离:开发、测试、生产环境应使用不同的逻辑端口,避免配置冲突
  2. 异常处理:必须捕获并处理CX_AI_SYSTEM_FAULTCX_AI_APPLICATION_FAULT等异常
  3. XML处理
    • 使用ST或XSLT生成XML数据
    • 注意编码和特殊字符转义
    • 部分场景下需手动调整XML字符串(如文档中提到的“去掉乱码字符”)
  4. 代理类查看:可通过SE24查看代理类的方法签名和数据结构

六、总结

通过SE80创建代理类、LPCONFIG配置逻辑端口、ABAP调用三步,SAP系统即可安全、灵活地调用外部Web Service。这种方式将外部服务封装为本地对象,提高了代码的可维护性和环境适配性,是企业系统集成中的常用实践。

Read more

基于AI WebUI Chatbot的实战开发:从架构设计到生产环境部署

快速体验 在开始今天关于 基于AI WebUI Chatbot的实战开发:从架构设计到生产环境部署 的探讨之前,我想先分享一个最近让我觉得很有意思的全栈技术挑战。 我们常说 AI 是未来,但作为开发者,如何将大模型(LLM)真正落地为一个低延迟、可交互的实时系统,而不仅仅是调个 API? 这里有一个非常硬核的动手实验:基于火山引擎豆包大模型,从零搭建一个实时语音通话应用。它不是简单的问答,而是需要你亲手打通 ASR(语音识别)→ LLM(大脑思考)→ TTS(语音合成)的完整 WebSocket 链路。对于想要掌握 AI 原生应用架构的同学来说,这是个绝佳的练手项目。 从0到1构建生产级别应用,脱离Demo,点击打开 从0打造个人豆包实时通话AI动手实验 基于AI WebUI Chatbot的实战开发:从架构设计到生产环境部署 痛点分析:Web端AI对话系统的常见挑战 开发一个真正可用的AI对话系统时,往往会遇到几个关键问题: * 高延迟体验差:传统HTTP请求-响应模式需要等待AI生成完整回复,

前端高频面试题Vue3、TypeScript

前端高频面试题Vue3、TypeScript

■ 符号说明 💘 课题 🐝 企业级面试题 ⭐️ 重要知识点 🌛 需要有影响 神龙教主 💘 初探、模板与指令 ⭐️ 谈谈你对vue的理解,有哪些重要的版本,vue3新增了哪些新特性 渐进式javascript框架 2013诞生 =》 2016发布2.0 =》 2019发布2.6 =》 2020.9 3.0 海贼王 =》 2021.8 3.2 script setup语法 Vue 3 中需要关注的一些新特性包括 * 组合式 API* vue3发展史:先是和vue2类似的语法选项式API、和原生js类似的语法组合式API 方便封装组合 * 单文件组件中的组合式 API 语法糖 ( setup函数中写 const a = 1 直接script脚本中写 const a= 1 * Teleport 组件

AI Skills:前端新的效率神器!

近来,AI 领域有个火爆的话题:Skills。 Github 上被疯狂 star 的仓库,很多都是和 skills 有关的。 有的仓库仅仅上线三个月就获得了快 50K 的 star,Skills 的火热可见一斑。 不管是大模型,还是 Cursor、Codex、Claude、Trae、Copilot 等编程 IDE 都在争先支持 Skills。 围绕 Skills,它们在做的就是为了完成一件事情:技能是通过学习和反复练习获得的,而 Skills 是把经验和最佳实践沉淀为 AI 能力,将“知道”转化为“做到”的本领。 详解什么是 Skills 要说清楚什么是 Skills,先来了解一下关于 AI 的 2

B站PC端web自动开启字幕脚本(2026新版适配)

B站自动字幕用户脚本:快捷键开关 + 自动开启字幕(2026新版适配) 作者:Apixus 更新日期:2026年3月5日 项目地址:GitHub仓库 一、脚本介绍 你是否经常在B站看视频时反复手动开启字幕?是否希望切换视频时字幕能自动开启? 这个用户脚本就是为了解决这些问题而开发的。 B站自动字幕脚本 提供了以下功能: * 🎯 快捷键控制:按 C 键快速开启或关闭字幕 * 🔄 自动开启:切换分P、点击推荐视频时自动打开字幕 * 🆕  2026新版适配:专为B站最新版播放器优化 * ⚡ 性能优化:智能监听,告别卡顿轮询 * 🛡️ 防冲突:自动识别输入框,避免误触 二、适用页面 * 普通视频页:https://www.bilibili.com/video/* * 播放列表页:https://www.bilibili.com/list/* 支持普通视频页、番剧页、播放列表页等常见场景。 三、