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 帐户,选中所需访问权限对应的框。
请问怎么解决?

解决方案 »

  1.   

    你是通过客户端访问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();