Загрузка файлов в Struts 2 не начнется - PullRequest
0 голосов
/ 27 апреля 2018

У меня есть следующий код стойки. Я пытаюсь скачать CSV-файл, но ничего не происходит, когда я нажимаю кнопку загрузки. Я не получаю никаких ошибок, и в JavaScript я получаю успешный ответ. Функция Myy post также регистрирует мой csv-контент на консоли браузера. Я не понимаю, почему загрузка файла не начинается.

Вот мой JSP:

<%@ taglib prefix="s" uri="/struts-tags"%>
<div>
    <div>


    <h4>Information</h4>
        <div class="tab-pane" id="login">
                <div class="panel panel-default">
                    <form id = "info" class="form-horizontal">
                        <div >
                            <label>FName</label>
                            <span style="float:right"><s:property value="%{fName}" 
     </span>

                        </div>
                        <div>
                            <label>MName or Initial</label>
                            <span style="float:right"><s:property value="%{mName}"/></span>

                        </div>  
                        <div>
                            <label>LName</label>
                            <span style="float:right"><s:property value="%{lName}"/></span>

                        </div>  
                </form>
            </div>
        </div>
        </div>
        <div class="footer">
              <button type="button" class="btn btn-primary" onClick="download();">Download</button>          
            </div>
    </div>



    <script>
    function download(){
        var action = 'download.action';
        var meth = 'post';
        var fields = jQuery("#info").children();
        var params = [];
        for(var i=0; i<fields.length;i++){
            var field = fields[i];
            var nodes = jQuery(field).children();
            if(nodes.length == 2){
                params.push(encodeURIComponent(nodes[0].innerText)
                        +"="+
                        encodeURIComponent(nodes[1].innerText)); 
            }
        }
        var encr = btoa(params.join('&'));
        jQuery.post(action,"data="+encr,function(data,status,xhr){
            console.log(data);
            console.log(status);
            console.log(xhr);
        });

    }
    </script>

Класс действия

public class Downloads extends CustomActionClass{

   private static final long serialVersionUID = 1L;
   private String data;
   private InputStream fileStream;
   private long contentLength;


    public String execute() {
        String decodeData = new 
        String(java.util.Base64.getDecoder().decode(data));
    List<String> downloadData = new ArrayList<String>();
    try {
             String fileName = "info.csv";
        String [] dataList = URLDecoder.decode(decodeData,"UTF-8").split("&");
             String header ="";
                 String vals = "";
                 for(String dat: dataList) {
                     String[] tData = dat.split("=");
                     header += tData[0] + ",";
                     if(tData.length>1)
                         vals += tData[1]+",";
                 }

                 if(StringUtils.isNotBlank(header))
                     downloadData.add(header.substring(0,header.length()-1));
                 if(StringUtils.isNotBlank(vals))
                     downloadData.add(vals.substring(0,vals.length()-1));

                 File fil = new File(getServerTempFolder()+fileName);
                 fil.createNewFile();
                 contentLength = fil.length();
                 FileUtils.writeLines(fil, "UTF-8", downloadData);
                 fileStream =  new FileInputStream(fil);

            } catch (Exception e) {
                log.info("Error: " + e.getMessage());
                log.debug(e.fillInStackTrace());
            }       
    return SUCCESS;
}

        /**
         * @return the data
         */
        public String getData() {
            return data;
        }

        /**
         * @param data the data to set
         */
        public void setData(String data) {
            this.data = data;
        }

        /**
         * @return the fileStream
         */
        public InputStream getFileStream() {
            return fileStream;
        }

        /**
         * @param fileStream the fileStream to set
         */
        public void setFileStream(InputStream fileStream) {
            this.fileStream = fileStream;
        }

        /**
         * @return the contentLength
         */
        public long getContentLength() {
            return contentLength;
        }

        /**
         * @param contentLength the contentLength to set
         */
        public void setContentLength(long contentLength) {
            this.contentLength = contentLength;
        }

    }

Вот мое отображение Struts:

<action name="download" class="com.util.Downloads">
<result name="success" type="stream">
<param name="contentType">application/octet-stream</param>
<param name="contentLength">${contentLength}</param>
<param name="inputName">fileStream</param>
<param name="contentDisposition">attachment;filename="info.csv"</param>
<param name="bufferSize">1024</param>

1 Ответ

0 голосов
/ 28 апреля 2018

Я решил эту проблему. Таким образом, решение этой проблемы заключается в том, что вызов ajax не будет запускать загрузку, поскольку это пост-запрос . Мне пришлось сделать window.href=action;, это сделало вызов get и, следовательно, поток был возвращен из класса действия.

Я собираюсь сделать еще один шаг, если у кого-то возникнут проблемы с кодированием. Для правильного кодирования в формате pdf напишите правильные заголовки, указав кодировку UTF-8 .. для csv запишите это в файл byte[] enc = new byte[] { (byte)0xEF, (byte)0xBB, (byte)0xBF }; перед тем, как начать записывать свои данные в файл. И да, вы можете записать этот поток байтов, а затем записать данные String в файл.

См. Эту ссылку для CSV http://smallbusiness.chron.com/utf8-encoding-excel-using-java-47939.html ...

...