gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-01 10:51:11 25 4
gpt4 key购买 nike

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

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com