當前位置: 首頁>>代碼示例>>PHP>>正文


PHP Zend_Crypt_Hmac::compute方法代碼示例

本文整理匯總了PHP中Zend_Crypt_Hmac::compute方法的典型用法代碼示例。如果您正苦於以下問題:PHP Zend_Crypt_Hmac::compute方法的具體用法?PHP Zend_Crypt_Hmac::compute怎麽用?PHP Zend_Crypt_Hmac::compute使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Zend_Crypt_Hmac的用法示例。


在下文中一共展示了Zend_Crypt_Hmac::compute方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: _signAuthenticate

 /**
  * @desc Authenticate using sha1 Merchant signature
  * @see success Action during checkout
  * @param Varien_Object $response
  */
 protected function _signAuthenticate(Varien_Object $response)
 {
     if ($this->_getConfigData('demoMode') === 'Y') {
         $secretWord = $this->_getConfigData('secret_wordt', 'adyen_hpp');
     } else {
         $secretWord = $this->_getConfigData('secret_wordp', 'adyen_hpp');
     }
     // do it like this because $_GET is converting dot to underscore
     $queryString = $_SERVER['QUERY_STRING'];
     $result = array();
     $pairs = explode("&", $queryString);
     foreach ($pairs as $pair) {
         $nv = explode("=", $pair);
         $name = urldecode($nv[0]);
         $value = urldecode($nv[1]);
         $result[$name] = $value;
     }
     // do not use merchantSig in calculation
     unset($result['merchantSig']);
     // Sort the array by key using SORT_STRING order
     ksort($result, SORT_STRING);
     $signData = implode(":", array_map(array($this, 'escapeString'), array_merge(array_keys($result), array_values($result))));
     $signMac = Zend_Crypt_Hmac::compute(pack("H*", $secretWord), 'sha256', $signData);
     $localStringToHash = base64_encode(pack('H*', $signMac));
     if (strcmp($localStringToHash, $response->getData('merchantSig')) === 0) {
         return true;
     }
     return false;
 }
開發者ID:LybeAB,項目名稱:magento,代碼行數:34,代碼來源:Authenticate.php

示例2: _generateHmacKey

 private static function _generateHmacKey($params = null, $apiKey = null)
 {
     $logger = self::getLoggerHandler();
     $signatureData = CitrusPay_RequestData::_generateSignatureData($params, $apiKey);
     $logger->info("Signature data is " . $signatureData);
     $hmackey = Zend_Crypt_Hmac::compute($apiKey, "sha1", $signatureData);
     $logger->info("Signature Key generated is " . $hmackey);
     return $hmackey;
 }
開發者ID:sagmahajan,項目名稱:aswan_release,代碼行數:9,代碼來源:CitrusPayApiResource.php

示例3: _generateAuthKey

 /**
  * Generate the mac key name. Must be the same function as used in the InsuranceFunctions.php
  *
  * @param string $requesthash Request hash of request
  */
 private function _generateAuthKey($requesthash)
 {
     $config = Zend_Registry::get('params');
     $secret = null;
     // Capture HMAC secret key
     if (isset($config->dms) && isset($config->dms->localcache) && isset($config->dms->localcache->hmacsecret)) {
         $secret = $config->dms->localcache->hmacsecret;
     }
     if ($secret == null) {
         throw new Exception('hmac secret not set');
     }
     return strtoupper(Zend_Crypt_Hmac::compute($secret, 'sha256', $requesthash));
 }
開發者ID:AlexEvesDeveloper,項目名稱:hl-stuff,代碼行數:18,代碼來源:IndexController.php

示例4: _signAuthenticate

 /**
  * @desc Authenticate using sha1 Merchant signature
  * @see success Action during checkout
  * @param Varien_Object $response
  */
 protected function _signAuthenticate(Varien_Object $response)
 {
     if ($this->_getConfigData('demoMode') === 'Y') {
         $secretWord = $this->_getConfigData('secret_wordt', 'adyen_hpp');
     } else {
         $secretWord = $this->_getConfigData('secret_wordp', 'adyen_hpp');
     }
     $sign = $response->getData('authResult') . $response->getData('pspReference') . $response->getData('merchantReference') . $response->getData('skinCode');
     $signMac = Zend_Crypt_Hmac::compute($secretWord, 'sha1', $sign);
     $localStringToHash = base64_encode(pack('H*', $signMac));
     if (strcmp($localStringToHash, $response->getData('merchantSig')) === 0) {
         return true;
     }
     return false;
 }
