使用JDBC客户端检索servlet中的参数

时间:2018-06-21 14:33:02

标签: java apache servlets jdbc apache-calcite

我有一个调用servlet的JDBC客户端。

这是我的客户:

String query = "select * FROM Table";
int port = 8080;
String user = "user";
String password = "passwd";
String jdbcAvaticaURL = "jdbc:avatica:remote:url=http://localhost:"+port+";authentication=BASIC;serialization=JSON";
Connection connection = DriverManager.getConnection(jdbcAvaticaURL, user, password); // ,info);

executeQuery(connection,query);

connection.close();

这是我的servlet:

@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    request.getParameter("user"); // returns NULL
    Enumeration<String> params = request.getParameterNames(); // Empty Collection
    response.setContentType("application/json;charset=utf-8");
    response.setStatus(HttpServletResponse.SC_OK);
    // DO THINGS
}

是否可以从servlet中的DriverManager.getConnection(jdbcAvaticaURL, user, password);检索用户和密码?

当我将参数放在JDBC URL中时,我已经尝试过String auth = request.getHeader("Authorization");,它可以正常工作,我可以检索用户和密码,但这不是我想要的。

1 个答案:

答案 0 :(得分:0)

没关系,在尝试获取请求的属性,参数等之后,证明凭据就在请求中……

在servlet中进行此操作,使我可以访问客户端中用于连接的用户和密码(经过JSON解析后):

String myRequest = request.getReader().lines().collect(Collectors.joining(System.lineSeparator()));