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


PHP String::hash方法代碼示例

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


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

示例1: generate

 /**
  * Generate hashed and salted token from `'prefix'` and `md5` hashed `$email` value
  * @param $email string User email that will be used as base for secret token
  * @param array $options Supported options:
  *        - `'prefix'` _string|int_ If not passed this method will generate random int from
  *          `100000` to `999999`. Hashed email will be prefixed with value of this option.
  *          Example: `'prefix_value' . md5($email)`
  *        - All other options are same as `lithium\util\String::hash()`
  * @return string Hashed prefixed email salted and hashed again
  * @see lithium\util\String::hash()
  */
 public static function generate($email, array $options = array())
 {
     $options += array('prefix' => null, 'salt' => LI3_UM_TokenSalt, 'type' => 'sha256');
     $prefix = $options['prefix'] ? $options['prefix'] : mt_rand(100000, 999999);
     unset($options['prefix']);
     return String::hash($prefix . md5($email), $options);
 }
開發者ID:djordje,項目名稱:li3_usermanager,代碼行數:18,代碼來源:Token.php

示例2: RemoveFriend

 public function RemoveFriend($hashuser_id, $user_id, $username)
 {
     if (String::hash($user_id) == $hashuser_id) {
         $user = Session::read('default');
         $id = $user['_id'];
         $details = Details::find('first', array('conditions' => array('user_id' => $id)));
         $friends = $details['Friend'];
         $addfriend = array();
         if (count($friends) != 0) {
             foreach ($friends as $ra) {
                 if ($ra != $username) {
                     array_push($addfriend, $ra);
                 }
             }
         }
         $data = array('Friend' => $addfriend);
         //			print_r($data);
         $details = Details::find('first', array('conditions' => array('user_id' => $id)))->save($data);
     }
     $this->redirect(array('controller' => 'ex', 'action' => "dashboard/", 'locale' => $locale));
 }
開發者ID:nilamdoc,項目名稱:msx,代碼行數:21,代碼來源:ExController.php

示例3: function

        return false;
    }
});
Validator::add('uniqueUsername', function ($value, $rule, $options) {
    $conflicts = Users::count(array('username' => $value));
    if ($conflicts) {
        return false;
    }
    return true;
});
Validator::add('uniqueEmail', function ($value, $rule, $options) {
    $conflicts = Users::count(array('email' => $value));
    if ($conflicts) {
        return false;
    }
    return true;
});
Users::applyFilter('save', function ($self, $params, $chain) {
    if ($params['data']) {
        $params['entity']->set($params['data']);
        $params['data'] = array();
    }
    if (!$params['entity']->exists()) {
        $params['entity']->password = String::hash($params['entity']->password);
        $params['entity']->password2 = String::hash($params['entity']->password2);
        $params['entity']->created = new \MongoDate();
        $params['entity']->updated = new \MongoDate();
        $params['entity']->ip = $_SERVER['REMOTE_ADDR'];
    }
    return $chain->next($self, $params, $chain);
});
開發者ID:nilamdoc,項目名稱:OxOPDF,代碼行數:31,代碼來源:Users.php

示例4:

								<tr>
									<td style="height:305px ">
									You have already made a withdrawal request for <strong><?php 
    echo number_format($transactions['Amount'], 8);
    ?>
 <?php 
    echo $transactions['Currency'];
    ?>
</strong> . Please check your email and complete the request. If you want to cancel the request, please send an email to <a href="mailto:support@SiiCrypto.com" >support@SiiCrypto.com</a>
									If your want to delete this request yourself, you can click on the link below:
									</td>
								</tr>
								<tr>
									<td>
										<strong><a href="/Users/removetransaction/<?php 
    echo String::hash($transactions['_id']);
    ?>
/<?php 
    echo $transactions['_id'];
    ?>
/funding/<?php 
    echo $transactions['Currency'];
    ?>
">REMOVE <i class="fa fa-remove"></i> <?php 
    echo number_format($transactions['Amount'], 8);
    ?>
 <?php 
    echo $transactions['Currency'];
    ?>
</a></strong>
									</td>
開發者ID:nilamdoc,項目名稱:msx,代碼行數:31,代碼來源:funding.html.php

