Uinavigationcontroller php to get the URL of the current URL and replace the parameter or URL method

Source: Internet
Author: User
Tags http authentication
First, PHP gets the URL of the current page:

Copy the Code code as follows:


Get the current script URL
function Getcururl ()
{
if (!empty ($_server["Request_uri"))
{
$scriptName = $_server["Request_uri"];
$nowurl = $scriptName;
}
Else
{
$scriptName = $_server["Php_self"];
if (Empty ($_server["query_string"]))
{
$nowurl = $scriptName;
}
Else
{
$nowurl = $scriptName. "?". $_server["Query_string"];
}
}
return $nowurl;
}


The other is the value of a variable in the query section of the PHP replacement URL For example, we want to set the key=321 in the.
In fact, there are several situations:
$url = ' www.sina.com/a.php?key=330′;
or $url= ' www.sina.com/a.php;
or $url= ' www.sina.com/a.php?cat=2′;
Wait a minute. Although the situation is many, PHP is very simple to handle, as follows:

Copy the Code code as follows:


/* Set a parameter in the URL to a value *///"This is a good paragraph."
function Url_set_value ($url, $key, $value)
{
$a =explode ('? ', $url);
$url _f= $a [0];
$query = $a [1];
Parse_str ($query, $arr);
$arr [$key]= $value;
return $url _f. '? '. Http_build_query ($arr);
}


But my replacement is written in this way. Of course it sucks.

Copy the Code code as follows:


/**
* Use routines: can be used for paging class or page replacement, etc.
$url = "add_jd.php?pid=4&tb=gm_jd&page=1";
Echo ("Original URL:". $url);
Echo ('
' );
Echo ("string parameter:". Url::replace ($url, "pid=10,page=2"));
Echo ('
' );
Echo ("Array type parameter:". Url::replace ($url, Array (' PID ' =>10, ' page ' =>5));
Echo (Urlreplace ($url, Array (' PID ' =>10, ' page ' =>5));
*/
/**
* URL Replace
* @param string $url The URL string to be replaced, usually aaa.php?abc=def, or take the path, like HTTP://XXX.COM/ABC/DEF.PHP?AA=BB
* @param mixed $options need to replace the variable, can be a string or an array, if it is a string, formatted as "AA=BB,CC=DD", there are multiple, separated by ","
* @return string $url the replaced URL
*/
Class URL
{
static function replace ($url, $options)
{
$options = Self::optinit ($options);
$Query = Parse_url ($url, php_url_query);
if ($Query) {
Parse_str ($Query, $GET);
if ($GET) {
foreach ($GET as $_k = $_v) {
if (Array_key_exists ($_k, $options)) {
$GET [$_k] = $options [$_k];
// //}
//}
$GET = Array_merge ($GET, $options);
}
Return Str_replace ($Query, Http_build_query ($GET), $url);
}
if (! $Query && $options) {
Return $url. "?" . Http_build_query ($options);
}
return $url;
}
Static Private Function Optinit ($options)
{
if (is_string ($options)) {
$optlists = Power::normalize ($options);
foreach ($optlists as $val) {
List ($tmpKey, $tmpVal) = Power::normalize ($val, "=");
$opts [$tmpKey] = $tmpVal;
}
}else{
$opts = $options;
}
Unset ($options);
return $opts;
}
}


Although some things have been considered, but it is only a general solution
Here are some additional information:
Example: I need to get the current URL address
$url _this = "http://". $_server [' http_host '].$_server[' php_self '];
echo $url _this;
The display is: http://localhost/lu.php
Server variable: $_server
Note: Used in PHP 4.1.0 and later versions. Previous versions, using the $HTTP _server_vars.
$_server is an array that contains such things as the head (headers), Path (paths), and script location (scripts locations). The entity of the array is created by the Web server. There is no guarantee that all servers will generate all the information; the server may have ignored some information or generated some new information that is not listed below. This means that a large number of these variables are described in CGI 1.1 specification, so you should study it carefully.
This is a "superglobal", or can be described as an automatic global variable. This simply means that it works in all scripts. You do not need to use the global $_server in a function or method; Access it as if you were using a $HTTP _server_vars.
$HTTP _server_vars contains the same information, but not an automatic global variable. (Note: $HTTP _server_vars and $_server are different variables, and PHP handles them in different ways.) )
If the register_globals directive is set, these variables are also available in all scripts, that is, the $_server and $HTTP _server_vars arrays are separated. For related information, please refer to the section on security using Register Globals. These individual global variables are not automatic global variables.
You may find that some of the $_server elements listed below are not available. Note that if you run PHP as a command line, the elements listed below are almost no valid (or meaningless).
"Php_self"
The file name of the currently executing script, which is related to document root. For example, using $_server[' php_self ' in a script with a URL address of Http://example.com/test.php/foo.bar will give the result/test.php/foo.bar.
If PHP is running as a command line, the variable is not valid.
"ARGV"
The arguments passed to the script. When the script runs in command-line mode, the ARGV variable is passed to the program's C-language style command-line arguments. When the GET method is called, the variable contains the requested data.
"ARGC"
Contains the number of command-line arguments passed to the program (if run in command-line mode).
"Gateway_interface"
The version of the CGI specification used by the server. For example, "cgi/1.1".
' Server_Name '
The name of the server host where the script is currently running. If the script is running on a virtual host, the name is determined by the value set by that virtual host.
' Server_software '
The string that the server identifies is given in the header in response to the request.
"Server_protocol"
The name and version of the communication protocol when the page is requested. For example, "http/1.0".
"Request_method"
The request method when the page is accessed. For example:, POST, PUT.
"Query_string"
A string that queries (query).
"Document_root"
The document root directory where the script is currently running. Defined in the server configuration file.
"Http_accept"
Accept for current request: The contents of the header.
"Http_accept_charset"
Accept-charset of the current request: the contents of the header. For example: "Iso-8859-1,*,utf-8".
"Http_accept_encoding"
Accept-encoding of the current request: the contents of the header. For example: "gzip".
"Http_accept_language"
Accept-language of the current request: the contents of the header. For example: "en".
"Http_connection"
Connection of the current request: the contents of the header. For example: "Keep-alive".
"Http_host"
Host of the current request: the contents of the header.
"Http_referer"
The URL address of the previous page that links to the current page. Not all user agents (browsers) will set this variable, and some can manually modify the Http_referer. Therefore, this variable is not always correct and true.
"Http_user_agent"
User_agent of the current request: the contents of the header. The string indicates the information of the user agent accessing the page. A typical example is: mozilla/4.5 [en] (X11; U Linux 2.2.9 i586). You can also use Get_browser () to get this information.
"REMOTE_ADDR"
The IP address of the user who is browsing the current page.
' Remote_host '
The host name of the user who is browsing the current page. Reverse Domain name resolution is based on the user's remote_addr.
Note: The WEB server must be configured to establish this variable. For example, Apache needs to have hostnamelookups on in httpd.conf. See Gethostbyaddr ().
"Remote_port"
The port that the user uses when connecting to the server.
"Script_filename"
The absolute path name of the currently executing script.
"Server_admin"
This value indicates the Server_admin parameter in the Apache server configuration file. If the script is running on a virtual host, the value is the value of that virtual host.
"Server_port"
The port used by the server. The default is "80". If you are using an SSL secure connection, this value is the HTTP port you set.
"Server_signature"
A string containing the server version and the virtual host name.
"Path_translated"
The base path to the file system (not the document root) where the current script resides. This is the result of the server making a virtual-to-real-path image.
"Script_name"
Contains the path to the current script. This is useful when the page needs to point to itself.
"Request_uri"
The URI required to access this page. For example, "/index.html".
"Php_auth_user"
When PHP is running in the Apache module mode and is using the HTTP authentication feature, this variable is the user name entered by the user.
"PHP_AUTH_PW"
When PHP is running in the Apache module mode and is using the HTTP authentication function, this variable is the password entered by the user.
"Auth_type"
This variable is the type of authentication when PHP is running in the Apache module mode and is using the HTTP authentication feature.

The above describes the Uinavigationcontroller php to get the URL of the current URL and replace the parameters or URLs, including the uinavigationcontroller aspects of the content, I hope to be interested in PHP tutorial friends helpful.

  • Related Article

    Contact Us

    The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

    If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.