ASP.NET导出Excel,打开时提示“您尝试打开文件✀XXX.xls✀的格式与文件扩展名指定文件不一致”

使用2007打开的
2024-11-30 03:36:43
推荐回答(2个)
回答1:

1、打开注册表编辑器
方法:开始 -> 运行 -> 输入regedit -> 确定

2、找到注册表子项
HKEY_CURRENT_USER\Software\Microsoft\Office\12.0\Excel\Security

3、在右侧空白处点击鼠标右键,选择“新建 -> DWORD值(D)”,输入“ExtensionHardening”点击确定。

4、用鼠标右键点击ExtensionHardening,然后单击“修改(M)”,在数值数据中填写“0”即可确定。

5、关闭注册表编辑器,再次打开xls文件看看是不是提示是不是不见了?

小知识:ExtensionHardening设置的值的数据设置:

* 0: 不检查文件扩展名和文件类型并绕过该函数的警告消息。
* 1: 检查文件扩展名和文件类型。如果它们不匹配会显示警告消息。
* 2: 检查文件扩展名和文件类型。如果它们不匹配不要打开该文件。

回答2:

改了注册表容易造成漏洞!
导出Excel时增加上 Excel Files (*.xlsx)|*.xlsx 就好了,2003以后也不用了。
或者在显示扩展名的情况下直接把扩展名改成xlsx 也不提示 不一致了!!
俺使用的是CommonDialog控件

.Filter = "All Files (*.*)|*.*|Excel Files (*.xlsx)|*.xlsx|Excel 2003 Files (*.xls)|*.xls|Batch Files (*.bat)|*.bat"

.FilterIndex = 2