示例5: removetransaction

 public function removetransaction($TransactionID, $ID, $url, $currency)
 {
     $Transaction = Transactions::find('first', array('conditions' => array('_id' => new MongoID($ID))));
     if (String::hash($Transaction['_id']) == $TransactionID) {
         $Remove = Transactions::remove(array('_id' => new MongoID($ID)));
     }
     return $this->redirect('/Users/' . $url . '/' . $currency);
 }
開發者ID:nilamdoc,項目名稱:msx,代碼行數:8,代碼來源:UsersController.php

示例6:

			<table class="table table-condensed table-bordered table-hover" style="font-size:14px">
				<thead>
					<tr>
						<th style="text-align:center ">Exchange</th>
						<th style="text-align:center ">Price</th>
						<th style="text-align:center ">Amount</th>
					</tr>
				</thead>
				<tbody>
				<?php 
foreach ($YourOrders as $YO) {
    ?>
					<tr>
							<td style="text-align:left ">
							<a href="/ex/RemoveOrder/<?php 
    echo String::hash($YO['_id']);
    ?>
/<?php 
    echo $YO['_id'];
    ?>
/<?php 
    echo $sel_curr;
    ?>
" title="Remove this order"><i class="fa fa-times"></i></a> &nbsp; 
							<?php 
    echo $YO['Action'];
    ?>
 <?php 
    echo $YO['FirstCurrency'];
    ?>
/<?php 
開發者ID:nilamdoc,項目名稱:msx,代碼行數:31,代碼來源:YourOrders.html.php

示例7: _runAssets

 /**
  * Method used to determine if an asset needs to be cached or timestamped.
  * Makes appropriate calls based on this.
  * @param  array  $files   [description]
  * @param  array  $options [description]
  * @return [type]          [description]
  */
 private function _runAssets(array $files = array(), array $options = array())
 {
     $this->styles = new AssetCollection();
     $this->scripts = new AssetCollection();
     if ($this->_config['compress'] or $this->_production) {
         $this->styles->ensureFilter(new Yui\CssCompressorFilter(YUI_COMPRESSOR));
         $this->scripts->ensureFilter(new Yui\JsCompressorFilter(YUI_COMPRESSOR));
     }
     $filename = "";
     // will store concatenated filename
     $stats = array('modified' => 0, 'size' => 0);
     // stores merged file stats
     // request type
     $type = $options['type'] == 'css' ? 'styles' : 'scripts';
     // loop over the sheets that were passed and run them thru Assetic
     foreach ($files as $file) {
         $_filename = $file;
         $path = $options['path'];
         // build filename if not a less file
         if ($isSpecial = $this->specialExt($file) or preg_match("/(.css|.js)\$/is", $file)) {
             $path .= $file;
         } else {
             $path .= "{$file}.{$options['type']}";
             $_filename = "{$file}.{$options['type']}";
         }
         // ensure file exists, if so set stats
         if (file_exists($path)) {
             $_stat = stat($path);
             $stats['modified'] += $_stat['mtime'];
             $stats['size'] += $_stat['size'];
             $stats[$path]['modified'] = $_stat['mtime'];
             $stats[$path]['size'] = $_stat['size'];
         } else {
             throw new RuntimeException("The {$options['type']} file '{$path}' does not exist");
         }
         $filters = array();
         // its a less or coffee file
         if ($isSpecial) {
             $path = $options['path'] . $file;
             $filters += $options['filters'];
         } else {
             // If we're not in production and we're not compressingthen we
             // dont need to cache static css assets
             if (!$this->_production and !$this->_config['compress']) {
                 $method = substr($type, 0, -1);
                 echo $this->_context->helper('html')->{$method}("{$_filename}?{$stats[$path]['modified']}") . "\n\t";
                 continue;
             }
         }
         $filename .= $path;
         // add asset to assetic collection
         $this->{$type}->add(new FileAsset($path, $filters));
     }
     // If in production merge files and server up a single stylesheet
     if ($this->_production) {
         // Hashed filename without stats appended.
         $_rawFilename = String::hash($filename, array('type' => 'sha1'));
         echo $this->buildHelper($_rawFilename, $this->{$type}, array('type' => $options['type'], 'stats' => $stats));
     } else {
         // not production so lets serve up individual files (better debugging)
         foreach ($this->{$type} as $leaf) {
             $filename = "{$leaf->getSourceRoot()}/{$leaf->getSourcePath()}";
             $_rawFilename = String::hash($filename, array('type' => 'sha1'));
             $stat = isset($stats[$filename]) ? $stats[$filename] : false;
             if ($stat) {
                 echo $this->buildHelper($_rawFilename, $leaf, array('type' => $options['type'], 'stats' => $stat));
             }
         }
     }
 }
開發者ID:joseym,項目名稱:li3_frontender,代碼行數:77,代碼來源:Assets.php

示例8: testHash

 /**
  * Tests hash generation using `String::hash()`.
  * @return string
  */
 public function testHash()
 {
     $salt = 'Salt and pepper';
     $value = 'Lithium rocks!';
     $expected = sha1($value);
     $result = String::hash($value, array('type' => 'sha1'));
     $this->assertEqual($expected, $result);
     $result = String::hash($value, array('type' => 'sha1') + compact('salt'));
     $this->assertEqual(sha1($salt . $value), $result);
     $this->assertEqual(md5($value), String::hash($value, array('type' => 'md5')));
     $result = String::hash($value, array('type' => 'md5') + compact('salt'));
     $this->assertEqual(md5($salt . $value), $result);
     $sha256 = function ($value) {
         if (function_exists('mhash')) {
             return bin2hex(mhash(MHASH_SHA256, $value));
         } elseif (function_exists('hash')) {
             return hash('sha256', $value);
         }
         throw new Exception();
     };
     try {
         $result = String::hash($value, array('type' => 'sha256'));
         $this->assertEqual($sha256($value), $result);
         $result = String::hash($value, array('type' => 'sha256') + compact('salt'));
         $this->assertEqual($sha256($salt . $value), $result);
     } catch (Exception $e) {
     }
     $string = 'Hash Me';
     $key = 'a very valid key';
     $salt = 'not too much';
     $type = 'sha256';
     $expected = '24f8664f7a7e56f85bd5c983634aaa0b0d3b0e470d7f63494475729cb8b3c6a4ef28398d7cf3';
     $expected .= '780c0caec26c85b56a409920e4af7eef38597861d49fbe31b9a0';
     $result = String::hash($string, compact('key'));
     $this->assertEqual($expected, $result);
     $expected = '35bc1d9a3332e524962909b7ccff6b34ae143f64c48ffa32b5be9312719a96369fbd7ebf6f49';
     $expected .= '09b375135b34e28b063a07b5bd62af165483c6b80dd48a252ddd';
     $result = String::hash($string, compact('salt'));
     $this->assertEqual($expected, $result);
     $expected = 'fa4cfa5c16d7f94e221e1d3a0cb01eadfd6823d68497a5fdcae023d24f557e4a';
     $result = String::hash($string, compact('type', 'key'));
     $this->assertEqual($expected, $result);
     $expected = 'a9050b4f44797bf60262de984ca12967711389cd6c4c4aeee2a739c159f1f667';
     $result = String::hash($string, compact('type'));
     $this->assertEqual($expected, $result);
 }
開發者ID:newmight2015,項目名稱:Blockchain-2,代碼行數:50,代碼來源:StringTest.php

示例9: function

}
Validator::add('passwordVerification', function ($value, $rule, $options) {
    if (!isset($options['values']['password2']) || $value == $options['values']['password2']) {
        return true;
    }
    return false;
});
Validator::add('uniqueUsername', function ($value, $rule, $options) {
    $conflicts = Users::count(array('username' => $value));
    if ($conflicts) {
        return false;
    }
    return true;
});
Users::applyFilter('save', function ($self, $params, $chain) {
    $entity = $params['entity'];
    $data = $params['data'];
    if ($data) {
        $entity->set($data);
        if (isset($data['password']) && $data['password'] && isset($data['password2']) && $data['password2']) {
            $entity->password = \lithium\util\String::hash($data['password']);
            $entity->password2 = \lithium\util\String::hash($data['password2']);
        }
    }
    if (!$entity->id) {
        $entity->created = new \MongoDate();
    }
    $entity->updated = new \MongoDate();
    $params['entity'] = $entity;
    return $chain->next($self, $params, $chain);
});
開發者ID:nilamdoc,項目名稱:TimeRig,代碼行數:31,代碼來源:Users.php

