获取'<'在第1行第0列."当试图使用googleapi库连接到谷歌时

本文关键字:googleapi 连接 谷歌 1行第 在第 0列 quot 获取 | 更新日期: 2023-09-27 18:12:26

我正在使用Google api,而不是Google Sign In,连接到我的应用程序上的Google,因为我正在使用Xamarin开发。

这是我正在使用的库:https://github.com/xamarin/google-apis

当我登录时,我得到这个错误:

验证误差意外字符'<'。第1行,第0列

也许是因为我的AccessTokenUrl不是很好,但我已经尝试了很多东西。我知道一个事实,我的ClientId,我的RedirectUrl和我的Secret是好的。

当登录时,谷歌正确地询问我想要的良好权限,但在我接受后,这是我收到错误的时候。

我试图找到请求,看看是否有'<'在其中,但没有运气访问它。

是否有一个好方法来连接到谷歌与Xamarin使用这个库或我只是做一些不好的?

我应该直接在iOS和Android上做吗?

谢谢

获取'<'在第1行第0列."当试图使用googleapi库连接到谷歌时

我刚刚在使用Xamarin时遇到了类似的问题。Auth访问自定义OAuth服务(即不是Google)。在我的例子中,accessTokenUrl指向控制器上的一个完全由[Authorize]属性保护的操作。当然,用户需要在使用web浏览器访问/oauth/authorize端点之前登录,但是请求/oauth/token交换访问令牌的结果授权码不在同一web浏览器/会话中。它试图以JSON格式获取令牌数据,但被重定向到HTML登录屏幕。一旦我将令牌端点更改为匿名访问,事情就开始工作了(注意:不经过身份验证就无法获得有效的授权代码)。

一般建议

错误消息强烈提示返回的响应是HTML(或至少某种形式的XML)。这可能是我的场景中的身份验证重定向,也可能是某种错误页面。我将首先设置一个代理。我利用Charles Proxy发现了一些有趣的信息。您需要在代理上配置SSL以查看除高级信息以外的任何信息。这将显示从你的应用程序发送到OAuth应用程序的确切请求。

我使用的另一种技术是模拟OAuth2Authenticator在web浏览器和/或Postman中发出的请求。第一个请求是授权:

https://your.domain.here/oauth/authorize?client_id=<some_client_id>&redirect_uri=https%3A%2F%2Fyour.domain.here%2F&response_type=code&scope=<some_scope>&state=<some_state>

该端点应该受到保护,因此您可能会被重定向到如下内容:

https://your.domain.here/Account/Login?returnurl=%2Foauth%2Fauthorize%3Fclient_id%3D<some_client_id>%26redirect_uri%3Dhttp%253A%252F%252Fyour.domain.here%252F%26response_type%3Dcode%26scope%3D<some_scope>%26state%3D<some_state>

验证之后,授权端点应该重定向到您的重定向URI,其中包含作为查询字符串参数的授权代码和状态。您将在下一步中使用该代码。

最后,使用新的web浏览器(即新的会话),您应该使用新的授权码和其他客户端信息击中令牌端点。

https://your.domain.here/oauth/token?client_id=<some_client_id>&client_secret=<some_secret>&grant_type=<your_grant_type>&code=<your_authorization_code>&redirect_uri=https%3A%2F%2Fyour.domain.here%2F

如果响应不是JSON数据,它应该告诉您Xamarin失败的原因。

得到相同的错误。通过使用https://accounts.google.com/o/oauth2/token作为AccessTokenUrl

解决