我有一个调用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");
,它可以正常工作,我可以检索用户和密码,但这不是我想要的。
答案 0 :(得分:0)
没关系,在尝试获取请求的属性,参数等之后,证明凭据就在请求中……
在servlet中进行此操作,使我可以访问客户端中用于连接的用户和密码(经过JSON解析后):
String myRequest = request.getReader().lines().collect(Collectors.joining(System.lineSeparator()));