search
HomeBackend DevelopmentPHP ProblemHow to replace link address in php

How to replace link address in php

Sep 22, 2021 am 09:29 AM
phpurlURL

php method to replace the link address: 1. Obtain the current script URL through the "function GetCurUrl(){...}" method; 2. Through the "function url_set_value($url,$key,$value)" {...}" method can be used to implement link replacement.

How to replace link address in php

The operating environment of this article: Windows 7 system, PHP version 7.1, Dell G3 computer.

How to replace the link address in php?

How to get the current URL and replace parameters or URLs with php

First, PHP gets the URL of the current page:

The code is as follows:

//获得当前的脚本网址 
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=321 in $url;
There are actually 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:

The code is as follows:

/* 将URL中的某参数设为某值*/ //【这一段就挺好啊】 
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. .

The code is as follows:

<?php 
/** 
*使用例程:可用于分页类或页面中的替换等 
$url = "add_jd.php?pid=4&tb=gm_jd&page=1"; 
echo( "原始的URL:" . $url ); 
echo( &#39;<br/>&#39; ); 
echo( "字符串参数:" . url::replace( $url , "pid=10,page=2") ); 
echo( &#39;<br/>&#39; ); 
echo( "数组型参数:" . url::replace( $url , array(&#39;pid&#39;=>10,&#39;page&#39;=>5)) ); 
//echo( urlReplace( $url , array(&#39;pid&#39;=>10,&#39;page&#39;=>5)) ); 
*/ 
/** 
* url replace 
* @param string $url 需要替换的URL字符串,一般为aaa.php?abc=def,也可以带上路径,象http://xxx.com/abc/def.php?aa=bb 
* @param mixed $options 需要替换的变量,可以是字符串或数组,如果是字符串,格式为"aa=bb,cc=dd",有多个,用","隔开 
* @return string $url 替换后的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, 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 [&#39;HTTP_HOST&#39;].$_SERVER[&#39;PHP_SELF&#39;]; 
echo $url_this;

and it displays: 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 items such as 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, $_SERVER and $_SERVER are separated $HTTP_SERVER_VARS array. 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"
The content of the Accept: header of the current request.

"HTTP_ACCEPT_CHARSET"
Contents of the Accept-Charset: header of the current request. For example: "iso-8859-1,*,utf-8".

"HTTP_ACCEPT_ENCODING"
Contents of the Accept-Encoding: header of the current request. For example: "gzip".

"HTTP_ACCEPT_LANGUAGE"
The content 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"
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 pathname 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 host name.

"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 of 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 the HTTP authentication function is being used, this variable is the username entered by the user.

"PHP_AUTH_PW"
When PHP is running in Apache module mode and the HTTP authentication function is being used, this variable is the password entered by the user.

"AUTH_TYPE"
When PHP is running in Apache module mode and the HTTP authentication function is being used, this variable is the type of authentication.

Recommended learning: "PHP Video Tutorial"

The above is the detailed content of How to replace link address in php. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
ACID vs BASE Database: Differences and when to use each.ACID vs BASE Database: Differences and when to use each.Mar 26, 2025 pm 04:19 PM

The article compares ACID and BASE database models, detailing their characteristics and appropriate use cases. ACID prioritizes data integrity and consistency, suitable for financial and e-commerce applications, while BASE focuses on availability and

PHP Secure File Uploads: Preventing file-related vulnerabilities.PHP Secure File Uploads: Preventing file-related vulnerabilities.Mar 26, 2025 pm 04:18 PM

The article discusses securing PHP file uploads to prevent vulnerabilities like code injection. It focuses on file type validation, secure storage, and error handling to enhance application security.

PHP Input Validation: Best practices.PHP Input Validation: Best practices.Mar 26, 2025 pm 04:17 PM

Article discusses best practices for PHP input validation to enhance security, focusing on techniques like using built-in functions, whitelist approach, and server-side validation.

PHP API Rate Limiting: Implementation strategies.PHP API Rate Limiting: Implementation strategies.Mar 26, 2025 pm 04:16 PM

The article discusses strategies for implementing API rate limiting in PHP, including algorithms like Token Bucket and Leaky Bucket, and using libraries like symfony/rate-limiter. It also covers monitoring, dynamically adjusting rate limits, and hand

PHP Password Hashing: password_hash and password_verify.PHP Password Hashing: password_hash and password_verify.Mar 26, 2025 pm 04:15 PM

The article discusses the benefits of using password_hash and password_verify in PHP for securing passwords. The main argument is that these functions enhance password protection through automatic salt generation, strong hashing algorithms, and secur

OWASP Top 10 PHP: Describe and mitigate common vulnerabilities.OWASP Top 10 PHP: Describe and mitigate common vulnerabilities.Mar 26, 2025 pm 04:13 PM

The article discusses OWASP Top 10 vulnerabilities in PHP and mitigation strategies. Key issues include injection, broken authentication, and XSS, with recommended tools for monitoring and securing PHP applications.

PHP XSS Prevention: How to protect against XSS.PHP XSS Prevention: How to protect against XSS.Mar 26, 2025 pm 04:12 PM

The article discusses strategies to prevent XSS attacks in PHP, focusing on input sanitization, output encoding, and using security-enhancing libraries and frameworks.

PHP Interface vs Abstract Class: When to use each.PHP Interface vs Abstract Class: When to use each.Mar 26, 2025 pm 04:11 PM

The article discusses the use of interfaces and abstract classes in PHP, focusing on when to use each. Interfaces define a contract without implementation, suitable for unrelated classes and multiple inheritance. Abstract classes provide common funct

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software