Как загрузить файл в weed-fs
Привет, я пытаюсь загрузить файл в weed-fs с помощью Java-клиента weed-fs. Я думаю, что я успешно установил травку согласно инструкциям того, как установить травку. Короче я
- запустить мастера с помощью команды
$./weed master
- затем объемные серверы с
$./weed volume -port=9444
мой сервер приложений уже занял порт 8080 - проверьте, что все работает, загрузив папку с помощью команды `$./weed upload -dir="any_dir_with_small_files"
На данный момент все хорошо. В моем приложении я пытаюсь опубликовать multipart/form-data
из браузера, который перехватывается сервлетом, который вызывает класс для обработки загрузки.
public void upload(HttpServletRequest request) throws FileUploadException, IOException {
client = new WeedFSClient(MASTER_ADDRESS, MASTER_PORT);
if (ServletFileUpload.isMultipartContent(request)) {
FileItemIterator fileItemIterator = new ServletFileUpload().getItemIterator(request);
InputStream inputStream = null;
while (fileItemIterator.hasNext()) {
FileItemStream item = fileItemIterator.next();
if (!item.isFormField()) {
inputStream = item.openStream();
File file = new File(request.getServletContext().getRealPath("/")+"img/uploads/"+item.getName());
FileOutputStream fos = new FileOutputStream(file);
Streams.copy(inputStream, fos, true);
RequestResult result = client.upload(file);
if (result.isSuccess()) {
System.out.println("uploaded file with ID "+result.getFid());
}
}
}
}
}
Когда я запускаю это, я получаю много отладочной информации
Info: DEBUG - Get connection for route {}->http://localhost:9444
Info: DEBUG - Connecting to localhost:9444
Info: DEBUG - CookieSpec selected: best-match
Info: DEBUG - Auth cache not set in the context
Info: DEBUG - Target auth state: UNCHALLENGED
Info: DEBUG - Proxy auth state: UNCHALLENGED
Info: DEBUG - Attempt 1 to execute request
Info: DEBUG - Sending request: POST /2,ace132597a HTTP/1.1
Info: DEBUG - >> "POST /2,ace132597a HTTP/1.1[\r][\n]"
Info: DEBUG - >> "Transfer-Encoding: chunked[\r][\n]"
Info: DEBUG - >> "Content-Type: multipart/form-data; boundary=TVf_3Jwe1DSTTHoUnZcyiA5KCVUFixPeItY3[\r][\n]"
Info: DEBUG - >> "Host: localhost:9444[\r][\n]"
Info: DEBUG - >> "Connection: Keep-Alive[\r][\n]"
Info: DEBUG - >> "User-Agent: Apache-HttpClient/4.2.5 (java 1.5)[\r][\n]"
Info: DEBUG - >> "[\r][\n]"
Info: DEBUG - >> POST /2,ace132597a HTTP/1.1
Info: DEBUG - >> Transfer-Encoding: chunked
Info: DEBUG - >> Content-Type: multipart/form-data; boundary=TVf_3Jwe1DSTTHoUnZcyiA5KCVUFixPeItY3
Info: DEBUG - >> Host: localhost:9444
Info: DEBUG - >> Connection: Keep-Alive
Info: DEBUG - >> User-Agent: Apache-HttpClient/4.2.5 (java 1.5)
Info: DEBUG - >> "1088[\r][\n]"
Info: DEBUG - >> "--TVf_3Jwe1DSTTHoUnZcyiA5KCVUFixPeItY3[\r][\n]"
Info: DEBUG - >> "Content-Disposition: form-data; name="fileBody"; filename="23.jpg"[\r][\n]"
Info: DEBUG - >> "Content-Type: text/plain[\r][\n]"
Info: DEBUG - >> "[\r][\n]"
Info: DEBUG - >> "[0xff][0xd8][0xff][0xe0][0x0][0x10]JFIF[0x0][0x1][0x1][0x1][0x0]H[0x0]H[0x0][0x0][0xff][0xe1][0x16][0xf2]Exif[0x0][0x0]II*[0x0][0x8][0x0][0x0][0x0][0x17][0x0][0x0][0x1][0x3][0x0][0x1][0x0][0x0][0x0][0x90][0x6][0x0][0x0][0x1][0x1][0x3][0x0][0x1][0x0][0x0][0x0][0x1a][0x4][0x0][0x0][0x2][0x1][0x3][0x0][0x3][0x0][0x0][0x0]"[0x1][0x0][0x0][0x6][0x1][0x3][0x0][0x1][0x0][0x0][0x0][0x2][0x0][0x0][0x0][0xf][0x1][0x2][0x0][0x6][0x0][0x0][0x0]([0x1][0x0][0x0][0x10][0x1][0x2][0x0][0x15][0x0][0x0][0x0].[0x1][0x0][0x0][0x12][0x1][0x3][0x0][0x1][0x0][0x0][0x0][0x1][0x0][0x0][0x0][0x15][0x1][0x3][0x0][0x1][0x0][0x0][0x0][0x3][0x0][0x0][0x0][0x1a][0x1][0x5][0x0][0x1][0x0][0x0][0x0]D[0x1][0x0][0x0][0x1a][0x1][0x5][0x0][0x1][0x0][0x0][0x0]L[0x1][0x0][0x0][0x1b][0x1][0x5]
это продолжается примерно как x10 высоты моего экрана, не забывая, что я установил очень маленький размер шрифта. Может кто-нибудь, пожалуйста, скажите мне, как это должно быть сделано. И я также буду признателен, если вы сможете направить меня к правильному руководству по Java-клиенту для Weed FS. Заранее спасибо.
1 ответ
Кажется, ты все делаешь правильно. Просто отключите сообщение отладки, если вы не хотите их видеть.