xml文件生成与下载

写在前面:

  最近要做一个新的功能,点击按钮,可以根据数据生成对应的xml文件并保存。下面记录一下在做的过程的一些疑惑与问题(我就是太笨了,一些很简单的知识都不知道,不过通过这次跟蛋蛋的交流,解决了我的很多疑惑~~~啊哈哈哈。。。)

  

  思考(做的过程中的疑惑):

  1.如何将实体类转成xml格式的文件?

    经查阅资料,生成xml格式的文件有很多种方法,dom、jdom、dom4j等,这里我采用的是jdom,具体的生成xml格式的过程可以看后面的代码部分。

  2.点击按钮可以生成xml文件,这个是可以做到的,但是在浏览器页面上却没有弹出提示框让用户选择文件的保存路径,那么这个弹出框是从哪里来的呢?

    原来这个下载弹出框,是需要我们在程序中设置的,就是需要我们设置response的响应头信息,设置之后,浏览器就会知道要弹出下载框。

  3.这个功能跟文件下载功能有什么区别?

    没有区别,生成xml文件,并保存,就是一个文件下载的功能

  4.什么是文件下载?

    文件下载的本质就是内容的输出。内容从哪里来?那么既然说是内容的输出,那这内容从何而来?大概有两种方式,第一,读取其他文件的内容;第二,在程序中,创建出一个内容,例如,一个字符串。如何输出?都说是输出,那肯定就是用OutputStream输出流来输出了。具体输出到哪儿?这里的输出并不是直接输出到文件里,而是把内容写到response响应里面,然后交给浏览器去做将内容写入到文件里的操作。

  5.什么是服务器内存?服务器磁盘?

    服务器内存是内存,磁盘是磁盘,两者不可混淆,但是要明白一点,文件下载,首先是要将内容保存到服务器内存中,然后才是从内存中写入到磁盘中。

  6.使用ajax请求进行文件下载可以吗?

    不可以的,因为ajax是异步的js,而js是不支持往磁盘里写东西的,所以响应流中的内容无法被写入到磁盘中,也就无法实现下载。故这里采用

window.location.href 

来发送请求。但是使用ajax请求发送请求是可以接收到响应的内容的。  

 

  好啦,在弄清楚了这些疑惑后,下面就开始具体的代码实现过程喽~

 

  前台jsp:

<%--
  Created by IntelliJ IDEA.
  User: Eleven
  Date: 2018/1/3
  Time: 10:07
  To change this template use File | Settings | File Templates.
--%>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<%@ page contentType="text/html;charset=UTF-8" language="java" %>

<%
    String scheme = request.getScheme();
    String serverName = request.getServerName();
    String contextPath = request.getContextPath();
    int port = request.getServerPort();

    //网站的访问跟路径
    String baseURL = scheme + "://" + serverName + ":" + port
            + contextPath;
    request.setAttribute("baseURL", baseURL);
%>

<html>
<head>
    <title>生成xml文件</title>
    <script type="text/javascript">

        function createXML(){
            //发送请求到服务器
            //!!!!对于文件的下载 不能使用ajax请求 因为ajax请求无法实现文件的下载
            window.location.href = '${baseURL}/createXML';
        }
    </script>
</head>
<body>
    点击按钮生成xml文件:<button id="btnClick" onclick="createXML();">生成xml文件</button>
</body>
</html>

  后台action:

/**
 * Description:com.ims.action
 * Author: Eleven
 * Date: 2018/1/2 9:56
 */
@Controller("FileAction")
public class FileAction extends BaseAction {

