梳理一下,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);
2、POST方法地址;
解决方法:要先用GET方法从去调用ODATA中GET_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')。
3、CSRF跨域问题;
解决方法:先用GET方法取到TOKEN再放到POST HEADER中。
String csrfToken = connection.getHeaderField("X-CSRF-Token");
connPost.setRequestProperty("X-CSRF-Token", csrfToken);
4、403错误;
解决方法:添加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解析,以下为完整代码,包含GET和POST方法:
package odata_test;
import java.io.BufferedReader;