asp.net - 从文件流读取时访问被拒绝错误

标签 asp.net sql sql-server filestream

我有一个将文件存储在 SQL 文件流中的 Intranet 应用程序。

在我的开发机器上,一切都像魅力一样。

我能够将文件上传和存储到 SQL 文件流 (AjaxUpload) 并能够下载它们。

在实时服务器上,我可以上传文件,删除它们,但是当我尝试从文件流下载文件时,我收到以下错误:


Access is denied

Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. 

Exception Details: System.ComponentModel.Win32Exception: Access is denied

Source Error: 

An unhandled exception was generated during the execution of the current web request. Information regarding the origin and location of the exception can be identified using the exception stack trace below.

Stack Trace: 

[Win32Exception (0x80004005): Access is denied]
   System.Data.SqlTypes.SqlFileStream.OpenSqlFileStream(String path, Byte[] transactionContext, FileAccess access, FileOptions options, Int64 allocationSize) +1465594
   System.Data.SqlTypes.SqlFileStream..ctor(String path, Byte[] transactionContext, FileAccess access, FileOptions options, Int64 allocationSize) +398
   System.Data.SqlTypes.SqlFileStream..ctor(String path, Byte[] transactionContext, FileAccess access) +27
   quotes_GetFileStream.quotes_GetFileStream_Load(Object sender, EventArgs e) +740
   System.Web.UI.Control.LoadRecursive() +71
   System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +3048

应用程序池设置为集成,V.4.0,我使用域用户进行身份认证回SQL。

我授予该用户 DB_Owner 对该应用程序的 SQL 数据库的权限。

甚至尝试给它所有的 SQL Server 角色,但我仍然收到上述错误。

当我将身份用户名更改为我的(我拥有域管理员权限)时,一切都在实时服务器上完美运行。

我缺少什么权利来授予该用户,以便他可以正确读取 SQL 文件流。

这是从文件流中获取文件并将其推送到浏览器的代码块,也许我在这里遗漏了一些东西(尽管一旦我修改了用户,它就很好用)。

Dim RecId As Integer = -1

    If Not IsNothing(Request.QueryString("ID")) And IsNumeric(Request.QueryString("ID")) Then
        RecId = CType(Request.QueryString("ID"), Integer)
    End If

    Dim ConString As String = ConfigurationManager.ConnectionStrings("ConnectionString").ToString
    Using Con As SqlConnection = New SqlConnection(ConString)
        Con.Open()
        Dim txn As SqlTransaction = Con.BeginTransaction()
        Dim Sql As String = "SELECT FileData.PathName() , GET_FILESTREAM_TRANSACTION_CONTEXT() as TransactionContext, [FileName], [FileExtension] FROM [QAttach] where RecId = @RecId"
        Dim cmd As SqlCommand = New SqlCommand(Sql, Con, txn)
        cmd.Parameters.Add("@RecID", Data.SqlDbType.Int).Value = RecId
        Dim Rdr As SqlDataReader = cmd.ExecuteReader()

        While Rdr.Read()
            Dim FilePath As String = Rdr(0).ToString()
            Dim objContext As Byte() = DirectCast(Rdr(1), Byte())
            Dim fname As String = Rdr(2).ToString()
            Dim FileExtension As String = Rdr(3).ToString()

            Dim sfs As SqlFileStream = New SqlFileStream(FilePath, objContext, FileAccess.Read)

            Dim Buffer As Byte() = New Byte(CInt(sfs.Length) - 1) {}
            sfs.Read(Buffer, 0, Convert.ToInt32(Buffer.Length))


            Response.Buffer = True
            Response.Charset = ""
            Response.Cache.SetCacheability(HttpCacheability.NoCache)
            Response.ContentType = FileExtension
            Response.AddHeader("content-disposition", "attachment;filename=" & fname)
            Response.BinaryWrite(Buffer)
            Response.Flush()
            Response.End()

            sfs.Close()

        End While
    End Using

谢谢

奥伦

最佳答案

关于asp.net - 从文件流读取时访问被拒绝错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19943655/

相关文章:

c# - 像 Smarty 这样的模板语言可用于 dotnet

sql - 连接小时和分钟列以十进制格式显示 SQL 查询

sql - 第二高薪水

c# - 如何在 Visual Studio 2010 中使用我的安装和部署项目部署 SQL 服务器数据库?

javascript - 如何使用asp.net将两个图像放置在单个 Canvas 中?

javascript - 如何正确设置标签和文本框填充?

sql-server - 获取当前工作日从周一到周日

C# 从多个线程对表执行批量更新,不会出现死锁

asp.net - 我应该注意ASP.NET应用程序的哪些关键性能监视器

mysql - (i) 从现有表创建一个表,并 (ii) 显示表中存储总计的详细数据