MVC下载Excel文件:js接受乱码 简单处理办法

    在做考试系统的时候,需要向题库里面批量导入试题。所以在导题之前需要下载一个Excel模版。

MVC中下载模版,需要创建一个Excel模版,然后发到前台。即点击之后,弹出一个下载框,提示下载(保存位置)。

 

现象:在MVC中,点击下载模版按钮,不提示下载。

原因:js接受 FileResult类型乱码

 

   如果是单纯的生成一个特定的Excel的文件,然后发到前台,即没有参数的下载。如果是这样的话直接让Controller创建,返回一个FileResult文件,前台就直接弹窗提示了。

 

   但是下载导入模版,肯定是要根据具体的题型来下载对应的模版。即带参数的下载文件。

 

 

第一思路:带参数的查询,肯定要把前台 "题型"数据传递到后台,然后后台去查找对应的文件。

   js提交数据到Controller,然后生成模版,在发送到前台。

技术分享

 

但是使用这种方法,前台在点击下载模版的时候,始终弹窗(不提示下载)……

 

   如果用js事件来提交数据的话,那么接受服务器发过来文件的就成了js里面的success事件处理。这样就带来了一个问题,js接受FileContentResult类型的数据全是乱码。

   然后,就开始了js为什么接收到是乱码。查了很多js FileResult类型之间的联系。直到看到开源中国社区的一个帖子。

技术分享

一年前的问题,至今没有人回答……

我想,或许我已经走偏了。用js来向后台传递数据,肯定得找到js乱码的的原因。虽然看起来思路非常简单,但是这不知道如何解决乱码问题真的花不起时间了,

 

 

第二思路:直接略过JsView直接提交数据到后台

技术分享

改用GET传值,从服务器上拿指定的文件。

即在选择题型的时候给  "下载模版" 的按钮 添加上参数。如图

技术分享

 

   这样做的好处,就是View直接去调用Controller,Controller创建文件 之后,就可以把数据 直接返回到前台页面(提示下载)

   使用GET传值,唯一不好的就是。容易把 代码设计中的 变量以及 值 暴露出来。降低安全性。当然这些在前台显示的时候  可以利用加密解密来进行处理。

   这样就可以直接从服务器上拿 文件了。

技术分享

   虽然换了一种方法,可以实现目的。但是感觉不用js与直接与Controller进行控制,有些不方便。用js来控制文件流,有很多值得优化的地方。

             在完成功能的基础上,还要继续进行优化。

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。