開發者ID:AmineCherrai,項目名稱:rostanvo,代碼行數:20,代碼來源:Authenticate.php

示例5: processCashResponse

 public function processCashResponse()
 {
     $response = $_REQUEST;
     $varienObj = new Varien_Object();
     foreach ($response as $code => $value) {
         if ($code == 'amount') {
             if (is_object($value)) {
                 $value = $value->value;
             }
             $code = 'value';
         }
         $varienObj->setData($code, $value);
     }
     $pspReference = $varienObj->getData('pspReference');
     $merchantReference = $varienObj->getData('merchantReference');
     $skinCode = $varienObj->getData('skinCode');
     $paymentAmount = $varienObj->getData('paymentAmount');
     $currencyCode = $varienObj->getData('currencyCode');
     $customPaymentMethod = $varienObj->getData('c_cash');
     $paymentMethod = $varienObj->getData('paymentMethod');
     $merchantSig = $varienObj->getData('merchantSig');
     $sign = $pspReference . $merchantReference . $skinCode . $paymentAmount . $currencyCode . $customPaymentMethod . $paymentMethod;
     $secretWord = $this->_getSecretWord();
     $signMac = Zend_Crypt_Hmac::compute($secretWord, 'sha1', $sign);
     $calMerchantSig = base64_encode(pack('H*', $signMac));
     // check if signatures are the same
     if ($calMerchantSig == $merchantSig) {
         //get order && payment objects
         $order = Mage::getModel('sales/order');
         //error
         $orderExist = $this->_incrementIdExist($varienObj, $merchantReference);
         if (empty($orderExist)) {
             $this->_writeLog("unknown order : {$merchantReference}");
         } else {
             $order->loadByIncrementId($merchantReference);
             $comment = Mage::helper('adyen')->__('Adyen Cash Result URL Notification: <br /> pspReference: %s <br /> paymentMethod: %s', $pspReference, $paymentMethod);
             $status = true;
             $history = Mage::getModel('sales/order_status_history')->setStatus($status)->setComment($comment)->setEntityName("order")->setOrder($order);
             $history->save();
             return $status;
         }
     }
     return false;
 }
開發者ID:Maikel-Koek,項目名稱:magento,代碼行數:44,代碼來源:Process.php

示例6: _signParameters

 /**
  * Computes the RFC 2104-compliant HMAC signature for request parameters
  *
  * This implements the Amazon Web Services signature, as per the following
  * specification:
  *
  * 1. Sort all request parameters (including <tt>SignatureVersion</tt> and
  *    excluding <tt>Signature</tt>, the value of which is being created),
  *    ignoring case.
  *
  * 2. Iterate over the sorted list and append the parameter name (in its
  *    original case) and then its value. Do not URL-encode the parameter
  *    values before constructing this string. Do not use any separator
  *    characters when appending strings.
  *
  * @param  string $queue_url  Queue URL
  * @param  array  $parameters the parameters for which to get the signature.
  *
  * @return string the signed data.
  */
 protected function _signParameters($url, array &$paramaters)
 {
     $data = '';
     uksort($paramaters, 'strcasecmp');
     unset($paramaters['Signature']);
     foreach ($paramaters as $key => $value) {
         $data .= $key . $value;
     }
     $hmac = Zend_Crypt_Hmac::compute($this->_secretKey, 'SHA1', $data, Zend_Crypt_Hmac::BINARY);
     $paramaters['Signature'] = base64_encode($hmac);
     return $data;
 }
開發者ID:schlypel,項目名稱:YiiBackboneBoilerplate,代碼行數:32,代碼來源:V1.php

