asp.net 正由另一个进程,因此该进程无法访问此文件

Z_X_S_ 2012-03-21 10:58:56
private void DaochuEXCEl(DataTable dt)
{
// 根据模板文件创建副本
string filePath = Server.MapPath("~/excel/Fuben.xls");
File.Copy(Server.MapPath("~/excel/demo.xls"), filePath);
// 使用OleDb驱动程序连接到副本
OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties=Excel 8.0;");
using (conn)
{
conn.Open();
foreach (DataRow row in dt.Rows)
{
// 增加记录
OleDbCommand cmd = new OleDbCommand("INSERT INTO [Sheet1$]([serial], [quyu], [name],[addr],[faren],[企业负责人],[质量负责人],[经营方式],[经营范围],[仓库地址],[许可证号],[发证机关],[许可证发证日期],[许可证有效日期],[药品养护人数],[药品验收人数],[质量管理人数],[药品保管人数],[岗位总人数],[在职情况]) VALUES(@serial,@quyu,@name,@addr,@faren,@企业负责人,@质量负责人,@经营方式,@经营范围,@仓库地址,@许可证号,@发证机关,@许可证发证日期,@许可证有效日期,@药品养护人数,@药品验收人数,@质量管理人数,@药品保管人数,@岗位总人数,@在职情况)", conn);
cmd.Parameters.AddWithValue("@serial", row["serial"].ToString());
cmd.Parameters.AddWithValue("@quyu", row["quyu"].ToString());
cmd.Parameters.AddWithValue("@name", row["name"].ToString());
cmd.Parameters.AddWithValue("@addr", row["addr"].ToString());
cmd.Parameters.AddWithValue("@faren", row["faren"].ToString());
cmd.Parameters.AddWithValue("@企业负责人", row["企业负责人"].ToString());
cmd.Parameters.AddWithValue("@质量负责人", row["质量负责人"].ToString());
cmd.Parameters.AddWithValue("@经营方式", row["经营方式"].ToString());
cmd.Parameters.AddWithValue("@经营范围", row["经营范围"].ToString());
cmd.Parameters.AddWithValue("@仓库地址", row["仓库地址"].ToString());
cmd.Parameters.AddWithValue("@许可证号", row["许可证号"].ToString());
cmd.Parameters.AddWithValue("@发证机关", row["发证机关"].ToString());
cmd.Parameters.AddWithValue("@许可证发证日期", row["许可证发证日期"].ToString());
cmd.Parameters.AddWithValue("@许可证有效日期", row["许可证有效日期"].ToString());
cmd.Parameters.AddWithValue("@药品养护人数", row["药品养护人数"].ToString());
cmd.Parameters.AddWithValue("@药品验收人数", row["药品验收人数"].ToString());
cmd.Parameters.AddWithValue("@质量管理人数", row["质量管理人数"].ToString());
cmd.Parameters.AddWithValue("@药品保管人数", row["药品保管人数"].ToString());
cmd.Parameters.AddWithValue("@岗位总人数", row["岗位总人数"].ToString());
cmd.Parameters.AddWithValue("@在职情况", row["在职情况"].ToString());
cmd.ExecuteNonQuery();
}
}
// 输出副本的二进制字节流
Response.ContentType = "application/ms-excel";
Response.AppendHeader("Content-Disposition", "attachment;filename=info.xls");
conn.Close();
conn.Dispose();
Response.BinaryWrite(File.ReadAllBytes(filePath));
// 删除副本
File.Delete(filePath);
} private void DaochuEXCEl(DataTable dt)
{
// 根据模板文件创建副本
string filePath = Server.MapPath("~/excel/Fuben.xls");
File.Copy(Server.MapPath("~/excel/demo.xls"), filePath);
// 使用OleDb驱动程序连接到副本
OleDbConnection conn = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + filePath + ";Extended Properties=Excel 8.0;");
using (conn)
{
conn.Open();
foreach (DataRow row in dt.Rows)
{
// 增加记录
OleDbCommand cmd = new OleDbCommand("INSERT INTO [Sheet1$]([serial], [quyu], [name],[addr],[faren],[企业负责人],[质量负责人],[经营方式],[经营范围],[仓库地址],[许可证号],[发证机关],[许可证发证日期],[许可证有效日期],[药品养护人数],[药品验收人数],[质量管理人数],[药品保管人数],[岗位总人数],[在职情况]) VALUES(@serial,@quyu,@name,@addr,@faren,@企业负责人,@质量负责人,@经营方式,@经营范围,@仓库地址,@许可证号,@发证机关,@许可证发证日期,@许可证有效日期,@药品养护人数,@药品验收人数,@质量管理人数,@药品保管人数,@岗位总人数,@在职情况)", conn);
cmd.Parameters.AddWithValue("@serial", row["serial"].ToString());
cmd.Parameters.AddWithValue("@quyu", row["quyu"].ToString());
cmd.Parameters.AddWithValue("@name", row["name"].ToString());
cmd.Parameters.AddWithValue("@addr", row["addr"].ToString());
cmd.Parameters.AddWithValue("@faren", row["faren"].ToString());
cmd.Parameters.AddWithValue("@企业负责人", row["企业负责人"].ToString());
cmd.Parameters.AddWithValue("@质量负责人", row["质量负责人"].ToString());
cmd.Parameters.AddWithValue("@经营方式", row["经营方式"].ToString());
cmd.Parameters.AddWithValue("@经营范围", row["经营范围"].ToString());
cmd.Parameters.AddWithValue("@仓库地址", row["仓库地址"].ToString());
cmd.Parameters.AddWithValue("@许可证号", row["许可证号"].ToString());
cmd.Parameters.AddWithValue("@发证机关", row["发证机关"].ToString());
cmd.Parameters.AddWithValue("@许可证发证日期", row["许可证发证日期"].ToString());
cmd.Parameters.AddWithValue("@许可证有效日期", row["许可证有效日期"].ToString());
cmd.Parameters.AddWithValue("@药品养护人数", row["药品养护人数"].ToString());
cmd.Parameters.AddWithValue("@药品验收人数", row["药品验收人数"].ToString());
cmd.Parameters.AddWithValue("@质量管理人数", row["质量管理人数"].ToString());
cmd.Parameters.AddWithValue("@药品保管人数", row["药品保管人数"].ToString());
cmd.Parameters.AddWithValue("@岗位总人数", row["岗位总人数"].ToString());
cmd.Parameters.AddWithValue("@在职情况", row["在职情况"].ToString());
cmd.ExecuteNonQuery();
}
}
// 输出副本的二进制字节流
Response.ContentType = "application/ms-excel";
Response.AppendHeader("Content-Disposition", "attachment;filename=info.xls");
conn.Close();
conn.Dispose();
Response.BinaryWrite(File.ReadAllBytes(filePath));
// 删除副本
File.Delete(filePath);
}
要是datatable数据少的时候,就不报错,要是数据一多就在 Response.BinaryWrite(File.ReadAllBytes(filePath));
这个地方报错“正由另一个进程,因此该进程无法访问此文件”什么情况
...全文
544 9 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
A小树A 2014-02-18
  • 打赏
  • 举报