示例10: array

<?php

namespace app\models;

class Authors extends \lithium\data\Model
{
    public $hasMany = array('Books');
    public $validates = array('email' => array(array('notEmpty', 'message' => 'You must type a valid email address')), 'password' => array(array('notEmpty', 'message' => 'You must type a password')));
}
Authors::applyFilter('save', function ($self, $params, $chain) {
    if (!$params['entity']->id && !empty($params['entity']->password)) {
        $params['entity']->password = \lithium\util\String::hash($params['entity']->password);
    }
    return $chain->next($self, $params, $chain);
});
開發者ID:nicolasramy,項目名稱:Book-Community,代碼行數:15,代碼來源:Authors.php

示例11: update

    /**
     * Generic update() action.
     * The trick here is that $this->calling_class and $this->calling_method will hold a string
     * reference for which extended class called this update() method. We need that in order to
     * get the proper records and access.
    */
    public function update() {
        // get the "_type" ... page_type, user_type, or block_type
        $model = Inflector::classify(Inflector::singularize($this->request->params['controller']));
        $modelClass = 'minerva\models\\'.$model;
        $x_type = strtolower($model) . '_type';
        
        // Use the pretty URL if provided
		if(isset($this->request->params['url'])) {
			$conditions = array('url' => $this->request->params['url']);
		}
		
        // ...But if the id was provided, use that (for example; UsersController will be using the id)
		if(isset($this->request->params['id'])) {
			$conditions = array('_id' => $this->request->params['id']);
		}
        
        // or set it to "all" if there is no *_type in the record (this part differs from create() because the type won't come from the route)
        $type = $modelClass::find('first', array('conditions' => $conditions, 'fields' => array($x_type)))->$x_type;
        $type = (!empty($type)) ? $type:'all';
        
        // Get the model class we should be using for this (it could be an extended class from a library)
        
        $modelClass = $modelClass::getMinervaModel($model, $type);
        
		// Get the name for the page, so if another type library uses the "admin" (core) templates for this action, it will be shown
		$display_name = $modelClass::display_name();
		
		// Get the fields so the view template can build the form
		$fields = $modelClass::schema();
		// Don't need to have these fields in the form
		unset($fields['_id']);
        if($this->request->params['controller'] == 'users') {
            unset($fields['password']);
            // unset password and add a "new_password" field for UsersController
            $fields['new_password'] = null;
        }
		// If a *_type was passed in the params (and wasn't "all") we'll need it to save to the page document.
		$fields[$x_type]['form']['value'] = ($type != 'all') ? $type:null;
		
		// Get the document
		$document = $this->getDocument(array('action' => $this->calling_method, 'request' => $this->request, 'find_type' => 'first', 'conditions' => $conditions));
        
        // Update the record
		if ($this->request->data) {
			// Set some data
            $this->request->data['modified'] = date('Y-m-d h:i:s');
            
            // (note: the password stuff is only useful for UsersController)
            if($this->request->params['controller'] == 'users') {
                if(isset($this->request->data['password'])) {
                    unset($this->request->data['password']);
                }
                if((isset($this->request->data['new_password'])) && (!empty($this->request->data['new_password']))) {
                    $this->request->data['password'] = String::hash($this->request->data['new_password']);
                    unset($this->request->data['new_password']);
                }
            }
			
            // Save it
			if($document->save($this->request->data)) {
                FlashMessage::set('The content has been updated successfully.', array('options' => array('type' => 'success', 'pnotify_title' => 'Success', 'pnotify_opacity' => .8)));
                $this->redirect(array('controller' => $this->request->params['controller'], 'action' => 'index'));
			} else {
                FlashMessage::set('The content could not be updated, please try again.', array('options' => array('type' => 'error', 'pnotify_title' => 'Error', 'pnotify_opacity' => .8)));
            }
		}
	    
	    $this->set(compact('document', 'fields', 'display_name'));
    }