示例7: _signS3UploadPolicy

 /**
  * Signed S3 Upload Policy
  *
  * @param string $policy            Base64 Encoded string that is the upload policy
  * @return string                   SHA1 encoded S3 Upload Policy
  */
 protected function _signS3UploadPolicy($policy)
 {
     $hmac = Zend_Crypt_Hmac::compute($this->_getSecretKey(), 'SHA1', $policy, Zend_Crypt_Hmac::BINARY);
     return $hmac;
 }
開發者ID:arendasistemasintegrados,項目名稱:mateusleme,代碼行數:11,代碼來源:Windows.php

示例8: _signParameters

 /**
  * Computes the RFC 2104-compliant HMAC signature for request parameters
  *
  * This implements the Amazon Web Services signature, as per the following
  * specification:
  *
  * 1. Sort all request parameters (including <tt>SignatureVersion</tt> and
  *    excluding <tt>Signature</tt>, the value of which is being created),
  *    ignoring case.
  *
  * 2. Iterate over the sorted list and append the parameter name (in its
  *    original case) and then its value. Do not URL-encode the parameter
  *    values before constructing this string. Do not use any separator
  *    characters when appending strings.
  *
  * @param array  $parameters the parameters for which to get the signature.
  * @param string $secretKey  the secret key to use to sign the parameters.
  *
  * @return string the signed data.
  */
 protected function _signParameters(array $paramaters)
 {
     $data = "POST\n";
     $data .= $this->getEndpoint()->getHost() . "\n";
     $data .= "/\n";
     uksort($paramaters, 'strcmp');
     unset($paramaters['Signature']);
     $arrData = array();
     foreach ($paramaters as $key => $value) {
         $value = urlencode($value);
         $value = str_replace("%7E", "~", $value);
         $value = str_replace("+", "%20", $value);
         $arrData[] = urlencode($key) . '=' . $value;
     }
     $data .= implode('&', $arrData);
     // require_once 'Zend/Crypt/Hmac.php';
     $hmac = Zend_Crypt_Hmac::compute($this->_getSecretKey(), 'SHA256', $data, Zend_Crypt_Hmac::BINARY);
     return base64_encode($hmac);
 }
開發者ID:JaroslavRamba,項目名稱:ex-facebook-bundle,代碼行數:39,代碼來源:SimpleDb.php

示例9: generateHmacKey

 public function generateHmacKey($data, $apiKey = null)
 {
     $hmackey = Zend_Crypt_Hmac::compute($apiKey, "sha1", $data);
     return $hmackey;
 }
開發者ID:sagmahajan,項目名稱:aswan_release,代碼行數:5,代碼來源:StandardController.php

