uri.java

来自「JAVA 所有包」· Java 代码 · 共 1,914 行 · 第 1/5 页

JAVA
1,914
字号
          break;        }        if (testChar == '%') {           if (index+2 >= end ||              !isHex(p_uriSpec.charAt(index+1)) ||              !isHex(p_uriSpec.charAt(index+2))) {            throw new MalformedURIException(                    "Query string contains invalid escape sequence!");           }           index += 2;        }        else if (!isURICharacter(testChar)) {          throw new MalformedURIException(                "Query string contains invalid character: " + testChar);        }        index++;      }      m_queryString = p_uriSpec.substring(start, index);    }    // fragment - starts with #    if (testChar == '#') {      index++;      start = index;      while (index < end) {        testChar = p_uriSpec.charAt(index);        if (testChar == '%') {           if (index+2 >= end ||              !isHex(p_uriSpec.charAt(index+1)) ||              !isHex(p_uriSpec.charAt(index+2))) {            throw new MalformedURIException(                    "Fragment contains invalid escape sequence!");           }           index += 2;        }        else if (!isURICharacter(testChar)) {          throw new MalformedURIException(                "Fragment contains invalid character: "+testChar);        }        index++;      }      m_fragment = p_uriSpec.substring(start, index);    }  } /**  * Get the scheme for this URI.  *  * @return the scheme for this URI  */  public String getScheme() {    return m_scheme;  } /**  * Get the scheme-specific part for this URI (everything following the  * scheme and the first colon). See RFC 2396 Section 5.2 for spec.  *  * @return the scheme-specific part for this URI  */  public String getSchemeSpecificPart() {    StringBuffer schemespec = new StringBuffer();    if (m_host != null || m_regAuthority != null) {      schemespec.append("//");          // Server based authority.      if (m_host != null) {        if (m_userinfo != null) {          schemespec.append(m_userinfo);          schemespec.append('@');        }                schemespec.append(m_host);                if (m_port != -1) {          schemespec.append(':');          schemespec.append(m_port);        }      }      // Registry based authority.      else {      	schemespec.append(m_regAuthority);      }    }    if (m_path != null) {      schemespec.append((m_path));    }    if (m_queryString != null) {      schemespec.append('?');      schemespec.append(m_queryString);    }    if (m_fragment != null) {      schemespec.append('#');      schemespec.append(m_fragment);    }    return schemespec.toString();  } /**  * Get the userinfo for this URI.  *  * @return the userinfo for this URI (null if not specified).  */  public String getUserinfo() {    return m_userinfo;  }  /**  * Get the host for this URI.  *  * @return the host for this URI (null if not specified).  */  public String getHost() {    return m_host;  } /**  * Get the port for this URI.  *  * @return the port for this URI (-1 if not specified).  */  public int getPort() {    return m_port;  }    /**   * Get the registry based authority for this URI.   *    * @return the registry based authority (null if not specified).   */  public String getRegBasedAuthority() {    return m_regAuthority;  }    /**   * Get the authority for this URI.   *    * @return the authority   */  public String getAuthority() {      StringBuffer authority = new StringBuffer();      if (m_host != null || m_regAuthority != null) {          authority.append("//");                    // Server based authority.          if (m_host != null) {                            if (m_userinfo != null) {                  authority.append(m_userinfo);                  authority.append('@');              }                            authority.append(m_host);                            if (m_port != -1) {                  authority.append(':');                  authority.append(m_port);              }          }          // Registry based authority.          else {              authority.append(m_regAuthority);          }      }      return authority.toString();  } /**  * Get the path for this URI (optionally with the query string and  * fragment).  *  * @param p_includeQueryString if true (and query string is not null),  *                             then a "?" followed by the query string  *                             will be appended  * @param p_includeFragment if true (and fragment is not null),  *                             then a "#" followed by the fragment  *                             will be appended  *  * @return the path for this URI possibly including the query string  *         and fragment  */  public String getPath(boolean p_includeQueryString,                        boolean p_includeFragment) {    StringBuffer pathString = new StringBuffer(m_path);    if (p_includeQueryString && m_queryString != null) {      pathString.append('?');      pathString.append(m_queryString);    }    if (p_includeFragment && m_fragment != null) {      pathString.append('#');      pathString.append(m_fragment);    }    return pathString.toString();  } /**  * Get the path for this URI. Note that the value returned is the path  * only and does not include the query string or fragment.  *  * @return the path for this URI.  */  public String getPath() {    return m_path;  } /**  * Get the query string for this URI.  *  * @return the query string for this URI. Null is returned if there  *         was no "?" in the URI spec, empty string if there was a  *         "?" but no query string following it.  */  public String getQueryString() {    return m_queryString;  } /**  * Get the fragment for this URI.  *  * @return the fragment for this URI. Null is returned if there  *         was no "#" in the URI spec, empty string if there was a  *         "#" but no fragment following it.  */  public String getFragment() {    return m_fragment;  } /**  * Set the scheme for this URI. The scheme is converted to lowercase  * before it is set.  *  * @param p_scheme the scheme for this URI (cannot be null)  *  * @exception MalformedURIException if p_scheme is not a conformant  *                                  scheme name  */  public void setScheme(String p_scheme) throws MalformedURIException {    if (p_scheme == null) {      throw new MalformedURIException(                "Cannot set scheme from null string!");    }    if (!isConformantSchemeName(p_scheme)) {      throw new MalformedURIException("The scheme is not conformant.");    }    m_scheme = p_scheme.toLowerCase();  } /**  * Set the userinfo for this URI. If a non-null value is passed in and  * the host value is null, then an exception is thrown.  *  * @param p_userinfo the userinfo for this URI  *  * @exception MalformedURIException if p_userinfo contains invalid  *                                  characters  */  public void setUserinfo(String p_userinfo) throws MalformedURIException {    if (p_userinfo == null) {      m_userinfo = null;      return;    }    else {      if (m_host == null) {        throw new MalformedURIException(                     "Userinfo cannot be set when host is null!");      }      // userinfo can contain alphanumerics, mark characters, escaped      // and ';',':','&','=','+','$',','      int index = 0;      int end = p_userinfo.length();      char testChar = '\0';      while (index < end) {        testChar = p_userinfo.charAt(index);        if (testChar == '%') {          if (index+2 >= end ||              !isHex(p_userinfo.charAt(index+1)) ||              !isHex(p_userinfo.charAt(index+2))) {            throw new MalformedURIException(                  "Userinfo contains invalid escape sequence!");          }        }        else if (!isUserinfoCharacter(testChar)) {          throw new MalformedURIException(                  "Userinfo contains invalid character:"+testChar);        }        index++;      }    }    m_userinfo = p_userinfo;  } /**  * <p>Set the host for this URI. If null is passed in, the userinfo  * field is also set to null and the port is set to -1.</p>  *   * <p>Note: This method overwrites registry based authority if it  * previously existed in this URI.</p>  *  * @param p_host the host for this URI  *  * @exception MalformedURIException if p_host is not a valid IP  *                                  address or DNS hostname.  */  public void setHost(String p_host) throws MalformedURIException {    if (p_host == null || p_host.length() == 0) {      if (p_host != null) {        m_regAuthority = null;      }      m_host = p_host;      m_userinfo = null;      m_port = -1;      return;    }    else if (!isWellFormedAddress(p_host)) {      throw new MalformedURIException("Host is not a well formed address!");    }    m_host = p_host;    m_regAuthority = null;  } /**  * Set the port for this URI. -1 is used to indicate that the port is  * not specified, otherwise valid port numbers are  between 0 and 65535.  * If a valid port number is passed in and the host field is null,  * an exception is thrown.  *  * @param p_port the port number for this URI  *  * @exception MalformedURIException if p_port is not -1 and not a  *                                  valid port number  */  public void setPort(int p_port) throws MalformedURIException {    if (p_port >= 0 && p_port <= 65535) {      if (m_host == null) {        throw new MalformedURIException(                      "Port cannot be set when host is null!");      }    }    else if (p_port != -1) {      throw new MalformedURIException("Invalid port number!");    }    m_port = p_port;  }    /**   * <p>Sets the registry based authority for this URI.</p>   *    * <p>Note: This method overwrites server based authority   * if it previously existed in this URI.</p>   *    * @param authority the registry based authority for this URI   *    * @exception MalformedURIException it authority is not a   * well formed registry based authority   */  public void setRegBasedAuthority(String authority)     throws MalformedURIException {  	if (authority == null) {  	  m_regAuthority = null;  	  return;  	}	// reg_name = 1*( unreserved | escaped | "$" | "," | 	//            ";" | ":" | "@" | "&" | "=" | "+" )  	else if (authority.length() < 1 ||  	  !isValidRegistryBasedAuthority(authority) ||  	  authority.indexOf('/') != -1) {      throw new MalformedURIException("Registry based authority is not well formed.");       	  	}  	m_regAuthority = authority;  	m_host = null;  	m_userinfo = null;

⌨️ 快捷键说明

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