uri.php.svn-base

来自「PHP 知识管理系统(基于树结构的知识管理系统), 英文原版的PHP源码。」· SVN-BASE 代码 · 共 168 行

SVN-BASE
168
字号
<?php/** * Zend Framework * * LICENSE * * This source file is subject to the new BSD license that is bundled * with this package in the file LICENSE.txt. * It is also available through the world-wide-web at this URL: * http://framework.zend.com/license/new-bsd * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to license@zend.com so we can send you a copy immediately. * * @category   Zend * @package    Zend_Uri * @copyright  Copyright (c) 2005-2007 Zend Technologies USA Inc. (http://www.zend.com) * @license    http://framework.zend.com/license/new-bsd     New BSD License *//** * Zend_Uri_Exception */require_once 'Zend/Uri/Exception.php';/** * Zend_Uri_Http */require_once 'Zend/Uri/Http.php';/** * Zend_Uri_Mailto */require_once 'Zend/Uri/Mailto.php';/** * @category   Zend * @package    Zend_Uri * @copyright  Copyright (c) 2005-2007 Zend Technologies USA Inc. (http://www.zend.com) * @license    http://framework.zend.com/license/new-bsd     New BSD License */abstract class Zend_Uri{	/**	 * Scheme of this URI (http, ftp, etc.)	 * @var string	 */	protected $_scheme = '';    /**     * Return a string representation of this URI.     *     * @see     getUri()     * @return  string     */    public function __toString()    {        return $this->getUri();    }    /**     * Convenience function, checks that a $uri string is well-formed     * by validating it but not returning an object.  Returns TRUE if     * $uri is a well-formed URI, or FALSE otherwise.     *     * @param string $uri     * @return boolean     */    static public function check($uri)    {        try {            $uri = self::factory($uri);        } catch (Exception $e) {            return false;        }        return $uri->valid();    }    /**     * Create a new Zend_Uri object for a URI.  If building a new URI, then $uri should contain     * only the scheme (http, ftp, etc).  Otherwise, supply $uri with the complete URI.     *     * @param string $uri     * @throws Zend_Uri_Exception     * @return Zend_Uri     */    static public function factory($uri = 'http')    {        /**         * Separate the scheme from the scheme-specific parts         * @link http://www.faqs.org/rfcs/rfc2396.html         */        $uri = explode(':', $uri, 2);        $scheme = strtolower($uri[0]);        $schemeSpecific = isset($uri[1]) ? $uri[1] : '';        if (!strlen($scheme)) {            throw new Zend_Uri_Exception('An empty string was supplied for the scheme');        }        // Security check: $scheme is used to load a class file, so only alphanumerics are allowed.        if (!ctype_alnum($scheme)) {            throw new Zend_Uri_Exception('Illegal scheme supplied, only alphanumeric characters are permitted');        }        /**         * Create a new Zend_Uri object for the $uri. If a subclass of Zend_Uri exists for the         * scheme, return an instance of that class. Otherwise, a Zend_Uri_Exception is thrown.         */        switch ($scheme) {            case 'mailto':                // fall through to next case            case 'http':                // fall through to next case            case 'https':                if ($scheme == 'https' or $scheme == 'http') {                    $className = 'Zend_Uri_Http';                } else {                    $className = 'Zend_Uri_' . ucfirst($scheme);                }                return new $className($scheme, $schemeSpecific);            default:				throw new Zend_Uri_Exception("Scheme \"$scheme\" is not supported");        }    }    /**     * Get the URI's scheme     *     * @return string|false Scheme or false if no scheme is set.     */    public function getScheme()    {    	if (!empty($this->_scheme)) {    		return $this->_scheme;    	} else {    		return false;    	}    }    /******************************************************************************     * Abstract Methods     *****************************************************************************/    /**     * Zend_Uri and its subclasses cannot be instantiated directly.     * Use Zend_Uri::factory() to return a new Zend_Uri object.     */    abstract protected function __construct($scheme, $schemeSpecific = '');    /**     * Return a string representation of this URI.     *     * @return string     */    abstract public function getUri();    /**     * Returns TRUE if this URI is valid, or FALSE otherwise.     *     * @return boolean     */    abstract public function valid();}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?