示例10: processCashResponse

 public function processCashResponse()
 {
     $response = $_REQUEST;
     $varienObj = new Varien_Object();
     foreach ($response as $code => $value) {
         if ($code == 'amount') {
             if (is_object($value)) {
                 $value = $value->value;
             }
             $code = 'value';
         }
         $varienObj->setData($code, $value);
     }
     $pspReference = $varienObj->getData('pspReference');
     $merchantReference = $varienObj->getData('merchantReference');
     $skinCode = $varienObj->getData('skinCode');
     $paymentAmount = $varienObj->getData('paymentAmount');
     $currencyCode = $varienObj->getData('currencyCode');
     $customPaymentMethod = $varienObj->getData('c_cash');
     $paymentMethod = $varienObj->getData('paymentMethod');
     $merchantSig = $varienObj->getData('merchantSig');
     $sign = $pspReference . $merchantReference . $skinCode . $paymentAmount . $currencyCode . $customPaymentMethod . $paymentMethod;
     $secretWord = $this->_getSecretWord();
     $signMac = Zend_Crypt_Hmac::compute($secretWord, 'sha1', $sign);
     $calMerchantSig = base64_encode(pack('H*', $signMac));
     // check if signatures are the same
     if ($calMerchantSig == $merchantSig) {
         //get order && payment objects
         $order = Mage::getModel('sales/order');
         //error
         $orderExist = $this->_incrementIdExist($varienObj, $merchantReference);
         if (empty($orderExist)) {
             $this->_writeLog("unknown order : {$merchantReference}");
         } else {
             $order->loadByIncrementId($merchantReference);
             $comment = Mage::helper('adyen')->__('Adyen Cash Result URL Notification: <br /> pspReference: %s <br /> paymentMethod: %s', $pspReference, $paymentMethod);
             $status = true;
             $history = Mage::getModel('sales/order_status_history')->setStatus($status)->setComment($comment)->setEntityName("order")->setOrder($order);
             $history->save();
             if ($this->_getConfigData('cash_drawer', 'adyen_pos')) {
                 $printerIp = trim($this->_getConfigData('cash_drawer_printer_ip', 'adyen_pos'));
                 if ($printerIp != "") {
                     $drawCodeConfig = trim($this->_getConfigData('cash_drawer_code', 'adyen_pos'));
                     if ($drawCodeConfig != "") {
                         // split comm based
                         $drawCodes = explode(",", $drawCodeConfig);
                         // open the cash drawer
                         try {
                             $esc = "";
                             $fp = fsockopen($printerIp, 9100);
                             fwrite($fp, $esc . "@");
                             $write = "";
                             $count = 0;
                             foreach ($drawCodes as $drawCode) {
                                 // first code 27 must be special character to let it work
                                 if ($count == 0 && $drawCode == "27") {
                                     $write .= $esc;
                                 } else {
                                     $write .= chr($drawCode);
                                 }
                                 ++$count;
                             }
                             // example: fwrite($fp, $esc . chr(112) . chr(48) . chr(55) . chr(121));
                             fwrite($fp, $write);
                             // close connection
                             fclose($fp);
                         } catch (Exception $e) {
                             Mage::logException($e);
                             Mage::throwException($e->getMessage());
                         }
                     } else {
                         Mage::log("Cash drawer Code not filled in check your Adyen POS settings", Zend_Log::DEBUG, "adyen_notification.log", true);
                         Mage::throwException('Cash drawer Code not filled in check your Adyen POS settings');
                     }
                 } else {
                     Mage::log("Cash drawer Code not filled in check your Adyen POS settings", Zend_Log::DEBUG, "adyen_notification.log", true);
                     Mage::throwException('Cash drawer IP not filled in check your Adyen POS settings');
                 }
             }
             return $status;
         }
     }
     return false;
 }
開發者ID:AmineCherrai,項目名稱:rostanvo,代碼行數:84,代碼來源:Process.php

示例11: _signParameters

 /**
  * Computes the RFC 2104-compliant HMAC signature for request parameters
  *
  * This implements the Amazon Web Services signature, as per the following
  * specification:
  *
  * 1. Sort all request parameters (including <tt>SignatureVersion</tt> and
  *    excluding <tt>Signature</tt>, the value of which is being created),
  *    ignoring case.
  *
  * 2. Iterate over the sorted list and append the parameter name (in its
  *    original case) and then its value. Do not URL-encode the parameter
  *    values before constructing this string. Do not use any separator
  *    characters when appending strings.
  *
  * @param  string $queue_url  Queue URL
  * @param  array  $parameters the parameters for which to get the signature.
  *
  * @return string the signed data.
  */
 protected function _signParameters($url, array &$paramaters)
 {
     $data = $this->_httpMethod . "\n";
     $data .= parse_url($url, PHP_URL_HOST) . "\n";
     $data .= '' == ($path = parse_url($url, PHP_URL_PATH)) ? '/' : $path;
     $data .= "\n";
     uksort($paramaters, 'strcmp');
     unset($paramaters['Signature']);
     $arrData = array();
     foreach ($paramaters as $key => $value) {
         $arrData[] = $key . '=' . str_replace('%7E', '~', rawurlencode($value));
     }
     $data .= implode('&', $arrData);
     $hmac = Zend_Crypt_Hmac::compute($this->_secretKey, 'SHA256', $data, Zend_Crypt_Hmac::BINARY);
     $paramaters['Signature'] = base64_encode($hmac);
     return $data;
 }
開發者ID:yonetici,項目名稱:pimcore-coreshop-demo,代碼行數:37,代碼來源:V2.php

