3

我有一个将文件存储在 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

谢谢

奥伦

4

3 回答 3

5

FILESTREAM 需要连接字符串的集成安全性。不支持 SQL Server 身份验证。

请参阅https://social.msdn.microsoft.com/Forums/fr-FR/c2b9e316-f77d-49e4-8433-440afd392d1a/sqlfilestream-opensqlfilestream-access-is-denied-in-c?forum=adodotnetdataproviders

于 2015-10-13T21:50:56.393 回答
2

我遇到了同样的问题,我能够通过确保用于访问数据库的帐户对正在访问的表中的 FILESTREAM 列具有 SELECT 和 UPDATE 权限来解决该问题。这是所需的 T-SQL 代码:

GRANT SELECT, UPDATE ON OBJECT::[schema name].[table name]([file stream column name]) TO [the role/user to grant the rights to] AS [dbo];
GO
于 2015-03-11T21:27:39.713 回答
1

听起来问题更像是操作系统权限而不是 SQL Server 权限。尝试向应用程序池使用的域帐户授予对创建文件流的路径的读/写访问权限

于 2013-11-13T04:21:54.400 回答