More TroubleShooting Tips for High Trust Apps on SharePoint 2013


Hey, I'm an app guy, I like doing dev, but honestly – I may go hoarse screaming at my computer if I have to track down one more "The issuer of the token is not a trusted issuer" problem with my new SharePoint apps.  To try and help you save your own voice (and sanity) I'm going to start a list here of things that I look for when I get this issue.  As I discover new and exciting ways of both invoking this error and resolving it, I will just update the post here and throw an "UPDATED!" doo hickey below. 

It's important to remember when I say "high trust app", that means that you are NOT using ACS as the trust broker for your SharePoint app; instead your are creating the OAuth token and signing it with your own certificate.  I know we have this whole process documented out there somewhere so I'm not going to try and describe that here again.  I'm going to assume you read it, you've been trying it, and now you are ready to give the one-finger salute to your monitor.  So, that being said, here are some of the ways I've seen this error occur:

  1. Add to the SPTrustedRootAuthority list – when you use a certificate to sign your OAuth tokens, you need to create a New-SPTrustedRootAuthority.  Just like the New-SPTrustedIdentityTokenIssuer in SharePoint 2010, you need to add the token signing certificate and every certificate in the chain to SharePoint's list of trusted authorities.  You can follow the same steps for this process as I described in this post:  http://blogs.technet.com/b/speschka/archive/2010/02/13/root-of-certificate-chain-not-trusted-error-with-claims-authentication.aspx.   Just ignore the stuff about exporting the certificate from ADFS – I'm assuming you created your certificate for your high trust apps via some other means – public root CA like GoDaddy, VeriSign, etc., self-signed cert, or domain issued cert.
  2. Client ID uses all uppercase characters – as I described in another post, make sure that you do NOT use uppercase letters when you plug in the client ID in the AppManifest.xml file of your application, or in the web.config of your web application if you are building a self-hosted solution.  For more details see this:  http://blogs.technet.com/b/speschka/archive/2012/07/28/an-important-tip-about-client-id-values-for-s2s-apps-in-sharepoint-2013.aspx.
  3. Token issuer not configured as trust broker – I also described this problem in another post here:  http://blogs.technet.com/b/speschka/archive/2012/09/27/another-apps-for-sharepoint-tip-with-the-error-quot-the-issuer-of-the-token-is-not-a-trusted-issuer-quot.aspx.  The net of this is make sure when you create your New-SPTrustedSecurityTokenIssuer that you include the -IsTrustBroker flag.
  4. UPDATED!:  Missing the IssuerId key in web.config – In order to use the trust broker feature of apps in SharePoint 2013, your application has to know what the IssuerId of the trust broker is when it creates the JWT token it sends to SharePoint.  The way it knows this is by looking in web.config for an app property called IssuerId.  It goes the same place in your application's web.config as ClientId, ClientSecret, etc.  It just looks like this:  <add key="IssuerId" value="e9134021-0180-4b05-9e7e-0a9e5a524965"/>.
  5. UPDATED!:  Using the Office Tools RTM Preview for Visual Studio – there actually is a little bug in the RTM Preview bits, which is fixed in Preview 2.  The code that sends that authorization token to SharePoint doesn't look for the IssuerId element in web.config, instead it sends a different value.  What it sends and why is not really important; what IS important is that the way you work around this with that version of the tools is to always use the IssuerId value for the SPTrustedSecurityTokenIssuer in the ClientId key in your web.config.  As you get the Preview 2 bits please install them right away and change the ClientId to a unique GUID that you create and register (with Register-SPAppPrincipal as explained below).  You don't want the ClientIds to all be the same because it identifies what application signed the OAuth token, and is used throughout the SharePoint UI.  If you ever need to do any troubleshooting or auditing it will be a problem if all apps use the same value.  UPDATED Part 2!:  The Preview 2 bits are now available!  You can find them at http://www.microsoft.com/web/handlers/WebPI.ashx?command=GetInstallerRedirect&appid=OfficeToolsForVS2012GA.
  6. UPDATED!:  Authentication not Configured on Provider Hosted App – you may have gotten everything working and then create a provider hosted app hosted in IIS instead of IIS Express (see here for more details on this process:  http://blogs.technet.com/b/speschka/archive/2013/06/12/converting-a-vs-net-web-for-a-provider-hosted-sharepoint-app-to-a-full-blown-web-or-console-application.aspx).  Despite that, when the code runs in your app you get access denied again.  Here's a tip – set a breakpoint in TokenHelper.cs in the GetClaimsWithWindowsIdentity method, and then look at the identity.User.Value.  If you see a very short SID value, like S-1-5-17, then that probably means it's the anonymous account for IIS.  The SID for a "real" user is much longer, something like S-1-5-21-1644491937-1935655697-1957994488-2138.  Remember that the way OAuth works (in the most common case with SharePoint Apps) is that it checks to make sure BOTH the app AND the user have rights to the content.  In most cases the anonymous user account will not have rights, and so you will get an access denied error message.  To fix this you need to go into IIS and find your provider hosted app, then disable Anonymous access and enable Windows authentication.  I recommend restarting the IIS virtual server for your hosted app, then try again.

Now, there's also a related issue worth noting:  suppose you "think" you've gotten past this error, but then you get an Access Denied error when trying to retrieve content from a SharePoint site in your self-hosted application?  Well what that can mean is:

  1. The ClientId value in your AppManifest.xml file for your SharePoint app does not match the ClientId value in the web.config for your self-hosted app.  We're making improvements to the Visual Studio tools that should alleviate this problem going forward.

Now a nearly equally good question is how do I track down stuff like this when it happens?  Well if it were easy I wouldn't be hoarse and saluting my monitor with one finger.  But here's the best data sources I've found so far to use when this problem happens.  Again, as I find new things I will add to the list:

  1. ULS logs – a perennial favorite, especially at holiday parties, I like to crank open the ULS logs and just admire the sheer volume of data.  Okay, that was sarcasm.  But what you can really do is go into Central Admin, Monitoring, Configure diagnostic logging.  Expand the SharePoint Foundation category and select the following items:  App Auth, Application Authentication, Authentication Authorization and Claims Authentication.  Setting the logging and trace level to Verbose for these guys and save your changes, then go and try and launch your application again.  Grab one of the many ULS log viewing tools to see your request come in and being processed.  It's a good way to gather hints about your app authentication issues.
  2. Fiddler – also a fan favorite, Fiddler is very useful for these situations too.  What you will most frequently see is a 401 unauthorized error (like whenever the underlying issue is the "issuer of the token is not a trusted issuer").  If you look at the last frame in the request and click on the Headers tab in the Response frame you will see a WWW-Authenticate cookie that looks something like this:  Bearer realm="8a96481b-6c65-4e78-b2ef-a446adb79b59",client_id="00000003-0000-0ff1-ce00-000000000000",trusted_issuers="e9134021-0180-4b05-9e7e-0a9e5a524965@8a96481b-6c65-4e78-b2ef-a446adb79b59,00000003-0000-0ff1-ce00-000000000000@8a96481b-6c65-4e78-b2ef-a446adb79b59" .  So what can you take away from this?  Well I know from looking at this that it expects my ClientId value to be e9134021-0180-4b05-9e7e-0a9e5a524965 and it expects my realm to be 8a96481b-6c65-4e78-b2ef-a446adb79b59.  The ClientId value is easy enough to check – I can go look in my AppManifest.xml file and my web.config for my self-hosted app.  It's extremely unlikely that your realm would be wrong, but you can always verify by running this PowerShell:

$spurl ="https://foo"
$spsite = Get-SPSite $spurl
$realm = Get-SPAuthenticationRealm -ServiceContext $spsite
$realm

That will output to the screen whatever your realm is.  Finally, there's one other thing you can do to verify – make sure that you have an appPrincipal created for the ClientId you are using.  Again here's some PowerShell you can use to check that, using my WWW-Authenticate header info from above:

Get-SPAppPrincipal -NameIdentifier e9134021-0180-4b05-9e7e-0a9e5a524965@8a96481b-6c65-4e78-b2ef-a446adb79b59 -Site https://foo

If you get an error or no results then you know you don't have a valid SPAppPrincipal so you need to create one using PowerShell.  For completeness, here's an example of that:

$clientId = "some guid you create"
$spurl ="https://foo"
$spsite = Get-SPSite $spurl
$realm = Get-SPAuthenticationRealm -ServiceContext $spsite
$fullAppIdentifier = $clientId + '@' + $realm
$appPrincipal = Register-SPAppPrincipal -NameIdentifier $fullAppIdentifier -Site $spsite.OpenWeb() -DisplayName "My Cool App"

Okay, and with that, my list of high trust app troubleshooting tips is exhausted for today, as am I.  When or if I have more news I will update this post.

 

 

 

 

Comments (15)

  1. Anonymous says:

    How to publish this in on-premise app stores (Organization app store)?

  2. alexandrad9x says:

    Tao http://dichvuketoanlongbien.com/
    Rủa
    http://dichvuketoanlongbien.com/a2-96-dich-vu-ke-toan-tron-goi.html
    Thằng http://dichvuketoanlongbien.com/a2-98-dich-vu-ke-toan-thue.html
    Cờ
    http://dichvuketoanlongbien.com/a2-103-dich-vu-bao-cao-tai-chinh.html
    http://dichvuketoanlongbien.com/a2-97-dich-vu-quyet-toan-thue.html
    Nào
    http://dichvuketoanlongbien.com/a2-114-dich-vu-ke-toan-tai-29-quan-huyen.html
    Soi
    http://dichvuketoanlongbien.com/i780-dich-vu-ke-toan-thue-tron-goi-tai-bac-ninh.html
    Tài
    http://dichvuketoanlongbien.com/i779-dich-vu-ke-toan-thue-tron-goi-tai-bac-giang.html
    Khoản
    http://dichvuketoanlongbien.com/i778-dich-vu-ke-toan-thue-tron-goi-tai-phu-tho.html

    http://dichvuketoanlongbien.com/i781-dich-vu-ke-toan-thue-tron-goi-tai-hung-yen.html
    Link
    http://dichvuketoanlongbien.com/i782-dich-vu-ke-toan-thue-tron-goi-tai-vinh-phuc.html
    Của
    http://dichvuketoanlongbien.com/i783-dich-vu-ke-toan-thue-tron-goi-tai-hai-phong.html
    Tao. http://www.trungtamketoan.com.vn/
    Chúng
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-ha-noi.html
    Mày
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-tp-hcm.html
    Đủ
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-quang-ninh.html
    Trình
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-hai-duong.html
    Thì
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-bac-giang.html
    Tự
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-bac-ninh.html
    Đi
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-hai-phong.html

    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-nam-dinh.html
    Làm.
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-thai-binh.html
    Việc
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-thanh-hoa.html

    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-vinh-phuc.html
    Phải
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-hung-yen.html
    Rẻ
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-phu-tho.html
    Rách
    http://www.trungtamketoan.com.vn/p/trung-tam-dao-tao-ke-toan-tai-binh-duong.html
    Như http://www.tosvn.com
    Thế. http://iketoan247.blogspot.com
    Loại http://tailieuveketoan.blogspot.com
    Chó http://mauhinhnendep.blogspot.com
    Má. http://www.tosvn.com/search/label/Hack%20CF
    Tao http://www.tosvn.com/search/label/Hack%20AvatarStar
    Rủa http://www.tosvn.com/search/label/Hack%20Warcraft-Dota2
    Những http://hocketoan360.com/category/tai-lieu-ke-toan/
    Thằng http://iketoan247.blogspot.com/search/label/thong-tin-kinh-te
    Soi http://iketoan247.blogspot.com/search/label/tin-bai-ve-thue
    Tao http://hoclamketoan.edu.vn/
    Sẽ http://hoclamketoan.edu.vn/category/khoa-hoc-ke-toan
    Tan http://hoclamketoan.edu.vn/category/dich-vu-ke-toan
    Cửa http://hoclamketoan.edu.vn/category/hoc-lam-ke-toan
    Nát http://hoclamketoan.edu.vn/category/tai-lieu-ke-toan
    Nhà http://hocketoan360.com/
    Haha http://hocketoan360.com/category/khoa-hoc-ke-toan/
    http://hocketoan360.com/category/dich-vu-ke-toan/

  3. Vinayak Sidnal says:

    Hi Steve,
    Thanks for sharing very useful information.

    I have a scenario where I’m unable to troubleshoot one of the issue with the SharePoint Provider Hosted high trust app.

    Whenever I access Provider hosted app from the HTTPS SharePoint site address I’m getting this error – "The remote certificate is invalid according to the validation procedure" and web exception says – "The underlying connection was closed: Could not establish
    trust relationship for the SSL/TLS secure channel."

    From this error I understand that the trust between the SharePoint site and the Provider Hosted app must be configured. I did by adding both certificates used for the SharePoint site and the Provider hosted app in the Central admin trusts, as well Machine trusted
    root certificates. But still the error persists.

    Any help on this?

  4. saluting your monitor with one finger says:

    Great article, I like the part saluting your monitor with one finger 🙂

  5. paslatek says:

    Hi, thanks for sharing theses tips !

    However, the link about setup Root Authorities is broken 🙁

    Another question : Where can I pick the IssuerID value to use in my web.config ? Is it the Id of object returned by the New-SPTrustedSecurityTokenIssuer cmdlet ?

  6. Dave W. says:

    We keep getting an error which states that the SPAppToken is blank and Azure Access Control Services is not available. This is a self contained on prem app (not using o365 or azure)

    is SPAppToken related to Azure ACS and is this why SPAppToken is blank?

    Do I need to install and configure Azure ACS on a on-prem environment? If so, what do i install… i thought this was installed a pre-req for SP2013… if not, is there a configuration to turn this off?

  7. Pankaj Surti says:

    Great Article! I like the salute part humor.

  8. Mikel says:

    The Fiddler troubleshooting tip and the information on clientId was exactly what I needed. Thanks so much!

  9. emzero says:

    I have tried everything here and I'm still getting 401.

    I've been having this problem for a few weeks now, I don't know what else to try…

  10. Sivadutta says:

    Hi,

    I have successfully created a provider hosted app in my machine, having IIS & SharePoint 2013 both.
    Now I want to deploy the app to another machine(in premises) which have IIS + SharePoint 2013.
    I followed every article published, but still unable to get the thing working. Please help me, below is the stuck points.

    1. I am able to get the app page(default.aspx-inside Web project), after adding the app.
    2. I am able to get the html controls & any response.write strings.

    Problem Facing area:
    1. ClientContext ctx = new ClientContext(“hosturl”) : Failed here
    2. Used Kirk Ivans code & steps:(http://blogs.msdn.com/b/kaevans/archive/2013/02/23/sharepoint-2013-app-only-policy-made-easy.aspx“) : Failed to resolve Token Helper-File not found & Private key not available(X509 error).
    3. Followed your coding, same error as above.

    Please help me how to resolve.

    Thanks in advance,
    Siva

  11. NGKPrasad says:

    after I enabled ssl in appweb hosted in remote web iis server, I received error access denied for my provider hosted app.( Access denied. You do not have permission to perform this action or access this resource. ),Please help me resolve this .
    thanks in advance

  12. Ladiebugged says:

    Hi thanks for the great article. I got our provider-hosted app up and running on-prem using high-trust. However during user testing, they encountered a 401 issue after being idle in IE for a few minutes. It seems that the connection to SP has been lost.
    The app is using kerberos with NTLM as fallback and the SP web app is configured to kerberos. Any idea would be great. Thanks

  13. Ramee says:

    Hi Steve,
    Very useful article. I developed a high trust provider app for sharepoint 2013 and deployed in sharepoint on premises.

    App is not redirecting to my website hosted in IIS and it is not working. The same is working from visual studio hosted in IIS express. I tried to debug and the problem is in SharepointContextFilterAttribute. It always goes to CanNotRedirect switch case. I
    am quiet new to this and struggling with this for past two days. Can you please help me to resolve this?

    Thanks

  14. Anonymous says:

    Hopefully by now everyone has heard about the new app model in SharePoint 2013. There’s a lot of

  15. Anonymous says:

    Let me preface this posting by saying a couple of things:

    This is not going to be a "how do