• <i id='6EFpW'><tr id='6EFpW'><dt id='6EFpW'><q id='6EFpW'><span id='6EFpW'><b id='6EFpW'><form id='6EFpW'><ins id='6EFpW'></ins><ul id='6EFpW'></ul><sub id='6EFpW'></sub></form><legend id='6EFpW'></legend><bdo id='6EFpW'><pre id='6EFpW'><center id='6EFpW'></center></pre></bdo></b><th id='6EFpW'></th></span></q></dt></tr></i><div id='6EFpW'><tfoot id='6EFpW'></tfoot><dl id='6EFpW'><fieldset id='6EFpW'></fieldset></dl></div>

    <small id='6EFpW'></small><noframes id='6EFpW'>

        <legend id='6EFpW'><style id='6EFpW'><dir id='6EFpW'><q id='6EFpW'></q></dir></style></legend><tfoot id='6EFpW'></tfoot>

          <bdo id='6EFpW'></bdo><ul id='6EFpW'></ul>

        用于服务应用程序的 Google oAuth 2.0(JWT 令牌请求

        时间:2023-06-03

          <i id='jg21V'><tr id='jg21V'><dt id='jg21V'><q id='jg21V'><span id='jg21V'><b id='jg21V'><form id='jg21V'><ins id='jg21V'></ins><ul id='jg21V'></ul><sub id='jg21V'></sub></form><legend id='jg21V'></legend><bdo id='jg21V'><pre id='jg21V'><center id='jg21V'></center></pre></bdo></b><th id='jg21V'></th></span></q></dt></tr></i><div id='jg21V'><tfoot id='jg21V'></tfoot><dl id='jg21V'><fieldset id='jg21V'></fieldset></dl></div>

          <tfoot id='jg21V'></tfoot>
          • <bdo id='jg21V'></bdo><ul id='jg21V'></ul>
            • <legend id='jg21V'><style id='jg21V'><dir id='jg21V'><q id='jg21V'></q></dir></style></legend>

              <small id='jg21V'></small><noframes id='jg21V'>

                <tbody id='jg21V'></tbody>
                  本文介绍了用于服务应用程序的 Google oAuth 2.0(JWT 令牌请求)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                  问题描述

                  限时送ChatGPT账号..

                  我正在尝试为此处描述的服务帐户实施 Google oAuth 2:https://developer.google.com/accounts/docs/OAuth2ServiceAccount 在 UnityScript(或 C# - 没关系,因为它们都使用相同的 Mono .NET 类).

                  I'm trying to implement Google oAuth 2 for service accounts described here: https://developers.google.com/accounts/docs/OAuth2ServiceAccount on UnityScript (or C# - that doesn't matter because they both use the same Mono .NET classes).

                  我在这里找到了类似的主题:Is there a JSON Web Token (JWT) example in C#?web-token-jwt-example-in-c 但我还是没有成功.

                  I've found similar topic here: Is there a JSON Web Token (JWT) example in C#? web-token-jwt-example-in-c but I still don't have a success.

                  首先,我已经生成了标题和声明集(就像在谷歌文档中一样)

                  Fist of all, I have generated header and claimset (that are just like in google documentation)

                  var header: String = GetJWTHeader();
                  var claimset: String = GetJWTClaimSet();
                  

                  结果是(为清楚起见,用新行分隔):

                  The result is (separated with new lines for clarity):

                  {"alg":"RS256","typ":"JWT"}

                  {"alg":"RS256","typ":"JWT"}

                  {"iss":"425466719070-1dg2rebp0a8fn9l02k9ntr6u5o4a8lp2.apps.googleusercontent.com",

                  {"iss":"425466719070-1dg2rebp0a8fn9l02k9ntr6u5o4a8lp2.apps.googleusercontent.com",

                  "范围":"https://www.googleapis.com/auth/prediction",

                  "aud":"https://accounts.google.com/o/oauth2/令牌",

                  "exp":1340222315,

                  "exp":1340222315,

                  "iat":1340218715}

                  "iat":1340218715}

                  Base-64 编码方式:

                  Base-64 encoding methods:

                  public static function Base64Encode(b: byte[]): String {
                      var s: String = Convert.ToBase64String(b);
                      s = s.Replace("+", "-");
                      s = s.Replace("/", "_");
                      s = s.Split("="[0])[0]; // Remove any trailing '='s
                      return s;
                  }
                  
                  public static function Base64Encode(s: String): String {    
                      return Base64Encode(Encoding.UTF8.GetBytes(s));
                  }
                  

                  那我要签名了.

                  var to_sign: byte[] = 
                       Encoding.UTF8.GetBytes(Base64Encode(header) + "." + Base64Encode(claimset));
                  var cert: X509Certificate2 = 
                       new X509Certificate2(google_pvt_key.ToArray(), "notasecret");
                  var rsa: RSACryptoServiceProvider = cert.PrivateKey;
                  var sgn: String = Base64Encode(rsa.SignData(to_sign, "SHA256"));
                  
                  var jwt: String = Base64Encode(header) + "." + Base64Encode(claimset) + 
                                       "." + sgn;
                  

                  然后形成请求:

                  var url: String = "https://accounts.google.com/o/oauth2/token";
                  var form: WWWForm = new WWWForm();
                  form.AddField("grant_type", "assertion");
                  form.AddField("assertion_type", "http://oauth.net/grant_type/jwt/1.0/bearer");
                  form.AddField("assertion", jwt);
                  var headers: Hashtable = form.headers;
                  headers["Content-Type"] = "application/x-www-form-urlencoded";
                  
                  var www: WWW = new WWW(url, form.data, headers);
                  

                  我得到的只是错误 400:错误请求".

                  编码后的数据看起来像(为清楚起见添加了换行符):

                  The encoded data looks like (line breaks added for clarity):

                  eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.

                  eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.

                  eyJpc3MiOiI0MjU0NjY3MTkwNzAtMWRnMnJlYnAwYThmbjlsMDJrOW50cjZ1NW80YThscDIuYXBwcy5nb29nbGV1c2VyY29udGVudC5jb20iLCJzY29wZSI6Imh0dHBzOi8vd3d3Lmdvb2dsZWFwaXMuY29tL2F1dGgvcHJlZGljdGlvbiIsImF1ZCI6Imh0dHBzOi8vYWNjb3VudHMuZ29vZ2xlLmNvbS9vL29hdXRoMi90b2tlbiIsImV4cCI6MTM0MDIyMjMxNSwiaWF0IjoxMzQwMjE4NzE1fQ.

                  eyJpc3MiOiI0MjU0NjY3MTkwNzAtMWRnMnJlYnAwYThmbjlsMDJrOW50cjZ1NW80YThscDIuYXBwcy5nb29nbGV1c2VyY29udGVudC5jb20iLCJzY29wZSI6Imh0dHBzOi8vd3d3Lmdvb2dsZWFwaXMuY29tL2F1dGgvcHJlZGljdGlvbiIsImF1ZCI6Imh0dHBzOi8vYWNjb3VudHMuZ29vZ2xlLmNvbS9vL29hdXRoMi90b2tlbiIsImV4cCI6MTM0MDIyMjMxNSwiaWF0IjoxMzQwMjE4NzE1fQ.

                  lIFg7-Og_BcC5qpICLt7USwGIHUOz-vV4ADNq0AWhuRtsvFrbZn5mxk4n9r5qU66q4reTVVAtuW06DeGsdcBMNgEdIMvN6VuYQybs64p9mqrfECBYxO1FWHbUG-2On1IpowybEsRRUjZfp0jFuEY7S

                  lIFg7-Og_BcC5qpICLt7USwGIHUOz-vV4ADNq0AWhuRtsvFrbZn5mxk4n9r5qU66q4reTVVAtuW06DeGsdcBMNgEdIMvN6VuYQybs64p9mqrfECBYxO1FWHbUG-2On1IpowybEsRRUjZfp0jFuEY7SLE3XRaXan0k5zmejcvLQo

                  我花了两天时间试图找出问题所在,但我看不到.

                  I've spent two days trying to figure out what is wrong but I can't see.

                  另外,我找不到任何合适的文档和示例.

                  Also, I couldn't find any suitable documentation and examples.

                  我只是想收到一个令牌.

                  I'm trying just to recieve a token.

                  1. 我是否以正确的方式签署字节?
                  2. 声明集中的范围"参数应该是什么样的?我试过https://www.googleapis.com/auth/devstorage.readonly"和https://www.googleapis.com/auth/prediction".
                  3. iss"参数应该等于什么?客户 ID 或电子邮件地址?(都试过了)
                  4. 有什么方法可以找出我的错误?
                  5. 是否有任何用于服务应用程序的 C# 库(不适用于已安装的应用程序或客户端登录)?

                  我快疯了......它必须工作,但它没有......:-/

                  I'm getting crazy... It has to work, but it doesn't... :-/

                  推荐答案

                  解决方案是在请求代码中所有斜杠都必须反斜杠

                  The solution was that in request code all slashes have to be backslashed

                  错误:

                  "scope":"https://www.googleapis.com/auth/prediction",
                  "aud":"https://accounts.google.com/o/oauth2/token",
                  

                  正确:

                  "scope":"https:\/\/www.googleapis.com\/auth\/prediction",
                  "aud":"https:\/\/accounts.google.com\/o\/oauth2\/token",
                  

                  这篇关于用于服务应用程序的 Google oAuth 2.0(JWT 令牌请求)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                  上一篇:如何使用对称密钥配置 Microsoft JWT? 下一篇:.NET JWT 令牌验证的命名空间:系统与 Microsoft

                  相关文章

                  最新文章

                  1. <tfoot id='TRib8'></tfoot>
                  2. <legend id='TRib8'><style id='TRib8'><dir id='TRib8'><q id='TRib8'></q></dir></style></legend>

                  3. <i id='TRib8'><tr id='TRib8'><dt id='TRib8'><q id='TRib8'><span id='TRib8'><b id='TRib8'><form id='TRib8'><ins id='TRib8'></ins><ul id='TRib8'></ul><sub id='TRib8'></sub></form><legend id='TRib8'></legend><bdo id='TRib8'><pre id='TRib8'><center id='TRib8'></center></pre></bdo></b><th id='TRib8'></th></span></q></dt></tr></i><div id='TRib8'><tfoot id='TRib8'></tfoot><dl id='TRib8'><fieldset id='TRib8'></fieldset></dl></div>

                      <small id='TRib8'></small><noframes id='TRib8'>

                        <bdo id='TRib8'></bdo><ul id='TRib8'></ul>