開發者ID:nateabele,項目名稱:Minerva-Plugin,代碼行數:75,代碼來源:MinervaController.php

示例12: password

 public function password()
 {
     if ($this->request->data) {
         if (stristr($_SERVER['HTTP_REFERER'], COMPANY_URL) === FALSE) {
             return $this->redirect('/login');
             exit;
         }
         $details = Details::find('first', array('conditions' => array('key' => $this->request->data['key']), 'fields' => array('user_id')));
         $msg = "Password Not Changed!";
         //			print_r($details['user_id']);
         if ($details['user_id'] != "") {
             if ($this->request->data['password'] == $this->request->data['password2']) {
                 //					print_r($this->request->data['password']);
                 $user = Users::find('first', array('conditions' => array('_id' => $details['user_id'])));
                 //					print_r($user['password']);
                 if ($user['password'] != String::hash($this->request->data['password'])) {
                     print_r($details['user_id']);
                     $data = array('password' => String::hash($this->request->data['password']));
                     //							print_r($data);
                     $user = Users::find('all', array('conditions' => array('_id' => $details['user_id'])))->save($data, array('validate' => false));
                     //		print_r($user);
                     if ($user) {
                         $msg = "Password changed!";
                     }
                 } else {
                     $msg = "Password same as old password!";
                 }
             } else {
                 $msg = "New password does not match!";
             }
         }
     }
     return compact('msg');
 }
