Solved

ASP.NET File permissions on Win Server

Posted on 2010-09-10
7
692 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
ID: 33650521
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
ID: 33650698
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
ID: 33650889
"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
Windows Server 2016: All you need to know

Learn about Hyper-V features that increase functionality and usability of Microsoft Windows Server 2016. Also, throughout this eBook, you’ll find some basic PowerShell examples that will help you leverage the scripts in your environments!

 
LVL 30

Expert Comment

by:MlandaT
ID: 33650910
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
ID: 33650928
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
ID: 33651397
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
ID: 33652370
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

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

If you migrate a Terminal Server licenses server inside the 2008 server family, you can takte advantage of the build-in migration tool. If you like to migrate an older 2003 Server (and the installed client CALs) to a 2008 R2 server for example, you …
Redirected folders in a windows domain can be quite useful for a number of reasons, one of them being that with redirected application data, you can give users more seamless experience when logging into different workstations.  For example, if a use…
This tutorial will show how to push an installation of Backup Exec to an additional server in both 2012 and 2014 versions of the software. Click on the Backup Exec button in the upper left corner. From here, select Installation and Licensing, then I…
This tutorial will walk an individual through setting the global and backup job media overwrite and protection periods in Backup Exec 2012. Log onto the Backup Exec Central Administration Server. Examine the services. If all or most of them are stop…

856 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