发新话题
打印

C#导出EXCEL的时候报错:拒绝访问

C#导出EXCEL的时候报错:拒绝访问

myApp=   new   ApplicationClass();   
  程序运行到这一句的时候会报错:   
  拒绝访问。     
  异常详细信息:   System.UnauthorizedAccessException:   拒绝访问。     
      
  ASP.NET   未被授权访问所请求的资源。请考虑授予   ASP.NET   请求标识访问此资源的权限。ASP.NET   有一个在应用程序没有模拟时使用的基进程标识(通常,在   IIS   5   上为   {MACHINE}\ASPNET,在   IIS   6   上为网络服务)。如果应用程序正在通过   <identity   impersonate="true"/>   模拟,则标识将为匿名用户(通常为   IUSR_MACHINENAME)或经过身份验证的请求用户。     
   
  若要授予   ASP.NET   对文件的写访问权,请在资源管理器中右击该文件,选择“属性”,然后选择“安全”选项卡。单击“添加”添加适当的用户或组。突出显示   ASP.NET   帐户,选中所需访问权限对应的框。   
   
   
  请问怎么解决?

TOP

你是通过客户端访问EXCEL文件的吧?   
  这肯定是不行的!   
  我是这样做的:   
  先上传该文件到服务器的一个目录下:   
  using   System.IO;   
   
  HttpFileCollection   files     =   HttpContext.Current.Request.Files;   
  HttpPostedFile   postedFile   =   files[0];   
  string   configPath   =   Server.MapPath("../../Config/");//得到上传目录   
  System.IO.File.Delete(configPath   +   name);//如果上次的文件还存在,先删除文件   
  postedFile.SaveAs(configPath   +   name);   
   
  然后再读取服务器上的文件。   
   
  你的可以这样:   
  //先在服务器上插入所有数据:   
  //然后提示客户端下载:   
  Response.Clear();   
  Response.ClearHeaders();   
  Response.Buffer=false;   
  Response.ContentType="application/octet-stream";   
  Response.AppendHeader("Content-Disposition","attachment;filename="   +   HttpUtility.UrlEncode(file.FullName,System.Text.Encoding.UTF8));   
  Response.AppendHeader("Content-Length",file.Length.ToString());   
  Response.WriteFile(file.FullName);   
  Response.Flush();

TOP

发新话题