示例12: getOptionalFormFields

 public function getOptionalFormFields($adyFields, $order)
 {
     if (empty($order)) {
         return $adyFields;
     }
     $helper = Mage::helper('adyen');
     $secretWord = $this->_getSecretWord();
     $billingAddress = $order->getBillingAddress();
     $adyFields['shopper.firstName'] = $billingAddress->getFirstname();
     $adyFields['shopper.lastName'] = $billingAddress->getLastname();
     $adyFields['billingAddress.street'] = $helper->getStreet($billingAddress)->getName();
     $adyFields['billingAddress.houseNumberOrName'] = $helper->getStreet($billingAddress)->getHouseNumber();
     $adyFields['billingAddress.city'] = $billingAddress->getCity();
     $adyFields['billingAddress.postalCode'] = $billingAddress->getPostcode();
     $adyFields['billingAddress.stateOrProvince'] = $billingAddress->getRegionCode();
     $adyFields['billingAddress.country'] = $billingAddress->getCountryId();
     $sign = $adyFields['billingAddress.street'] . $adyFields['billingAddress.houseNumberOrName'] . $adyFields['billingAddress.city'] . $adyFields['billingAddress.postalCode'] . $adyFields['billingAddress.stateOrProvince'] . $adyFields['billingAddress.country'];
     //Generate HMAC encrypted merchant signature
     $signMac = Zend_Crypt_Hmac::compute($secretWord, 'sha1', $sign);
     $adyFields['billingAddressSig'] = base64_encode(pack('H*', $signMac));
     $deliveryAddress = $order->getShippingAddress();
     if ($deliveryAddress != null) {
         $adyFields['deliveryAddress.street'] = $helper->getStreet($deliveryAddress)->getName();
         $adyFields['deliveryAddress.houseNumberOrName'] = $helper->getStreet($deliveryAddress)->getHouseNumber();
         $adyFields['deliveryAddress.city'] = $deliveryAddress->getCity();
         $adyFields['deliveryAddress.postalCode'] = $deliveryAddress->getPostcode();
         $adyFields['deliveryAddress.stateOrProvince'] = $deliveryAddress->getRegionCode();
         $adyFields['deliveryAddress.country'] = $deliveryAddress->getCountryId();
         $sign = $adyFields['deliveryAddress.street'] . $adyFields['deliveryAddress.houseNumberOrName'] . $adyFields['deliveryAddress.city'] . $adyFields['deliveryAddress.postalCode'] . $adyFields['deliveryAddress.stateOrProvince'] . $adyFields['deliveryAddress.country'];
         //Generate HMAC encrypted merchant signature
         $secretWord = $this->_getSecretWord();
         $signMac = Zend_Crypt_Hmac::compute($secretWord, 'sha1', $sign);
         $adyFields['deliveryAddressSig'] = base64_encode(pack('H*', $signMac));
     }
     if ($adyFields['shopperReference'] != self::GUEST_ID . $order->getRealOrderId()) {
         $customer = Mage::getModel('customer/customer')->load($adyFields['shopperReference']);
         if ($this->getCustomerAttributeText($customer, 'gender') != "") {
             $adyFields['shopper.gender'] = strtoupper($this->getCustomerAttributeText($customer, 'gender'));
         } else {
             // fix for OneStepCheckout (guest is not logged in but uses email that exists with account)
             $_customer = Mage::getModel('customer/customer');
             if ($order->getCustomerGender()) {
                 $customerGender = $order->getCustomerGender();
             } else {
                 // this is still empty for OneStepCheckout so uses extra saved parameter
                 $payment = $order->getPayment();
                 $customerGender = $payment->getAdditionalInformation('customerGender');
             }
             $adyFields['shopper.gender'] = strtoupper($_customer->getResource()->getAttribute('gender')->getSource()->getOptionText($customerGender));
         }
         $adyFields['shopper.infix'] = $customer->getPrefix();
         $dob = $customer->getDob();
         if (!empty($dob)) {
             $adyFields['shopper.dateOfBirthDayOfMonth'] = $this->getDate($dob, 'd');
             $adyFields['shopper.dateOfBirthMonth'] = $this->getDate($dob, 'm');
             $adyFields['shopper.dateOfBirthYear'] = $this->getDate($dob, 'Y');
         } else {
             // fix for OneStepCheckout (guest is not logged in but uses email that exists with account)
             $dob = $order->getCustomerDob();
             if (!empty($dob)) {
                 $adyFields['shopper.dateOfBirthDayOfMonth'] = $this->getDate($dob, 'd');
                 $adyFields['shopper.dateOfBirthMonth'] = $this->getDate($dob, 'm');
                 $adyFields['shopper.dateOfBirthYear'] = $this->getDate($dob, 'Y');
             }
         }
     } else {
         // checkout as guest use details from the order
         $_customer = Mage::getModel('customer/customer');
         $adyFields['shopper.gender'] = strtoupper($_customer->getResource()->getAttribute('gender')->getSource()->getOptionText($order->getCustomerGender()));
         $adyFields['shopper.infix'] = $order->getCustomerPrefix();
         $dob = $order->getCustomerDob();
         if (!empty($dob)) {
             $adyFields['shopper.dateOfBirthDayOfMonth'] = $this->getDate($dob, 'd');
             $adyFields['shopper.dateOfBirthMonth'] = $this->getDate($dob, 'm');
             $adyFields['shopper.dateOfBirthYear'] = $this->getDate($dob, 'Y');
         }
     }
     // for sweden add here your socialSecurityNumber
     // $adyFields['shopper.socialSecurityNumber'] = "Result of your custom input field";
     $adyFields['shopper.telephoneNumber'] = $billingAddress->getTelephone();
     $openinvoiceType = $this->_getConfigData('openinvoicetypes', 'adyen_openinvoice');
     // get current payment method
     if ($order->getPayment()->getMethod() == "adyen_openinvoice" || $order->getPayment()->getMethodInstance()->getInfoInstance()->getCcType() == "klarna" || $order->getPayment()->getMethodInstance()->getInfoInstance()->getCcType() == "afterpay_default") {
         // initialize values if they are empty
         $adyFields['shopper.gender'] = isset($adyFields['shopper.gender']) ? $adyFields['shopper.gender'] : "";
         $adyFields['shopper.infix'] = isset($adyFields['shopper.infix']) ? $adyFields['shopper.infix'] : "";
         $adyFields['shopper.dateOfBirthDayOfMonth'] = isset($adyFields['shopper.dateOfBirthDayOfMonth']) ? $adyFields['shopper.dateOfBirthDayOfMonth'] : "";
         $adyFields['shopper.dateOfBirthMonth'] = isset($adyFields['shopper.dateOfBirthMonth']) ? $adyFields['shopper.dateOfBirthMonth'] : "";
         $adyFields['shopper.dateOfBirthYear'] = isset($adyFields['shopper.dateOfBirthYear']) ? $adyFields['shopper.dateOfBirthYear'] : "";
         $shoppperSign = $adyFields['shopper.firstName'] . $adyFields['shopper.infix'] . $adyFields['shopper.lastName'] . $adyFields['shopper.gender'] . $adyFields['shopper.dateOfBirthDayOfMonth'] . $adyFields['shopper.dateOfBirthMonth'] . $adyFields['shopper.dateOfBirthYear'] . $adyFields['shopper.telephoneNumber'];
         $shopperSignMac = Zend_Crypt_Hmac::compute($secretWord, 'sha1', $shoppperSign);
         $adyFields['shopperSig'] = base64_encode(pack('H*', $shopperSignMac));
     }
     $count = 0;
     $currency = $order->getOrderCurrencyCode();
     $additional_data_sign = array();
     foreach ($order->getItemsCollection() as $item) {
         //skip dummies
         if ($item->isDummy()) {
             continue;
//.........這裏部分代碼省略.........
開發者ID:raphaelpor,項目名稱:magento,代碼行數:101,代碼來源:Openinvoice.php

示例13: addSignature

 /**
  * Add the S3 Authorization signature to the request headers
  *
  * @param  string $method
  * @param  string $path
  * @param  array &$headers
  * @return string
  */
 protected function addSignature($method, $path, &$headers)
 {
     if (!is_array($headers)) {
         $headers = array($headers);
     }
     $type = $md5 = $date = '';
     // Search for the Content-type, Content-MD5 and Date headers
     foreach ($headers as $key => $val) {
         if (strcasecmp($key, 'content-type') == 0) {
             $type = $val;
         } else {
             if (strcasecmp($key, 'content-md5') == 0) {
                 $md5 = $val;
             } else {
                 if (strcasecmp($key, 'date') == 0) {
                     $date = $val;
                 }
             }
         }
     }
     // If we have an x-amz-date header, use that instead of the normal Date
     if (isset($headers['x-amz-date']) && isset($date)) {
         $date = '';
     }
     $sig_str = "{$method}\n{$md5}\n{$type}\n{$date}\n";
     // For x-amz- headers, combine like keys, lowercase them, sort them
     // alphabetically and remove excess spaces around values
     $amz_headers = array();
     foreach ($headers as $key => $val) {
         $key = strtolower($key);
         if (substr($key, 0, 6) == 'x-amz-') {
             if (is_array($val)) {
                 $amz_headers[$key] = $val;
             } else {
                 $amz_headers[$key][] = preg_replace('/\\s+/', ' ', $val);
             }
         }
     }
     if (!empty($amz_headers)) {
         ksort($amz_headers);
         foreach ($amz_headers as $key => $val) {
             $sig_str .= $key . ':' . implode(',', $val) . "\n";
         }
     }
     $sig_str .= '/' . parse_url($path, PHP_URL_PATH);
     if (strpos($path, '?location') !== false) {
         $sig_str .= '?location';
     } else {
         if (strpos($path, '?acl') !== false) {
             $sig_str .= '?acl';
         } else {
             if (strpos($path, '?torrent') !== false) {
                 $sig_str .= '?torrent';
             }
         }
     }
     $signature = base64_encode(Zend_Crypt_Hmac::compute($this->_getSecretKey(), 'sha1', utf8_encode($sig_str), Zend_Crypt_Hmac::BINARY));
     $headers['Authorization'] = 'AWS ' . $this->_getAccessKey() . ':' . $signature;
     return $sig_str;
 }
開發者ID:hirentricore,項目名稱:devmagento,代碼行數:68,代碼來源:S3.php

示例14: signParameters

 /**
  * Computes the RFC 2104-compliant HMAC signature for request parameters
  *
  * This implements the Amazon Web Services signature, as per the following
  * specification:
  *
  * 1. Sort all request parameters (including <tt>SignatureVersion</tt> and
  *    excluding <tt>Signature</tt>, the value of which is being created),
  *    ignoring case.
  *
  * 2. Iterate over the sorted list and append the parameter name (in its
  *    original case) and then its value. Do not URL-encode the parameter
  *    values before constructing this string. Do not use any separator
  *    characters when appending strings.
  *
  * @param array  $parameters the parameters for which to get the signature.
  * @param string $secretKey  the secret key to use to sign the parameters.
  *
  * @return string the signed data.
  */
 protected function signParameters(array $paramaters)
 {
     $data = '';
     uksort($paramaters, 'strcasecmp');
     unset($paramaters['Signature']);
     foreach ($paramaters as $key => $value) {
         $data .= $key . $value;
     }
     require_once 'Zend/Crypt/Hmac.php';
     $hmac = Zend_Crypt_Hmac::compute($this->getSecretKey(), 'SHA1', $data, Zend_Crypt_Hmac::BINARY);
     return base64_encode($hmac);
 }
開發者ID:jwhitcraft,項目名稱:zend_service_amazon_ec2,代碼行數:32,代碼來源:Abstract.php

示例15: testHmacRIPEMD160_7

 public function testHmacRIPEMD160_7()
 {
     $data = 'Test Using Larger Than Block-Size Key and Larger Than One Block-Size Data';
     $key = str_repeat("ª", 80);
     $hmac = Zend_Crypt_Hmac::compute($key, 'RIPEMD160', $data);
     $this->assertEquals('69ea60798d71616cce5fd0871e23754cd75d5a0a', $hmac);
 }
開發者ID:netvlies,項目名稱:zf,代碼行數:7,代碼來源:HmacTest.php


注:本文中的Zend_Crypt_Hmac::compute方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。