JavaXMLA代理类

JavaXMLA代理类,java,kendo-ui,xmla,Java,Kendo Ui,Xmla,我需要在Java上编写一个XMLA代理类,它一边与cube Mondrian或MS SSAS通信,另一边与Kendo UI PivotGrid通信。它必须做两件事: 在OLAP服务器上进行自动化 将查询从UI转换为OLAP多维数据集并返回 Kendo PivotGrid可以直接连接到XMLA服务器,但这不是个好主意,因为客户端浏览器可以读取连接所需的用户和密码。所以,我决定写一个代理,隐藏它们 假设是这样,您能为如何实现它提供一些指导吗?经过一些研究,我在olap4j源代码中找到了解决方案。这里

我需要在Java上编写一个XMLA代理类,它一边与cube Mondrian或MS SSAS通信,另一边与Kendo UI PivotGrid通信。它必须做两件事:

在OLAP服务器上进行自动化 将查询从UI转换为OLAP多维数据集并返回 Kendo PivotGrid可以直接连接到XMLA服务器,但这不是个好主意,因为客户端浏览器可以读取连接所需的用户和密码。所以,我决定写一个代理,隐藏它们


假设是这样,您能为如何实现它提供一些指导吗?

经过一些研究,我在olap4j源代码中找到了解决方案。这里有一个chenged方法,org.olap4j.driver.xmla.proxy.XmlaOlap4jAbstractHttpProxy类的成员


我面临着同样的问题;你写代理了吗?你是否使用了你在答案中发布的课程?thanks@ps0604是的,很管用。我已经改变了一些与领域相关的东西,比如安全性,但主要思想和代码仍然是一样的
public byte[] getResponse(String server_url, String request) throws IOException {
    URLConnection urlConnection = null;
    try {
        URL url = new URL(server_url);
        urlConnection = url.openConnection();
        urlConnection.setDoOutput(true);
        // Set headers
        urlConnection.setRequestProperty("content-type", "text/xml; charset=".concat("UTF-8"));
        urlConnection.setRequestProperty("User-Agent", "Olap4j");
        urlConnection.setRequestProperty("Accept", "text/xml;q=1");
        urlConnection.setRequestProperty("Accept-Charset", "UTF-8;q=1");
        urlConnection.setRequestProperty("Accept-Encoding", "gzip"); // Tell the server that we support gzip encoding
        // Some servers expect a SOAPAction header.
        if (request.contains("DISCOVER")) {
            urlConnection.setRequestProperty("SOAPAction", "\"urn:schemas-microsoft-com:xml-analysis:Discover\"");
        } else if (request.contains("EXECUTE")) {
            urlConnection.setRequestProperty("SOAPAction", "\"urn:schemas-microsoft-com:xml-analysis:Execute\"");
        }
        // Send data (i.e. POST). Use same encoding as specified in the
        // header.
        final String encoding1 = "UTF-8";
        urlConnection.getOutputStream().write(request.getBytes(encoding1));
        // Get the response, again assuming default encoding.
        InputStream is = urlConnection.getInputStream();
        // Detect that the server used gzip encoding
        String contentEncoding =
                urlConnection.getHeaderField("Content-Encoding");
        if ("gzip".equals(contentEncoding)) {
            is = new GZIPInputStream(is);
        }
        final ByteArrayOutputStream baos = new ByteArrayOutputStream();
        byte[] buf = new byte[1024];
        int count;
        while ((count = is.read(buf)) > 0) {
            baos.write(buf, 0, count);
        }
        return baos.toByteArray();
    } catch (Exception e) {
        // In order to prevent the JDK from keeping this connection
        // in WAIT mode, we need to empty the error stream cache.
        final int espCode =
                ((HttpURLConnection) urlConnection).getResponseCode();
        InputStream errorStream =
                ((HttpURLConnection) urlConnection).getErrorStream();
        final ByteArrayOutputStream baos =
                new ByteArrayOutputStream();
        final byte[] buf = new byte[1024];
        int count;
        if (errorStream != null) {
            while ((count = errorStream.read(buf)) > 0) {
                baos.write(buf, 0, count);
            }
            errorStream.close();
        }
        baos.close();
    }
    return null;
}