開發者ID:nilamdoc,項目名稱:OxOPDF,代碼行數:34,代碼來源:UsersController.php

示例13:

		
		// Set created, modified, and pretty url (slug)
		if (!$params['entity']->exists()) {
			if(Validator::rule('moreThanFive', $params['data']['password']) === true) {
				$params['data']['password'] = String::hash($params['data']['password']); // will be sha512
			}
			// Unique E-mail validation ONLY upon new record creation
			if(Validator::rule('uniqueEmail', $params['data']['email']) === false) {
				$params['data']['email'] = ''; 
			}
			
		} else {
			// If the fields password and password_confirm both exist, then validate the password field too
			if((isset($params['data']['password'])) && (isset($params['data']['password_confirm']))) {
				if(Validator::rule('moreThanFive', $params['data']['password']) === true) {
					$params['data']['password'] = String::hash($params['data']['password']); // will be sha512
				}
			}
			
			// If the new_email field was passed, the user is requesting to update their e-mail, we will set it and send an email to allow them to confirm, once confirmed it will be changed
			if(isset($params['data']['new_email'])) {
				// Unique E-mail validation
				if((Validator::rule('uniqueEmail', $params['data']['new_email']) === false) || (Validator::isEmail($params['data']['new_email']) === false)) {
					// Invalidate
					$params['data']['new_email'] = '';
				} else {
					$params['data']['approval_code'] = Util::unique_string(array('hash' => 'md5'));
					Email::changeUserEmail(array('first_name' => $params['data']['first_name'], 'last_name' => $params['data']['last_name'], 'to' => $params['data']['new_email'], 'approval_code' => $params['data']['approval_code']));
				}
			}
		}
開發者ID:nateabele,項目名稱:Minerva-Plugin,代碼行數:30,代碼來源:User.php