回复
把OleDbCommand 也using一下就好了 大家可以试试
A小树A 2013-11-02
  • 打赏
  • 举报
回复
给大家说说啊 我也等答案呢。。。。
whoo529 2012-07-07
  • 打赏
  • 举报
回复
需要断掉这个进程先
sanfanghuang 2012-06-27
  • 打赏
  • 举报
回复
求解决方法,楼主是怎么解决的啊
Z_X_S_ 2012-03-21
  • 打赏
  • 举报
回复
问题解决了
能说话的哑巴 2012-03-21
  • 打赏
  • 举报
回复
呵呵 这个问题我以前做文件上传的时候也遇到过,也不知道是什么原因,等待结果看.......
xuan.ye 2012-03-21
  • 打赏
  • 举报
回复
using (conn)
{}
conn.Close();

这样不会出错吗?有点不理解
jiuhexuan 2012-03-21
  • 打赏
  • 举报
回复
因为每一次对这个页面的请求一个线程,都会执行方法,但操作都是同一个文件。
另外你的副本并没有起到作用,即使操作的是副本也会冲突。
因为可能你的创建和删除都在进行,因为副本名字相同
你可以给每个副本文件的名字加当前操作的标识符,比如累加的操作次数,sessionid,等不重复的,避免多线程操作一个文件的标识
能说话的哑巴 2012-03-21
  • 打赏
  • 举报
