SAP CPI 教程003 如何抓取Http适配器异常信息

HTTP异常信息:HTTP异常通常指HTTP状态码 中表示请求失败的那一类(4xx客户端错误,5xx服务端错误)。在日常开发、测试或访问网站时遇到它们,可以按下面的分类快速定位问

题。

1 HTTP异常分类:

1.1 4xx:客户端错误 ------ "你(浏览器/客户端)的问题"

状态码 含义 常见场景与解决方法
400 Bad Request(错误请求) 请求参数格式不对、缺少必要字段、JSON 语法错误。 解决 :检查 API 文档,确认请求头(如 Content-Type: application/json)和请求体内容。
401 Unauthorized(未授权) 未登录,或 token/API key 过期、无效。 解决 :重新登录,或在请求头中加上正确的 Authorization
403 Forbidden(禁止访问) 已经登录,但没有权限 访问该资源(比如普通用户想进管理员页面)。 解决 :确认账号权限是否正确;如果是爬虫,可能需要添加 User-Agent 或处理反爬机制。
404 Not Found(找不到资源) 请求的 URL 地址有误,或后端确实没有该接口/文件。 解决:检查 URL 拼写(路径、大小写、斜杠)、确认服务是否已部署对应的接口。
405 Method Not Allowed(方法不允许) 使用了错误的 HTTP 方法,比如用 GET 请求了一个只支持 POST 的接口。 解决:查阅文档,改用正确的方法(POST/PUT/DELETE 等)。
429 Too Many Requests(请求过多) 在单位时间内请求次数触发了限流(常用于 API 频率控制)。 解决:降低请求频率,或添加延时等待。

1.2 5xx:服务端错误 ------ "服务器(后端)的问题"

状态码 含义 常见场景与解决方法
500 Internal Server Error(内部服务器错误) 后端代码抛了未捕获的异常(如空指针、数据库连接失败、语法错误)。 解决:这是后端需要修复的问题,前端/用户只能稍后重试,或反馈给开发人员查看日志。
502 Bad Gateway(错误的网关) 网关/代理(如 Nginx)从上游服务器(如 PHP-FPM、Tomcat)收到了无效响应,上游可能挂了。 解决:重启上游服务,或检查网关与上游的配置。
503 Service Unavailable(服务不可用) 服务器过载、正在维护、或故意拒绝服务。 解决:稍后重试;如果是自己的服务,检查 CPU/内存,或看是否开启了维护模式。
504 Gateway Timeout(网关超时) 网关等了太久,上游服务器没有在规定时间内响应。常见于数据库查询慢、调用外部接口超时。 解决:优化慢查询、调长超时时间、或检查网络链路。

2 CPI环境如何抓取HTTP错误日志:

下图是整个集成流程,发送一个http请求,通过request reply调用另外一个HTTP的服务,在这个服务中特意把get请求改成post请求,模拟系统报错行为,收到异常信息后我们在流程中新增一个exception subprocess的异常信息。

注意:一定需要有个exception subprocess的接受异常信息,否者无法打印出错误的日志。

代码解释: 11 行是读取系统变量CamelExceptionCaught信息

15 判断异常类别是org.apache.camel.component.ahc.AhcOperationFailedException

18 在cpi环境打印出log日志,会在cpi中新增一个tab页签。名字是http.ResponseBody

这要http就可以通过文件的形式查看到对应的日志。

Groovy 复制代码
import com.sap.gateway.ip.core.customdev.util.Message;
import java.util.HashMap;
def Message processData(Message message) {
    def map = message.getProperties();

    def ex = map.get("CamelExceptionCaught");
    if (ex!=null) {
        
        // an http adapter throws an instance of org.apache.camel.component.ahc.AhcOperationFailedException
        if (ex.getClass().getCanonicalName().equals("org.apache.camel.component.ahc.AhcOperationFailedException")) {
            
            def messageLog = messageLogFactory.getMessageLog(message);
            messageLog.addAttachmentAsString("http.ResponseBody", ex.getResponseBody(), "text/plain");

            message.setProperty("http.ResponseBody",ex.getResponseBody());
            message.setBody(ex.getResponseBody());

            message.setProperty("http.StatusCode",ex.getStatusCode());
            message.setProperty("http.StatusText",ex.getStatusText());
            
        }
    }

    return message;

}
相关推荐
辣椒思密达10 小时前
Python HTTP请求中的重试与超时控制:提升稳定性的实用方法
开发语言·python·http
珠***格11 小时前
实操落地|防逆流装置的安装规范、调试标准与故障处置
网络·数据库·人工智能·分布式·能源·边缘计算
国科安芯11 小时前
国科安芯推出商业航天级抗辐照全双工 RS485/422 收发器 ASC491S2Y
网络·分布式·单片机·架构·安全性测试
浮芷.12 小时前
鸿蒙PC端 TTS 网络连接错误问题详解:在线/离线模式切换与网络状态管理
网络·华为·开源·harmonyos·鸿蒙·鸿蒙系统
雪度娃娃12 小时前
ASIO异步通信——多线程模型
开发语言·网络·c++·php
luj_176812 小时前
残熵算法:风险缓冲与效率优化的融合
c语言·开发语言·网络·经验分享·算法
Bobolink_12 小时前
多场次美区拍卖直播,网络资源调度与复用方案
网络·网络优化·网络调度·跨境直播·直播网络
时代文章12 小时前
UCX 官方文档和 InfiniBand 架构知识整理
网络·ai·性能优化
快乐肚皮12 小时前
【无标题】
服务器·网络·tcp/ip
YHHLAI13 小时前
前端 HTTP 请求 & LLM 接口开发
前端·网络协议·http