使用php在netsuite中实现Oauth
我尝试使用PHP工具包通过帐户id、用户名和密码访问Netsuite。我可以使用上述凭证获取客户详细信息。我有通行证。但现在我尝试使用访问令牌访问Netsuite。我需要PHP代码来访问Netsuite使用令牌,我想得到客户的详细信息使用php在netsuite中实现Oauth,php,oauth,netsuite,Php,Oauth,Netsuite,我尝试使用PHP工具包通过帐户id、用户名和密码访问Netsuite。我可以使用上述凭证获取客户详细信息。我有通行证。但现在我尝试使用访问令牌访问Netsuite。我需要PHP代码来访问Netsuite使用令牌,我想得到客户的详细信息 提前感谢以下是我为使用RESTlet和OAuth的PHP->NS集成编写的一些代码: define("NETSUITE_URL", 'https://rest.netsuite.com/app/site/hosting/restlet.nl'); define("
提前感谢以下是我为使用RESTlet和OAuth的PHP->NS集成编写的一些代码:
define("NETSUITE_URL", 'https://rest.netsuite.com/app/site/hosting/restlet.nl');
define("NETSUITE_SCRIPT_ID", 'XXXXXX');
define("NETSUITE_DEPLOY_ID", 'XXXXXX');
define("NETSUITE_ACCOUNT", 'XXXXXX');
define("NETSUITE_CONSUMER_KEY", 'XXXXXX');
define("NETSUITE_CONSUMER_SECRET", 'XXXXXX');
define("NETSUITE_TOKEN_ID", 'XXXXXX');
define("NETSUITE_TOKEN_SECRET", 'XXXXXX');
function sendOrderToNS($details) {
$data_string = json_encode($details);
$oauth_nonce = md5(mt_rand());
$oauth_timestamp = time();
$oauth_signature_method = 'HMAC-SHA1';
$oauth_version = "1.0";
$base_string =
"POST&" . urlencode(NETSUITE_URL) . "&" .
urlencode(
"deploy=" . NETSUITE_DEPLOY_ID
. "&oauth_consumer_key=" . NETSUITE_CONSUMER_KEY
. "&oauth_nonce=" . $oauth_nonce
. "&oauth_signature_method=" . $oauth_signature_method
. "&oauth_timestamp=" . $oauth_timestamp
. "&oauth_token=" . NETSUITE_TOKEN_ID
. "&oauth_version=" . $oauth_version
. "&realm=" . NETSUITE_ACCOUNT
. "&script=" . NETSUITE_SCRIPT_ID
);
$sig_string = urlencode(NETSUITE_CONSUMER_SECRET) . '&' . urlencode(NETSUITE_TOKEN_SECRET);
$signature = base64_encode(hash_hmac("sha1", $base_string, $sig_string, true));
$auth_header = "OAuth "
. 'oauth_signature="' . rawurlencode($signature) . '", '
. 'oauth_version="' . rawurlencode($oauth_version) . '", '
. 'oauth_nonce="' . rawurlencode($oauth_nonce) . '", '
. 'oauth_signature_method="' . rawurlencode($oauth_signature_method) . '", '
. 'oauth_consumer_key="' . rawurlencode(NETSUITE_CONSUMER_KEY) . '", '
. 'oauth_token="' . rawurlencode(NETSUITE_TOKEN_ID) . '", '
. 'oauth_timestamp="' . rawurlencode($oauth_timestamp) . '", '
. 'realm="' . rawurlencode(NETSUITE_ACCOUNT) .'"';
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, NETSUITE_URL . '?&script=' . NETSUITE_SCRIPT_ID . '&deploy=' . NETSUITE_DEPLOY_ID . '&realm=' . NETSUITE_ACCOUNT);
curl_setopt($ch, CURLOPT_POST, "POST");
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
'Authorization: ' . $auth_header,
'Content-Type: application/json',
'Content-Length: ' . strlen($data_string)
]);
curl_exec($ch);
curl_close($ch);
}
我想评论一下,但现在还不能。michoel的回答是正确的,但当'realm=…'是$auth_头变量的一部分时,抛出了“无效登录尝试”错误。去掉该字符串可消除该问题 Netsuite TBA RESTlet在2021.1版本中将不再支持SHA1,您必须将PHP代码更改为 从$oauth_签名_方法='HMAC-SHA1';至$oauth_签名_方法='HMAC-SHA256'; 和 from$signature=base64_encode(hash_hmac(“sha1”),$base_string,$sig_string,true));to$signature=base64_encode(hash_hmac(“sha256”),$base_string,$sig_string,true))
这太宽泛了,请发布您使用过的代码、遇到的问题/错误等。我有代码可以使用凭据而不是Oauth访问Netsuite。我只需要使用Oauth的代码。谢谢你的回复。您的答案是帮助继续下一步。我尝试了使用Netsuite脚本获取客户详细信息的代码。但是我从OAuth得到了一个空的响应。这样,我们需要为每个独立的Netsuite帐户创建一个脚本。是否有任何可能的方法可以在不在Netsuite帐户中创建脚本的情况下获取客户详细信息?非常感谢michoel。您的代码工作正常。我在传递数据时犯了错误。我错误地将数据作为字符串发送。我只添加了这两行$数据字符串=数组('recordtype'=>'customer','id'=>'5');sendOrderToNS($datastring);有没有什么方法可以不在Netsuite帐户中创建脚本而获取客户详细信息?很好的示例,谢谢。不要忘记
curl\u close($ch)代码>。对于TBA新手,请务必注意。$auth_头的顺序非常重要<代码>OAuth规范要求按字母顺序排序,这是许多库的默认字母顺序排序。
此处相同。OAuth规范说不包括领域
。我必须删除它才能让它工作(在我的例子中是用Delphi而不是PHP)。@Brian你对get请求做了什么?
define("NETSUITE_URL", 'https://rest.netsuite.com/app/site/hosting/restlet.nl');
define("NETSUITE_SCRIPT_ID", 'XXXXXX');
define("NETSUITE_DEPLOY_ID", 'XXXXXX');
define("NETSUITE_ACCOUNT", 'XXXXXX');
define("NETSUITE_CONSUMER_KEY", 'XXXXXX');
define("NETSUITE_CONSUMER_SECRET", 'XXXXXX');
define("NETSUITE_TOKEN_ID", 'XXXXXX');
define("NETSUITE_TOKEN_SECRET", 'XXXXXX');
function sendOrderToNS($details) {
$data_string = json_encode($details);
$oauth_nonce = md5(mt_rand());
$oauth_timestamp = time();
$oauth_signature_method = 'HMAC-SHA256';
$oauth_version = "1.0";
$base_string =
"POST&" . urlencode(NETSUITE_URL) . "&" .
urlencode(
"deploy=" . NETSUITE_DEPLOY_ID
. "&oauth_consumer_key=" . NETSUITE_CONSUMER_KEY
. "&oauth_nonce=" . $oauth_nonce
. "&oauth_signature_method=" . $oauth_signature_method
. "&oauth_timestamp=" . $oauth_timestamp
. "&oauth_token=" . NETSUITE_TOKEN_ID
. "&oauth_version=" . $oauth_version
. "&realm=" . NETSUITE_ACCOUNT
. "&script=" . NETSUITE_SCRIPT_ID
);
$sig_string = urlencode(NETSUITE_CONSUMER_SECRET) . '&' . urlencode(NETSUITE_TOKEN_SECRET);
$signature = base64_encode(hash_hmac("sha256", $base_string, $sig_string, true));
$auth_header = "OAuth "
. 'oauth_signature="' . rawurlencode($signature) . '", '
. 'oauth_version="' . rawurlencode($oauth_version) . '", '
. 'oauth_nonce="' . rawurlencode($oauth_nonce) . '", '
. 'oauth_signature_method="' . rawurlencode($oauth_signature_method) . '", '
. 'oauth_consumer_key="' . rawurlencode(NETSUITE_CONSUMER_KEY) . '", '
. 'oauth_token="' . rawurlencode(NETSUITE_TOKEN_ID) . '", '
. 'oauth_timestamp="' . rawurlencode($oauth_timestamp) . '", '
. 'realm="' . rawurlencode(NETSUITE_ACCOUNT) .'"';
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, NETSUITE_URL . '?&script=' . NETSUITE_SCRIPT_ID . '&deploy=' . NETSUITE_DEPLOY_ID . '&realm=' . NETSUITE_ACCOUNT);
curl_setopt($ch, CURLOPT_POST, "POST");
curl_setopt($ch, CURLOPT_POSTFIELDS, $data_string);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);
curl_setopt($ch, CURLOPT_HTTPHEADER, [
'Authorization: ' . $auth_header,
'Content-Type: application/json',
'Content-Length: ' . strlen($data_string)
]);
curl_exec($ch);
curl_close($ch);
}