回复
怎么解决的?
ASP.NET ASP.NET 概述 ASP.NET一个统一的 Web 开发模型,它包括您使用尽可能少的代码生成企业级 Web 应用程序所必需的各种服务。ASP.NET 作为 .NET Framework 的一部分提供。当您编写 ASP.NET 应用程序的代码时,可以访问 .NET Framework 中的类。您可以使用与公共语言运行库 (CLR) 兼容的任何语言来编写应用程序的代码,这些语言包括 Microsoft Visual Basic、C#、JScript .NET 和 J#。使用这些语言,可以开发利用公共语言运行库、类型安全、继承等方面的优点的 ASP.NET 应用程序。 ASP.NET 包括: 页和控件框架 ASP.NET 编译器 安全基础结构 状态管理功能 应用程序配置 运行状况监视和性能功能 调试支持 XML Web services 框架 可扩展的宿主环境和应用程序生命周期管理 可扩展的设计器环境 页和控件框架 ASP.NET 页和控件框架是一种编程框架,它在 Web 服务器上运行,可以动态地生成和呈现 ASP.NET 网页。可以从任何浏览器或客户端设备请求 ASP.NET 网页,ASP.NET 会向请求浏览器呈现标记(例如 HTML)。通常,您可以对多个浏览器使用相同的页,因为 ASP.NET 会为发出请求的浏览器呈现适当的标记。但是,您可以针对诸如 Microsoft Internet Explorer 6 的特定浏览器设计 ASP.NET 网页,并利用该浏览器的功能。ASP.NET 支持基于 Web 的设备(如移动电话、手持型计算机和个人数字助理 (PDA))的移动控件。 ASP.NET 网页是完全面向对象的。在 ASP.NET 网页中,可以使用属性、方法和事件来处理 HTML 元素。ASP.NET 页框架为响应在服务器上运行的代码中的客户端事件提供统一的模型,从而使您不必考虑基于 Web 的应用程序中固有的客户端和服务器隔离的实现细节。该框架还会在页处理生命周期中自动维护页及该页上控件的状态。有关更多信息,请参见 ASP.NET 网页概述。 使用 ASP.NET 页和控件框架还可以将常用的 UI 功能封装成易于使用且可重用的控件。控件只需编写一次,即可用于许多页并集成到 ASP.NET 网页中。这些控件在呈现期间放入 ASP.NET 网页中。 ASP.NET 页和控件框架还提供各种功能,以便可以通过主题和外观来控制网站的整体外观和感觉。可以先定义主题和外观,然后在页面级或控件级应用这些主题和外观。有关更多信息,请参见 ASP.NET 主题和外观概述。 除了主题外,还可以定义母版页,以使应用程序中的页具有一致的布局。一个母版页可以定义您希望应用程序中的所有页(或一组页)所具有的布局和标准行为。然后可以创建包含要显示的页特定内容的各个内容页。当用户请求内容页时,这些内容页与母版页合并,产生将母版页的布局与内容页中的内容组合在一起的输出。有关更多信息,请参见 ASP.NET 母版页概述。 ASP.NET 编译器 所有 ASP.NET 代码都经过了编译,可提供强类型、性能优化和早期绑定以及其他优点。代码一经编译,公共语言运行库会进一步将 ASP.NET 编译为本机代码,从而提供增强的性能。 ASP.NET 包括一个编译器,该编译器将包括页和控件在内的所有应用程序组件编译成一个程序集,之后 ASP.NET 宿主环境可以使用该程序集来处理用户请求。有关更多信息,请参见 ASP.NET 编译概述。 安全基础结构 除了 .NET 的安全功能外,ASP.NET 还提供了高级的安全基础结构,以便对用户进行身份验证和授权,并执行其他与安全相关的功能。您可以使用由 IIS 提供的 Windows 身份验证对用户进行身份验证,也可以通过您自己的用户数据库使用 ASP.NET Forms 身份验证和 ASP.NET 成员资格来管理身份验证。此外,可以使用 Windows 组或您自己的自定义角色数据库(使用 ASP.NET 角色)来管理 Web 应用程序的功能和信息方面的授权。您可以根据应用程序的需要方便地移除、添加或替换这些方案。有关更多信息,请参见下列主题: ASP.NET 网站安全性 使用成员资格管理用户 使用角色管理授权 Forms 身份验证提供程序 ASP.NET 始终使用特定的 Windows 标识运行,因此,您可以通过使用 Windows 功能(例如 NTFS 访问控制列表 (ACL)、数据库权限等等)来保护应用程序的安全。有关 ASP.NET 标识的更多信息,请参见配置 ASP.NET 进程标识和 ASP.NET 模拟。 状态管理功能 ASP.NET

62,244

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