# Google APIs
使用带有VBA-Web的Google API的示例包含在项目的`examples /`文件夹中。 一些细节:
## [](https://github.com/VBA-tools/VBA-Web/wiki/Google-APIs#authentication)Authentication授权
有许多方法可以使用Google的OAuth 2.0身份验证,但是要与VBA-Web一起使用,不能使用任何需要回调网址的方法。 这限制了[已安装的应用程序/设备](https://developers.google.com/accounts/docs/OAuth2#installed)的身份验证方法。
1. 转到[Google的API控制台](https://code.google.com/apis/console#access)以使用Google创建新的应用程序。 在“客户端ID设置”部分,选择“已安装的应用程序和其他”。 存储生成的客户端ID和密码。
2. 确定应用程序的所需范围。 例如,要访问Google Analytics数据,需要在范围内将其定义为`https://www.googleapis.com/auth/analytics.readonly`。 通常,每个范围都以`https://www.googleapis.com/auth/`作为前缀,然后添加特定范围。 有关可用范围的列表,请访问[Google OAuth 2.0 Playground](https://developers.google.com/oauthplayground/)
3. 将`GoogleAuthenticator`类添加到项目中并按如下方式进行设置:
~~~vbnet
Dim Auth As New GoogleAuthenticator
Auth.Setup _
ClientId:="ClientId", _
ClientSecret:="ClientSecret"
Auth.Scope = Array("https://www.googleapis.com/auth/analytics.readonly")
Auth.Login
Set Client.Authenticator = Auth
~~~
## [](https://github.com/VBA-tools/VBA-Web/wiki/Google-APIs#example-request)Example Request请求范例
通过客户端的身份验证设置,您可以使用正常的请求配置。 以下是用于检索Google Analytics数据以及如何设置请求的所需网址示例:
~~~vbnet
'// 期望的请求: GET https://www.googleapis.com/analytics/v3/data/ga
'// ?ids=ga:12345
'// &start-date=2008-10-01
'// &end-date=2008-10-31
'// &metrics=ga:visits,ga:bounces
'// Client.BaseUrl = "https://www.googleapis.com/analytics/v3/"
Public Function AnalyticsRequest(ProfileId As String, StartDate As Date, EndDate As Date) As RestRequest
Set AnalyticsRequest = New WebRequest
AnalyticsRequest.Resource = "data/ga"
AnalyticsRequest.Method = WebMethod.HttpGet
AnalyticsRequest.AddQuerystringParam "ids", "ga:" & ProfileId
AnalyticsRequest.AddQuerystringParam "start-date", Format(StartDate, "yyyy-mm-dd")
AnalyticsRequest.AddQuerystringParam "end-date", Format(EndDate, "yyyy-mm-dd")
AnalyticsRequest.AddQuerystringParam "metrics", "ga:visits,ga:bounces"
End Function
~~~
### [](https://github.com/VBA-tools/VBA-Web/wiki/Google-APIs#links)链接:
* [使用OAuth 2.0访问Google API,已安装的应用程序/设备](https://developers.google.com/accounts/docs/OAuth2#installed)
* [将OAuth 2.0用于已安装的应用程序](https://developers.google.com/accounts/docs/OAuth2InstalledApp)
* [Google OAuth 2.0 Playground](https://developers.google.com/oauthplayground/)
- README
- 指南
- 概述
- GET Request
- WebRequest
- 属性
- Resource
- Method
- Body
- Format
- RequestFormat
- ResponseFormat
- CustomRequestFormat
- CustomResponseFormat
- ContentType
- Accept
- ContentLength
- FormattedResource
- Cookies
- Headers
- QuerystringParams
- UrlSegments
- 方法
- AddHeader
- SetHeader
- AddUrlSegment
- AddQuerystringParam
- AddCookie
- AddBodyParameter
- CreateFromOptions
- WebClient
- 属性
- BaseUrl
- Authenticator
- TimeoutMs
- ProxyServer
- ProxyBypassList
- ProxyUsername
- ProxyPassword
- EnableAutoProxy
- Insecure
- FollowRedirects
- 方法
- Execute
- GetJson
- PostJson
- SetProxy
- GetFullUrl
- WebResponse
- 属性
- StatusCode
- StatusDescription
- Content
- Data
- Body
- Headers
- Cookies
- 方法
- Update
- WebHelpers
- 属性
- WebStatusCode
- WebMethod
- WebFormat
- UrlEncodingMode
- EnableLogging
- 方法
- LogDebug
- LogWarning
- LogError
- LogRequest
- LogResponse
- Obfuscate
- ParseJson
- ConvertToJson
- ParseUrlEncoded
- ConvertToUrlEncoded
- ParseXml
- ConvertToXml
- ParseByFormat
- ConvertToFormat
- UrlEncode
- UrlDecode
- Base64Encode
- Base64Decode
- RegisterConverter
- JoinUrl
- UrlParts
- CloneDictionary
- CloneCollection
- CreateKeyValue
- FindInKeyValues
- AddOrReplaceInKeyValues
- FormatToMediaType
- MethodToName
- HMACSHA1
- HMACSHA256
- MD5
- CreateNonce
- IWebAuthenticator
- 方法
- BeforeExecute
- AfterExecute
- PrepareHttp
- PrepareCurl
- WebAsyncWrapper
- 属性
- Client
- 方法
- ExecuteAsync
- 范例
- Salesforce网站
- Google APIs
- Todoist API
- 其他主题
- 调试
- 授权
- 实现自己的IWebAuthenticator
- Url编码