Magento에서 새로운 고객을 만들려고합니다. 여기에 내가 그Magento (RESTful, PHP)에서 신규 고객 만들기
<?php
$callbackUrl = "http://localhost/magento/webservices/NewCustomer1.php";
$temporaryCredentialsRequestUrl = "http://localhost/magento/oauth/initiate?oauth_callback=". urlencode($callbackUrl);
$adminAuthorizationUrl = 'http://localhost/magento/admin/oauth_authorize';
$accessTokenRequestUrl = 'http://localhost/magento/oauth/token';
$apiUrl = 'http://localhost/magento/api/rest';
$consumerKey = 's3xt7w8lwhfrrfzrfvwm3lrilkf66d5n';
$consumerSecret = 'vr3eq1x899pz1cf4zzxjzx3q03t66r3n';
session_start();
if (!isset($_GET['oauth_token']) && isset($_SESSION['state']) && $_SESSION['state'] == 1) {
$_SESSION['state'] = 0;
}
try {
$authType = ($_SESSION['state'] == 2) ? OAUTH_AUTH_TYPE_AUTHORIZATION : OAUTH_AUTH_TYPE_URI;
$oauthClient = new OAuth($consumerKey, $consumerSecret, OAUTH_SIG_METHOD_HMACSHA1, $authType);
$oauthClient->enableDebug();
if (!isset($_GET['oauth_token']) && !$_SESSION['state']) {
$requestToken = $oauthClient->getRequestToken($temporaryCredentialsRequestUrl);
$_SESSION['secret'] = $requestToken['oauth_token_secret'];
$_SESSION['state'] = 1;
header('Location: ' . $adminAuthorizationUrl . '?oauth_token=' . $requestToken['oauth_token']);
exit;
} else if ($_SESSION['state'] == 1) {
$oauthClient->setToken($_GET['oauth_token'], $_SESSION['secret']);
$accessToken = $oauthClient->getAccessToken($accessTokenRequestUrl);
$_SESSION['state'] = 2;
$_SESSION['token'] = $accessToken['oauth_token'];
$_SESSION['secret'] = $accessToken['oauth_token_secret'];
header('Location: ' . $callbackUrl);
exit;
} else {
$oauthClient->setToken($_SESSION['token'], $_SESSION['secret']);
$resourceUrl = "$apiUrl/customers/create";
$customerData = json_encode(array(
'firstname' => 'demofirstname',
'lastname' => 'demolastname',
'email_address' => '[email protected]',
'password' => 'demo1234',
'confirmation' => 'demo1234',
));
$headers = array('Content-Type' => 'application/json');
$oauthClient->fetch($resourceUrl, $customerData, OAUTH_HTTP_METHOD_POST, $headers);
print_r($oauthClient->getLastResponseInfo());
}
} catch (OAuthException $e) {
print_r($e);
}
?>
나는이 오류를 얻고 위해 쓴 PHP 스크립트입니다
OAuthException : 잘못된 인증/잘못된 요청 (있어 405, HTTP/1.1 20 배 또는 리디렉션 예상) C의를 : \ wamp \ www \ magento \ WebServices \ newcustomer1.php on line 47 호출 스택 #TimeMemoryFunctionLocation 10.0010386016 {주} ( ) .. \ newcustomer1.php : 0 20.0017391216OAuth-> fetch ( ) .. \ newcustomer1.php : 47)
Oauth와 PHP를 처음 사용합니다. 누군가가 도울 수 있다면 기쁠 것입니다. 주변에 라인 (36)
나머지 고객은 out oauth를 사용하여 추가 할 수 있습니까? – zamil
magento에 내장 된 REST API를 사용하고 있습니까? __no .__ 자신의 REST API를 롤아웃하거나 Inchoo_Api를 사용하는 경우 예/아마도. –
정보 주셔서 감사합니다. – zamil