JAVA调用SAP ODATA服务

本文详细介绍了在JAVA中调用SAP ODATA服务时遇到的问题及解决方案,包括处理401未经授权错误、POST方法地址使用、CSRF跨域问题以及403错误。文中提供了解决这些问题的代码示例,包括设置HTTP HEADER、处理Cookie和XML解析等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

梳理一下,JAVA调下SAP ODATA服务过程中遇到的一些坑。

1、(401) 未经授权;

       解决方法:将用户名密码加密后,添加到HTTP HEADER中。

String auth = "ZRFC" + ":"  + "Init1234";

        String encodeAuth = "Basic " + new String(Base64.getEncoder().encode(auth.getBytes(StandardCharsets.UTF_8)));

        connection.setRequestProperty("Authorization", encodeAuth);

2POST方法地址;

    解决方法:要先用GET方法从去调用ODATAGET_ENTIY方法,例如:http://vhcals4h.com:44301/sap/opu/odata/sap/ztest_srv/HEADERSet('5000000001'),然后再将返回内容作为表身,传到ENTITYSET地址,如http://vhcals4h.com:44301/sap/opu/odata/sap/ztest_srv/HEADERSet('5000000001')

3CSRF跨域问题;

    解决方法:先用GET方法取到TOKEN再放到POST HEADER中。

String csrfToken = connection.getHeaderField("X-CSRF-Token");

connPost.setRequestProperty("X-CSRF-Token", csrfToken);

4403错误;

    解决方法:添加Cookie支持。

//添加cookie支持

    CookieManager manager = new CookieManager();

    //设置cookie策略,只接受与你对话服务器的cookie,而不接收Internet上其它服务器发送的cookie

        manager.setCookiePolicy(CookiePolicy.ACCEPT_ORIGINAL_SERVER);

        CookieHandler.setDefault(manager);

        System.out.println(manager.getCookieStore());

另外还涉及到一些XML解析,以下为完整代码,包含GETPOST方法:

package odata_test;

import java.io.BufferedReader;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值