使用axios从打字稿中调用Salesforce Rest API

问题描述

我正在尝试使用由Salesforce和用户访问令牌提供的工具API从临时组织中获取记录。可以说

accesstoken = "abcd"
url = "https://example.my.salesforce.com/services/data/v49.0/tooling/query?q=SELECT+Id,Name+FROM+Account"

我已经使用axios节点模块进行如下所示的API调用

    const options = {
        headers: {
            "Authorization": "Bearer " + accesstoken,"Content-Type": "application/json"
        }
    };
    axios.get(url,options).then(response => {
        console.log(response.status);
        if(response.status == 200){
            console.log(response.data);
        } else {
            //do something else
        }
   });

该呼叫以状态200进行响应,即请求提供了响应。但是,我没有从Account对象获得正确的记录,而是获得了登录html页面

'登录| Salesforcehtml {可见度: 隐藏;} a {color:#0070d2;} body {background-color:#F4F6F9;}#content,.container {background-color:#ffffff;}#header {color:#16325c;} body {display: 表; width:100%;}#content {margin-bottom:24px;}#wrap {height:100%;} html {可见性:隐藏; } if(self == top) {document.documentElement.style.visibility ='visible';}其他 {document.write =''; top.location = self.location; setTimeout(function(){document.body.innerHTML ='';}, 1); window.self.onload = function(evt){document.body.innerHTML ='';};} var SFDCSessionVars = {“服务器”:“ https://test.salesforce.com/login/sessionserver212.html”,“ im”:true,“ ah”:“活动”,“保存”:“保存”,“ saveOne” :“保存 1更改”,“ sum”:“#p#已保存的用户名”,“ iaac”:false,“ hac”:“选择一个 用户名”,“ suo”:“ 1已保存的用户名”,“标题”:“ | Salesforce”,“ savemany”:“保存#p# 更改”,“ lpt”:“登录”,“ lllbl”:“闪电” 登录“,”主机“:” test.salesforce.com“,” le“:false,” heu“:”编辑用户名 列表“,” ic“:false,” lh“:false,” ur“:” https://business-data-8148-dev-ed.cs79.my.salesforce.com“,” hidp“:”日志 在“正在使用”,“ ih”:“无效”,“ dc”:“用户名删除”中。点击保存提交 更改。“}; LoginHint.hideLoginForm();编辑ListSaveCancel

用户名密码大写锁定已打开。 我
忘记了你 密码?要转到公司的登录

Custom Domainhttps:// domain .my.salesforce.comContinueBack使用其他登录登录用户名©2020 salesforce.com,inc。保留所有权利。

有人知道我在这里想念什么吗?根据Salesforce文档 https://developer.salesforce.com/docs/atlas.en-us.api_rest.meta/api_rest/dome_query.htm 标头中的accesstoken应该足以进行API调用

注意:我通过运行获得了访问令牌

sfdx force:user:display -u <username>

解决方法

  1. 您的查询是错误的。您选择了用于元数据(有关类,触发器,对象,字段,部署,正在运行的单元测试的信息)的Tooling API服务。如果您要查询帐户-这是正常数据。仅尝试/services/data/v49.0/query?q=SELECT+Id,Name+FROM+Account

enter image description here

  1. 我认为您不需要在其中使用Content-Type标头。您什么都不张贴。充其量您可以发送Acceptapplication/jsonapplication/xml

  2. 您确定会话ID有效吗?正如您可以进入组织,设置->会话管理,在那看到它吗?还是在用户的登录历史记录中?

  3. 可能是您的SF管理员做了一些令人讨厌的事情,例如将会话锁定到其起源的IP上,或者用户没有API访问权限...查看是否可以在{{3 }}->实用程序-> REST资源管理器,然后返回Axios?