示例14: YourOrders

    public function YourOrders($FirstCurrency = "BTC", $SecondCurrency = "USD", $user_id = null)
    {
        $YourOrders = Orders::find('all', array('conditions' => array('user_id' => $user_id, 'Completed' => 'N', 'FirstCurrency' => $FirstCurrency, 'SecondCurrency' => $SecondCurrency), 'order' => array('DateTime' => -1)));
        $YourCompleteOrders = Orders::find('all', array('conditions' => array('user_id' => $user_id, 'Completed' => 'Y', 'FirstCurrency' => $FirstCurrency, 'SecondCurrency' => $SecondCurrency), 'order' => array('DateTime' => -1)));
        $YourOrdersHTML = '<table class="table table-condensed table-bordered table-hover" style="font-size:11px">
				<thead>
					<tr>
						<th style="text-align:center ">Exchange</th>
						<th style="text-align:center ">Price</th>
						<th style="text-align:center ">Amount</th>
					</tr>
				</thead>
				<tbody>';
        foreach ($YourOrders as $YO) {
            $YourOrdersHTML = $YourOrdersHTML . '<tr>
							<td style="text-align:left ">
							<a href="/ex/RemoveOrder/' . String::hash($YO['_id']) . '/' . $YO['_id'] . '/' . strtolower($FirstCurrency) . '_' . strtolower($SecondCurrency) . '" title="Remove this order">
								<i class="fa fa-times"></i></a> &nbsp; 
							' . $YO['Action'] . ' ' . $YO['FirstCurrency'] . '/' . $YO['SecondCurrency'] . '</td>
						<td style="text-align:right ">' . number_format($YO['PerPrice'], 3) . '...</td>
						<td style="text-align:right ">' . number_format($YO['Amount'], 3) . '...</td>
					</tr>';
        }
        $YourOrdersHTML = $YourOrdersHTML . '				</tbody>
			</table>';
        $YourCompleteOrdersHTML = '<table class="table table-condensed table-bordered table-hover" style="font-size:11px">
				<thead>
					<tr>
						<th style="text-align:center ">Exchange</th>
						<th style="text-align:center ">Price</th>
						<th style="text-align:center ">Amount</th>
					</tr>
				</thead>
				<tbody>';
        foreach ($YourCompleteOrders as $YO) {
            $YourCompleteOrdersHTML = $YourCompleteOrdersHTML . '<tr style="cursor:pointer" class=" tooltip-x" rel="tooltip-x" data-placement="top" title="' . $YO['Action'] . ' ' . number_format($YO['Amount'], 3) . ' at ' . number_format($YO['PerPrice'], 8) . ' on ' . gmdate('Y-m-d H:i:s', $YO['DateTime']->sec) . '">
						<td style="text-align:left ">
						' . $YO['Action'] . ' ' . $YO['FirstCurrency'] . '/' . $YO['SecondCurrency'] . '</td>
						<td style="text-align:right ">' . number_format($YO['PerPrice'], 3) . '...</td>
						<td style="text-align:right ">' . number_format($YO['Amount'], 3) . '...</td>
					</tr>';
        }
        $YourCompleteOrdersHTML = $YourCompleteOrdersHTML . '				</tbody>
			</table>';
        return $this->render(array('json' => array('YourCompleteOrdersHTML' => $YourCompleteOrdersHTML, 'YourOrdersHTML' => $YourOrdersHTML)));
    }
開發者ID:nilamdoc,項目名稱:msx,代碼行數:46,代碼來源:UpdatesController.php

示例15: testHash

 /**
  * testHash method - Tests hash generation using `util\String::hash()`
  *
  * @return void
  */
 public function testHash()
 {
     $salt = 'Salt and pepper';
     $value = 'Lithium rocks!';
     $expected = sha1($value);
     $result = String::hash($value, 'sha1');
     $this->assertEqual($expected, $result);
     $result = String::hash($value);
     $this->assertEqual($expected, $result);
     $expected = sha1($salt . $value);
     $result = String::hash($value, 'sha1', $salt);
     $this->assertEqual($expected, $result);
     $expected = md5($value);
     $result = String::hash($value, 'md5');
     $this->assertEqual($expected, $result);
     $expected = md5($salt . $value);
     $result = String::hash($value, 'md5', $salt);
     $this->assertEqual($expected, $result);
     $sha256 = function ($value) {
         if (function_exists('mhash')) {
             return bin2hex(mhash(MHASH_SHA256, $value));
         } elseif (function_exists('hash')) {
             return hash('sha256', $value);
         }
         throw new Exception();
     };
     try {
         $expected = $sha256($value);
         $result = String::hash($value, 'sha256');
         $this->assertEqual($expected, $result);
         $expected = $sha256($salt . $value);
         $result = String::hash($value, 'sha256', $salt);
         $this->assertEqual($expected, $result);
     } catch (Exception $e) {
     }
 }
開發者ID:kdambekalns,項目名稱:framework-benchs,代碼行數:41,代碼來源:StringTest.php


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