This is the way I do it.
The things you need is a folder named "Uploads".
All the rest is done automaticaly.
First when a user open's the page where the uploading is done on a Page_Load I do the following to make sure the folder for the authenticated user is created.
Protected Sub Page_Load (ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
If My.User.IsAuthenticated Then
Try
If Not Page.IsPostBack Then
Select Case My.Computer.FileSystem.DirectoryExists (Server.MapPath ("~/Uploads"))
Case False
My.Computer.FileSystem.CreateDirectory (Server.MapPath ("~/Uploads"))
End Select
Select Case My.Computer.FileSystem.DirectoryExists (Server.MapPath ("~/Uploads/" & My.User.Name))
Case False
My.Computer.FileSystem.CreateDirectory (Server.MapPath ("~/Uploads/" & My.User.Name))
End Select
ListMyFiles()
End If
Catch ex As Exception
'Some code for catching exceptions
End Try
Else
Response.Redirect ("YOUR LOGIN PAGE")
End If
End Sub
Then on the page I already added a ASP:FileUpload control.
On the Click eveent of this control I add this code
Try
Select Case FileUpload1.HasFile
Case True
Dim fname = FileUpload1.PostedFile.FileName
SaveFile(FileUpload1.PostedFile)
ListMyFiles()
Case False
Fupload.Text = "Please select a file for uploading!"
End Select
Catch ex As Exception
'Some code for catching exceptions
End Try
The SaveFile function has the following code
Sub SaveFile (ByVal file As HttpPostedFile)
Try
Dim _
filext = _
Split (FileUpload1.PostedFile.FileName, ".") ( _
Split (FileUpload1.PostedFile.FileName, ".").Length - _
1)
Select Case filext
Case "txt"
Dim foldername = "~/Uploads/" & My.User.Name
Dim filename = foldername & "/Uploaded_" & FileUpload1.FileName
Dim savePath As String = "~/Uploads/" & My.User.Name
Dim pathToSave As String = Server.MapPath (filename)
Select Case IO.File.Exists (pathToSave)
Case False
FileUpload1.SaveAs (pathToSave)
Dim uploadedFile = My.Computer.FileSystem.ReadAllText ((pathToSave))
uploadedFile = uploadedFile
My.Computer.FileSystem.WriteAllText (pathToSave, uploadedFile, False)
Dim msg As String = "Your file was uploaded successfully."
Fupload.Text = msg
Case True
Dim _
msg As String = _
"You have already uploaded this file. Please delete the file from server first and then try to upload it again."
Fupload.Text = msg
End Select
Case Else
Dim _
msg As String = "The file type '" & filext & _
"' you are trying to upload is not allowed. You can only upload '.txt' files."
Fupload.Text = msg
End Select
Catch ex As Exception
'Some code for catching exceptions
End Try
End Sub
and the ListMyFiles functions has the following code.
Protected Sub ListMyFiles()
Try
Dim foldername = "~/Uploads/" & My.User.Name
Dim files As New List(Of MyFiles)
For Each s As String In My.Computer.FileSystem.GetFiles (Server.MapPath (foldername) & "\")
Dim f As New MyFiles
f.Filename = Split (s, "\") (Split (s, "\").Length - 1)
f.CompletePath = s
f.FileSize = My.Computer.FileSystem.GetFileInfo (s).Length
files.Add (f)
Next
ListFiles.DataSource = files
ListFiles.DataBind()
Catch ex As Exception
'Some code for catching exceptions
End Try
End Sub
Hope I solved your problem.
I know that you could tweak the code but this had done the job for me.
There is another way you can use by storing the files as binary on you database but I choose to do it this way since it's simpler.