This post was most recently updated on August 26th, 2022.
4 min read.This issue seems to pop up bafflingly often, so I thought that it was finally time to document it for future generations. Granted, it mainly considers Classic SharePoint (which is very tightly built around Publishing features) – but Classic is going to be part of our lives for quite a while still, especially for those of us still primarily on SharePoint Server!
While trying to provision subsites to your SharePoint Publishing intranet you encounter either a generic “Access Denied” -error or any error with 0x80070005 as the underlying error code. Your subsite is not created. This error might surface via the GUI, via PowerShell, using CSOM, or even in full-trust -code running in a farm solution.
Your permissions don’t seem to help at all – no matter which accounts you’re using, you get the same error.
Solutions
A lot of things could cause this – without getting access to more log information, the error is very ambiguous. However, a lot of times it’s related to the badly documented, built-in permissions that Publishing infrastructure requires. And those can usually be fixed, as long as you figure out what the actual issue is.
Let’s take a look at a few different solutions you could try and see if they help!
Fix the style/design resource permissions
In a lot of cases, this issue is thrown because someone messed around with the built-in SharePoint permissions. Let’s see how to fix that!
I was originally led to this solution from this blog, which seems to have been removed since then: https://savtechsol-public.sharepoint.com/Education/BeckysBlog/Lists/Posts/Post.aspx?ID=174. I guess that’s what you get for using SharePoint Online’s public-facing sites… :)
Despite being removed, the blog post seems to be mirrored on this content-stealing website (not worth actually linking to them – stealing content is pretty bad-mannered): http[://]sptrac.com/wordpress/?p=3003
I think the blog post was originally posted by Becky Bertram. It says:
It turns out that the Restricted Readers group is natively assigned permission to several libraries in a Publishing Site Collection, such as the Master Page Gallery, the Site Collection Images, the Style Library, etc. (You can see what permissions the Restricted Readers group has by going to the View Groups page, selecting the Restricted Readers group, then clicking on the Settings item in the toolbar and selecting View Group Permissions.)
“Restricted Readers” is a prime example of a hazardous group, and “Style Resource Readers” (and their respective translations to all the different localizations) is another. They are used by SharePoint internally, so don’t mess with them! They are very, very much required in order for the Publishing infrastructure to work at all.
Of these 2 groups, Restricted Readers doesn’t have any visible members by default, but Style Resource Readers does. See the default members below.
Are those 2 groups intact and are members ok? Next thing to try!
How to create a subsite in Sharepoint
Time needed: 20 minutes
https://[siteurl]/Style Library/
See the correct permissions below!
https://[siteurl]/_catalogs/wp
Generally speaking, this list should inherit its permissions, so the first step might be to reset unique permissions if it has them.
https://[siteurl]/Lists/TaxonomyHiddenList/AllItems.aspx
Try giving ‘everyone‘ everyone read access and your timer service account ‘full control’ to the following list. I ran across this issue in the past and that resolved the issue.
It might also be worth it to add “View Items” permissions level to “Anonymous Users” – that sounds hazardous, but that’s the default setting
This list is a pain to work with.
You could at the very least check if you can access it.
See further below for a code example.
Below, you can see an example of how to access the UserInfoList. This example just lists the fields of the list, but you could also loop through the users (to verify that they are populating) or reset the list’s permissions if nothing else is helping.<pre lang ="csharp">var usersList =
clientContext.Site.RootWeb.SiteUserInfoList;
ctx.Load(usersList); // ctx is your client context
// check that this list is not completely broken - list and access its fields
foreach (SPField f in usersList.Fields)
{
System.Console.WriteLine("{0} - {1}",f.Title, f.InternalName);
}</pre>
Did that all help at all? No? Try the last resort solution in the final step
Okay, in that case, your next thing to try is going to be digging into the ULS logs. There’s a lot you have to go through, most likely, so better get started :) Look for any words like “unauthorized”, (or even just “authorized”, for “not authorized..), 401, “Access denied”, or even just “access”…
Good luck!
References and sources
These posts describe the reasoning behind some of these changes:
- https://social.technet.microsoft.com/Forums/office/en-US/3992261c-c102-4b4a-9864-cf8e8de95814/cannot-create-sub-site-even-with-full-permission?forum=sharepointadmin
- https://social.technet.microsoft.com/Forums/Lync/en-US/c0066b0c-e095-4335-83d3-55b71bfee761/access-denied-when-creating-a-subsite-with-a-user-who-has-full-control?forum=sharepointadminprevious
- https://social.technet.microsoft.com/Forums/azure/en-US/88d64e3a-55d8-41f4-a6cb-78671aa7562f/sub-site-creation-fails-works-but-access-is-denied-autodelete?forum=sharepointadmin
- Weirdnesses of the UserInfoList: https://zimmergren.net/sharepoints-hidden-user-list-user-information-list/
- And about the disgusting tweaks, everyone always forgets to apply when configuring Distributed Cache: https://docs.microsoft.com/en-us/SharePoint/administration/configure-object-cache-user-accounts
- TaxonomyHiddenList: https://social.technet.microsoft.com/Forums/sharepoint/en-US/b77c5983-dee6-4e94-b7f8-981ef399bb26/site-owner-unable-to-save-template?forum=sharepointadminprevious
- 2024 Year Review – and 20 years in business! - December 31, 2024
- Merging on GitHub Actions fails with “could not read Username for ‘https://github.com’: No such device or address”? - December 24, 2024
- How to close the Sidebar in Microsoft Edge - December 17, 2024