    /**
     * 文件下载的过程大致分为三大步:
     * 1.设置response响应头,告知浏览器是文件下载,并弹出那个文件保存的框框
     * 2.获取输出的内容,并将要输出的内容转为byte[]格式
     * 3.输出,将内容写到响应中
     */
    public void createXML(){

        //准备数据
        Demo d = new Demo();
        d.setDemoId(11);
        d.setDemoName("凤姐");
        Demo d2 = new Demo();
        d2.setDemoId(22);
        d2.setDemoName("小花");
        Demo d3 = new Demo();
        d3.setDemoId(33);
        d3.setDemoName("狗子");

        List<Demo> list = new ArrayList<Demo>();
        list.add(d);
        list.add(d2);
        list.add(d3);

        //1.设置文件下载的response响应格式
        String fileName = "demo";  //文件名
        String fileType = "xml";    //文件类型
        HttpServletResponse response = ServletActionContext.getResponse();
        response.setHeader("Content-Disposition", "attachment;filename=" + fileName + "." + fileType);
        response.setContentType("multipart/form-data");
        //2.将数据转为xml格式的字符串
        Element root = new Element("Demo-list");
        Document document = new Document(root);
        for(Demo demo:list){

            Element element = new Element("Demo");
            element.addContent(new Element("demoId").setText(String.valueOf(demo.getDemoId())));
            element.addContent(new Element("demoName").setText(demo.getDemoName()));

            root.addContent(element);
        }

        Format format = Format.getPrettyFormat(); //使xml文件 缩进效果
        XMLOutputter xmlout = new XMLOutputter(format);
        String result = xmlout.outputString(document);
        System.out.println("转为xml格式的数据:"+result);
        try {
            //3.将内容转为byte[]格式
            byte[] data = result.getBytes("UTF-8");

            //4.将内容写入响应流

            OutputStream out = response.getOutputStream();
            out.write(data);
            out.flush();
            out.close();
        } catch (IOException e) {
            e.printStackTrace();
        }


    }


}

  对于将实体类对象生成xml格式的字符串,这里用到了jdom的工具包,故需要导入jdom-jar包。

 

  sturts.xml配置:

<action name="createXML" class="FileAction" method="createXML">
</action>

  

  好啦,完成了上面的步骤,xml文件的生成与下载就完成了,运行截图:

 

 

  附:

  1.为什么大多数程序都要像下面的代码这样边读边写?

outputStream = new FileOutputStream(file);            
byte[] temp = new byte[1024];
int size = -1;
while ((size = inputStream.read(temp)) != -1) { // 每次读取1KB,直至读完
    outputStream.write(temp, 0, size);
}

    为了减少服务器的内存,所以我们经常看见上面这段程序,此程序就是在边读边写(从一个文件中读取内容,然后将内容写到一个文件中),每次读取1kb,每次写1kb。

 

转载于:https://www.cnblogs.com/eleven258/p/8183119.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
EtherCAT(以太CAT)是一种实时以太网通信协议,它允许工业设备在实时性要求严格的应用中进行高效的通信。生成EtherCAT XML文件是为了配置和描述EtherCAT网络中的各个设备的通信参数和功能。 首先,要生成EtherCAT XML文件,我们需要一个EtherCAT配置工具,比如Beckhoff的TwinCAT工具。通过这个工具,我们可以创建一个新的EtherCAT配置项目,并添加相应的从站设备。 接下来,我们可以通过工具来配置从站设备的参数,如设备的名称、ID、固件版本等等。此外,还可以配置设备的输入输出接口、参数设置、数据处理逻辑等等。 当设置完所有的从站设备后,我们可以利用工具来生成EtherCAT XML文件。这个XML文件包含了整个EtherCAT网络的配置信息,其中包括主站设备的参数和每个从站设备的详细配置。 生成的EtherCAT XML文件可以被导出并保存在本地计算机上,然后可以用于配置和部署EtherCAT网络。在实际应用中,我们可以使用EtherCAT主站设备加载这个XML文件,并根据配置将相应的参数和功能发送给从站设备。 总结而言,生成EtherCAT XML文件是为了配置和描述EtherCAT网络中的各个设备的通信参数和功能。通过EtherCAT配置工具,我们可以创建并配置EtherCAT网络,并生成包含所有配置信息的XML文件。这个XML文件可以用于配置和部署EtherCAT网络,以实现高效的实时通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值