VBA获取token方法

获取token方法

'获取access_token方法

Sub 获取access_token()
    Debug.Print GetAccessToken("APIKey ", "SecretKey ")
End Sub










Function GetAccessToken(APIKey As String, SecretKey As String) As String
    Dim request As Object
    Dim response As String
    Dim url As String
    Dim payload As String
    Dim headers As Object
    
    ' 设置请求URL
    url = "https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=" & APIKey & "&client_secret=" & SecretKey
    
    ' 创建HTTP请求对象
    Set request = CreateObject("MSXML2.XMLHTTP")
    
    ' 构建请求参数
    payload = "{}"
    
    ' 设置请求头
    Set headers = CreateObject("Scripting.Dictionary")
    headers.Add "Content-Type", "application/json"
    headers.Add "Accept", "application/json"
    
    ' 发送POST请求
    With request
        .Open "POST", url, False
        For Each Header In headers
            .setRequestHeader Header, headers(Header)
        Next Header
        .send payload
        response = .responseText
    End With
    
    ' 解析响应结果,获取access_token
    GetAccessToken = ParseAccessToken(response)
End Function

Function ParseAccessToken(response As String) As String
    Dim sc As Object
    Dim json As Object
    Dim jsonResponse As String
    
    ' 创建ScriptControl对象
    Set sc = CreateObject("ScriptControl")
    sc.Language = "JScript"
    
    ' 解析JSON字符串
    sc.addcode "function getRs(){return json.access_token;}"
    sc.Eval "var json = " & response
    

    'MsgBox sc.Run("getRs")
    ' 获取access_token字段的值
    ParseAccessToken = sc.Run("getRs")
End Function


  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Excel_VBA创维大表格จุ๊บ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值