Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Java: Работа с сетью > Linux + setContentType(application/exel)


Автор: Den1s 6.11.2007, 10:44
Имею примерно следующий кусок кода где arg1 это HttpServletResponse
Код

try {
                  arg1.setContentType(contentType);
                  arg1.setContentLength(content.length);
                  arg1.getOutputStream().write(content);      
                  arg1.getOutputStream().close();
                
                  } catch (Exception e) {
                  logger.error(e);
                  }


так вот на Linux'ах если contentType является 'application/pdf' или 'application/exel' catch ловит следующий эксепшн

ClientAbortException:  java.net.SocketException: Connection reset



На Windows этот эксепшн вываливается если при появлении окошка Открыть Сохранить Отмена нажать Отмена, но на Линуксе это окно сохранения вообще не появляется и эксепшн вываливается. Есть подозрения что дело в том что на линуксе нет программ поддерживающих эксель или пдф, но тем не менее сохранение файлов должно работать, подскажите плз что нужно исправить чтобы работало?

Спасибо.

P.S. если это имеет значение приложение работает на сервере Tomcat 6

Автор: Kangaroo 6.11.2007, 11:32
Попробуй так для екселя:
Код

response.setContentType( "application/vnd.ms-excel" );                
response.setHeader("Content-Disposition", "attachment;filename=nameOfFile.xls");

Автор: Den1s 6.11.2007, 12:22
Цитата(Kangaroo @ 6.11.2007,  11:32)
Попробуй так для екселя:
Код

response.setContentType( "application/vnd.ms-excel" );                
response.setHeader("Content-Disposition", "attachment;filename=nameOfFile.xls");

Неа, не помогло:( то же самое, валится на arg1.getOutputStream().write(content);       Такое ощущение что Отменить как то автоматически указывается:( может какие еще идеи будут? smile 

Автор: Kangaroo 6.11.2007, 13:04
Поспрашивал/почитал.
Для Винды(когда жмешь отмену) он считается нормальным, просто Tomcat не смог записать в поток, так как браузер его закрыл.
Может в Линуксе по другой причине не работает, а не из-за этого иксепшна?

Автор: Borisff2003 6.11.2007, 13:11
Цитата

arg1.getOutputStream().close();

А вот это точно надо делать?
У тебя на каком операторе все вываливается?

Автор: Den1s 6.11.2007, 13:16
Цитата(Kangaroo @ 6.11.2007,  13:04)
Поспрашивал/почитал.
Для Винды(когда жмешь отмену) он считается нормальным, просто Tomcat не смог записать в поток, так как браузер его закрыл.
Может в Линуксе по другой причине не работает, а не из-за этого иксепшна?

Ну для Винды это понятно, я тоже читал что это стандартный эксепшн. Но дело в том что в моем случае под Виндой все работает (появляется попапина сохранения файла), а в Линуксе она не появляется и в любом случае валится на строке arg1.getOutputStream().write(content); с вышеописанным эксепшеном. Причем это происходит только для pdf и excel файлов, в виде HTML все экспортиться отлично. Опять же если я уберу ContentType вообще то файлы сохраняются. Т.е. методом эксперимента было обнаружено что виновато скорей всего 
response.setContentType( "application/vnd.ms-excel" );     видимо application/vnd.ms-excel или же application/excel почему то не проходит в Линухе, но я не могу понять почему(((

Добавлено через 3 минуты и 5 секунд
Цитата(Borisff2003 @ 6.11.2007,  13:11)
Цитата

arg1.getOutputStream().close();

А вот это точно надо делать?
У тебя на каком операторе все вываливается?

валится на 

Код

arg1.getOutputStream().write(content);



Да, я знаю что
Цитата

arg1.getOutputStream().close();


необязательно, т.к. Томкат сам закрывает потоки, но если я уберу эту строку ничего не изменится:(

Автор: Borisff2003 6.11.2007, 13:44
Я делал так 
Код

response.setContentType("application/vnd.ms-excel"); 
response.addHeader("Content-Disposition", "attachment;filename=data.xls");

а вот в этом я тоже не уверен
Цитата

arg1.setContentLength(content.length);


У меня в linuxe firefox открывает без проблем, OpenOffice пподхватил smile


Автор: Den1s 6.11.2007, 17:08
Цитата(Borisff2003 @ 6.11.2007,  13:44)
Я делал так 
Код

response.setContentType("application/vnd.ms-excel"); 
response.addHeader("Content-Disposition", "attachment;filename=data.xls");

а вот в этом я тоже не уверен
Цитата

arg1.setContentLength(content.length);


У меня в linuxe firefox открывает без проблем, OpenOffice пподхватил smile

На той машине где я тестирую и находится сервер программы OpenOffice не установлен, тестирую я со своей машины у меня Windows и OpenOffice стоит но файл не сохранялся...Вообщем сменил я код на следующий:

Код

try {

                  arg1.setContentType("application/vnd.ms-excel;charset=UTF-8");
                  arg1.setHeader("Content-Disposition","attachment;filename=report.xls");
                  arg1.setContentLength(content.length);
                  ServletOutputStream outStream = arg1.getOutputStream();
                  outStream.write(content,0,content.length);      
                  outStream.close();
                
                  } catch (Exception e) {
                   logger.error(e);
                  }


Эксепшена теперь нет и вроде все нормально проходит, но тем не менее Окно для сохранения не появляется, т.е. ошибок нет но и ничего не происходит, и как следствие файл не сохраняется и не открывается причем это только с эксельными файлами такое, со всеми остальными все работает нормально.

Автор: LSD 6.11.2007, 17:49
Попробуй поставить ContentType - binary/octet-stream.

Автор: Den1s 6.11.2007, 19:12
К сожалению и  ContentType - binary/octet-stream не помогает. Видимо тут какая то проблема Linux и сохранения файлов с расширением xls. Будем копать. smile 

Автор: Den1s 8.11.2007, 11:46
вообщем на данный момент я пришел к следующей аномалии, если вводить адрес через хост например http://localhost:8080/myapp/report/report.xls то все сохраняется нормально, если же использовать айпишник например http://127.0.0.1:8080/myapp/report/report.xls то валится ClientAbortException:  java.net.SocketException: Connection reset и файл не сохраняется, есть мнения по этому поводу?

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)