我是ICEfaces的新手,我有一个要求,我需要从给定的网址(http://ipaddress/formexec?objectid=201)下载文件。
此网址使用通过ICEFaces部署的基于表单的身份验证。
我跟踪了此网址的请求,并获得以下内容:
&ice.submit.partial=false&ice.event.target=loginForm%3Aj_id33&ice.event.captured=loginForm%3Aj_id33
是否有任何库或代码可通过成功传递用户名和密码来下载文档。
答案 0 :(得分:1)
您需要从jsessionid
响应标头中提取Set-Cookie
,并将其作为网址属性附加到后续请求http://example.com/path/page.jsf;jsessionid=XXX
。
以下是“普通香草”java.net.URLConnection
的帮助下的启动示例:
// Prepare stuff.
String loginurl = "http://example.com/login";
String username = "itsme";
String password = "youneverguess";
URLConnection connection = null;
InputStream response = null;
// First get jsessionid (do as if you're just opening the login page).
connection = new URL(loginurl).openConnection();
response = connection.getInputStream(); // This will actually send the request.
String cookie = connection.getHeaderField("Set-Cookie");
String jsessionid = cookie.split(";")[0].split("=")[1]; // This assumes JSESSIONID is first field (normal case), you may need to change/finetune it.
String jsessionidurl = ";jsessionid=" + jsessionid;
response.close(); // We're only interested in response header. Ignore the response body.
// Now do login.
String authurl = loginurl + "/j_security_check" + jsessionidurl;
connection = new URL(authurl).openConnection();
connection.setDoOutput(true); // Triggers POST method.
PrintWriter writer = new PrintWriter(new OutputStreamWriter(connection.getOutputStream()));
writer.write("j_username=" + URLEncoder.encode(username, "UTF-8")
+ "&j_password=" + URLEncoder.encode(password, "UTF-8"));
writer.close();
response = connection.getInputStream(); // This will actually send the request.
response.close();
// Now you can do any requests in the restricted area using jsessionid. E.g.
String downloadurl = "http://example.com/download/file.ext" + jsessionidurl;
InputStream download = new URL(downloadurl).openStream();
// ...
要使用较少膨胀的代码实现相同目标,请考虑Apache Commons HttpComponents Client。
答案 1 :(得分:0)
基于表单的身份验证与其他请求没有太大区别。您所要做的就是向auth表单提交一个请求,提供所需的参数,例如用户和密码,在某些情况下还需要从源页面获取的额外令牌。然后,您需要从auth响应或会话ID参数中获取cookie,并将它们复制到下一个将获取数据的请求中。