Solved

ASP.NET File permissions on Win Server

Posted on 2010-09-10
7
689 Views
Last Modified: 2012-05-10
Hello -

I've written a .net page that moves a file from one folder to another.  Pretty simple, and works great on my Dev machine.  It doesn't seem to work on my Test server though.  I don't get an error, but the file doesn't move.  (code below)

I'm running Windows Server 2008 R2.  Do I need to set file permissions to allow .NET to move files from a web app?  Please advise.  Thanks -

Justin
// Move the file to the Purgatory folder

            string strFromPath = "c:\\FTP\\" + Request.QueryString["job"].ToString() + "\\" + Profile.UserName.ToString() + "\\" + Request.QueryString["file"].ToString();

            string strToPath = "c:\\Purgatory\\" + txtFileName.Text.ToString();



            if (!File.Exists(strFromPath))

            {

                // This statement ensures that the file is created,

                // but the handle is not kept.

                using (FileStream fs = File.Create(strFromPath)) { }

            }



            // Ensure that the target does not exist.

            if (File.Exists(strToPath))

                File.Delete(strToPath);



            // Move the file.

            File.Move(strFromPath, strToPath);

Open in new window

0
Comment
Question by:JT_SIRO
  • 5
  • 2
7 Comments
 
LVL 30

Expert Comment

by:MlandaT
Comment Utility
yes give the Network Service permissions on the folders. If the folders are created by the ASP.NET application then they shld already have the necessary permissions.

 If you need to allow the same level of access to a file resource for all accounts that run ASP.NET applications (Network Service or a custom service account), you can grant access to the IIS_WPG group instead of specifically to the Network Service account. Any account used to run ASP.NET is required to be a member of the IIS_WPG group.

If your ASP.NET application is configured to use a custom application pool, check the identity used to run that application pool and give that account permissions on the folders in question.
0
 

Author Comment

by:JT_SIRO
Comment Utility
Thanks MlandaT, but I'm still kind of stuck.  Here's what I did:
I gave NETWORK SERVICE Full Control on the two folders and it did not work.  
I tried adding my App Pool DefaultAppPool, and the name was not recognized.
I tried adding IIS_WPG and the name was not recognized.

For the heck of it, I gave the Users group Full Control, and it DID work.  But I don't want to grant this permission to all Users do I?  
0
 
LVL 30

Expert Comment

by:MlandaT
Comment Utility
"I tried adding my App Pool DefaultAppPool, and the name was not recognized." I dont think this is right...

1. Check what application pool your application is running under.
- Right click your website in IIS, Manage Website -> Advanced Settings ... you will see the Application Pool there.

2. Check what user account your applicaiton pool is using.
- Click "Application Pools" in IIS, find the application pool in (1) above, right click, click "Advanced Settings"... check what the Identity being used is....

3. Make sure that account has permissions on the fodlers...
0
Free book by J.Peter Bruzzese, Microsoft MVP

Are you using Office 365? Trying to set up email signatures but you’re struggling with transport rules and connectors? Let renowned Microsoft MVP J.Peter Bruzzese show you how in this exclusive e-book on Office 365 email signatures. Better yet, it’s free!

 
LVL 30

Expert Comment

by:MlandaT
Comment Utility
If the Application Pool is configured to use the AppPoolIdentity, you have 2 options
1) On the folders in question.. assign permissions to the 'user' that has the same name as your applicaiton pool (http://learn.iis.net/page.aspx/624/application-pool-identities/, http://blogs.msdn.com/b/vijaysk/archive/2009/02/13/goodbye-network-service.aspx)
2) Change it to a different account e.g. NetworkService...in which case granting the NETWORK SERVICE account permissions o the folder will work as normal.


Additional Reading:
http://blogs.iis.net/webdevelopertips/archive/2009/10/02/tip-98-did-you-know-the-default-application-pool-identity-in-iis-7-5-windows-7-changed-from-networkservice-to-apppoolidentity.aspx
0
 
LVL 30

Expert Comment

by:MlandaT
Comment Utility
And in case you have problems with the configuration using the GUI... you may have to switch to the command line... http://serverfault.com/questions/81165/how-to-assign-permissions-to-applicationpoolidentity-account
 Of course all assuming that you are continuing use of the new ApplicationPoolIdentity
0
 

Author Comment

by:JT_SIRO
Comment Utility
I read the articles and still can't get it to recognize my app pool name.  Please see attached images.
appPool1.bmp
appPool2.bmp
0
 
LVL 30

Accepted Solution

by:
MlandaT earned 250 total points
Comment Utility
Option 1:
Note that if you enter "IIS APPPOOL\MusicSearchTEST" directly into the "Select User or Group" (instead of searching for it) when editing permissions, it will be recognized just fine (tested on Win2k8 R2 x64).

Option 2:
Have you tried the command line option:

icacls c:\inetpub\wwwroot /grant "IIS APPPOOL\MusicSearchTEST":(OI)(CI)(RX)

ICACLS command syntax: http://technet.microsoft.com/en-us/library/cc753525%28WS.10%29.aspx, http://ss64.com/nt/icacls.html
Reference material: http://serverfault.com/questions/81165/how-to-assign-permissions-to-applicationpoolidentity-account
0

Featured Post

Shouldn't all users have the same email signature?

You wouldn't let your users design their own business cards, would you? So, why do you let them design their own email signatures? Think of the damage they could be doing to your brand reputation! Choose the easy way to manage set up and add email signatures for all users.

Join & Write a Comment

Introduction This article shows how to use the open source plupload control to upload multiple images. The images are resized on the client side before uploading and the upload is done in chunks. Background I had to provide a way for user…
Restoring deleted objects in Active Directory has been a standard feature in Active Directory for many years, yet some admins may not know what is available.
This tutorial will give a short introduction and overview of Backup Exec 2012 and how to navigate and perform basic functions. Click on the Backup Exec button in the upper left corner. From here, are global settings for the application such as conne…
This tutorial will show how to configure a new Backup Exec 2012 server and move an existing database to that server with the use of the BEUtility. Install Backup Exec 2012 on the new server and apply all of the latest hotfixes and service packs. The…

772 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

10 Experts available now in Live!

Get 1:1 Help Now