


UINavigationController php method to get the current website URL and replace parameters or URLs
First, PHP gets the URL of the current page:
Copy the code The code is 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 to replace the value of a variable in the query part of the URL with PHP. For example, we want to set the key in $url=321;
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′;
etc. Although there are many situations, it is very simple to handle with PHP, as follows:
Copy the code The code is as follows:
/* Set a certain parameter in the URL to a certain value*/ //[This paragraph is pretty good. 】
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 like this. . Of course it sucks. .
Copy the code The code is as follows:
/**
*Usage routines: can be used for paging classes or replacements in pages, 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 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 that needs to be replaced, usually aaa.php?abc=def, you can also bring the path, like http://xxx.com/abc/def.php?aa =bb
* @param mixed $options The variable to be replaced can be a string or an array. If it is a string, the format is "aa=bb,cc=dd". If there are multiple, use "," to separate them
* @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 I have considered some things, it is only a very general solution
The following is some supplementary information:
Example: I need to get the current URL address
$url_this = "http://".$_SERVER ['HTTP_HOST '].$_SERVER['PHP_SELF'];
echo $url_this;
Then display: http://localhost/lu.php
Server variable: $_SERVER
Note: Used in PHP 4.1.0 and later versions. Previous versions, used $HTTP_SERVER_VARS.
$_SERVER is an array containing things like headers, paths, and script locations. The entities of the array are created by the web server. There is no guarantee that all servers will produce all messages; servers may ignore some messages or generate new messages not listed below. This means that a large number of these variables are specified in the CGI 1.1 specification, so you should study it carefully.
This is a "superglobal", or can be described as an automatic global variable. This just means that it works in all scripts. You do not need to use global $_SERVER; to access it within a function or method, as you would with $HTTP_SERVER_VARS.
$HTTP_SERVER_VARS contains the same information, but is not an automatic global variable. (Note: $HTTP_SERVER_VARS and $_SERVER are different variables, and PHP handles them differently.)
These variables are also available in all scripts if the register_globals directive is set; that is, the $_SERVER and $HTTP_SERVER_VARS arrays are separated. For related information, see the security-related chapter 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 few of the elements listed below are valid (or have no real meaning) if you run PHP from the command line.
"PHP_SELF"
The file name of the currently executing script, related to the document root. For example, using $_SERVER['PHP_SELF'] in a script with the URL address http://example.com/test.php/foo.bar will result in /test.php/foo.bar.
If PHP is run in command line mode, this variable has no effect.
"argv"
The arguments passed to this script. When the script is run in command-line mode, the argv variable is passed to the program as C-style command-line arguments. When the GET method is called, this variable contains the requested data.
"argc"
Contains the number of command line arguments passed to the program (if running 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 for that virtual host.
'SERVER_SOFTWARE'
The string identifying the server, given in the header when responding to the request.
"SERVER_PROTOCOL"
The name and version of the communication protocol when requesting the page. For example, "HTTP/1.0".
"REQUEST_METHOD"
The request method when accessing the page. For example: "GET", "HEAD", "POST", "PUT".
"QUERY_STRING"
The string of query.
"DOCUMENT_ROOT"
The document root directory where the currently running script is located. Defined in the server configuration file.
"HTTP_ACCEPT"
Contents of the Accept: header of the current request.
"HTTP_ACCEPT_CHARSET"
The contents of the Accept-Charset: header of the current request. For example: "iso-8859-1,*,utf-8".
"HTTP_ACCEPT_ENCODING"
The content of the Accept-Encoding: header of the current request. For example: "gzip".
"HTTP_ACCEPT_LANGUAGE"
Contents of the Accept-Language: header of the current request. For example: "en".
"HTTP_CONNECTION"
Contents of the Connection: header of the current request. For example: "Keep-Alive".
"HTTP_HOST"
Contents of the Host: header of the current request.
"HTTP_REFERER"
The URL address of the previous page linked to the current page. Not all user agents (browsers) will set this variable, and some can also modify HTTP_REFERER manually. Therefore, this variable is not always true.
"HTTP_USER_AGENT"
The contents of the User_Agent: header of the current request. This string indicates information about the user agent accessing this 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 create this variable. For example Apache requires HostnameLookups On in httpd.conf. See gethostbyaddr().
"REMOTE_PORT"
The port used by users to connect to the server.
"SCRIPT_FILENAME"
The absolute path name of the currently executing script.
"SERVER_ADMIN"
This value specifies the SERVER_ADMIN parameter in the Apache server configuration file. If the script is running on a virtual host, this value is that of that virtual host.
"SERVER_PORT"
The port used by the server. Default is "80".If you use an SSL secure connection, this value is the HTTP port you set.
"SERVER_SIGNATURE"
A string containing the server version and virtual hostname.
"PATH_TRANSLATED"
The base path of the file system (not the document root) where the current script is located. This is the result after the server has been imaged from a virtual to real path.
"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 Apache module mode and using the HTTP authentication function, this variable is the username entered by the user.
"PHP_AUTH_PW"
When PHP is running in Apache module mode and using the HTTP authentication function, this variable is the password entered by the user.
"AUTH_TYPE"
When PHP is running in Apache module mode and is using the HTTP authentication function, this variable is the authentication type.
The above introduces the method of UINavigationController php to get the current URL and replace the parameters or URL, including the content of UINavigationController. I hope it will be helpful to friends who are interested in PHP tutorials.

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Laravel simplifies handling temporary session data using its intuitive flash methods. This is perfect for displaying brief messages, alerts, or notifications within your application. Data persists only for the subsequent request by default: $request-

This is the second and final part of the series on building a React application with a Laravel back-end. In the first part of the series, we created a RESTful API using Laravel for a basic product-listing application. In this tutorial, we will be dev

Laravel provides concise HTTP response simulation syntax, simplifying HTTP interaction testing. This approach significantly reduces code redundancy while making your test simulation more intuitive. The basic implementation provides a variety of response type shortcuts: use Illuminate\Support\Facades\Http; Http::fake([ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

The PHP Client URL (cURL) extension is a powerful tool for developers, enabling seamless interaction with remote servers and REST APIs. By leveraging libcurl, a well-respected multi-protocol file transfer library, PHP cURL facilitates efficient execution of various network protocols, including HTTP, HTTPS, and FTP. This extension offers granular control over HTTP requests, supports multiple concurrent operations, and provides built-in security features.

Do you want to provide real-time, instant solutions to your customers' most pressing problems? Live chat lets you have real-time conversations with customers and resolve their problems instantly. It allows you to provide faster service to your custom

In this article, we're going to explore the notification system in the Laravel web framework. The notification system in Laravel allows you to send notifications to users over different channels. Today, we'll discuss how you can send notifications ov

Article discusses late static binding (LSB) in PHP, introduced in PHP 5.3, allowing runtime resolution of static method calls for more flexible inheritance.Main issue: LSB vs. traditional polymorphism; LSB's practical applications and potential perfo

PHP logging is essential for monitoring and debugging web applications, as well as capturing critical events, errors, and runtime behavior. It provides valuable insights into system performance, helps identify issues, and supports faster troubleshoot
