您的位置:

php复制url问题,php文件复制

本文目录一览:

求解一个php传递url参数问题

这个只是小小误区,把链接地址中的第二个?号改为号即可:

链接地址

改为:

链接地址

获取参数就可以了:

?

$url=$_GET['url'];//结果:localhost/public.php

$table=$_GET['table'];

$vcat=$_GET['vcat'];

$cat=$_GET['cat'];

$pic=$_GET['pic'];

?

然后就是合成地址:

?

$url=$_GET['url']."?talbe=".$table."vcat=".$vcat."cat=".$cat."pic=".$pic;

?

php打开URL的几种方法

PHP中打开URL地址的几种方法总结,这里的函数主要用于小偷采集等函数。

1: 用file_get_contents 

以get方式获取内容 

复制代码 代码如下:

?php 

$url=''; 

$html = file_get_contents($url); 

//print_r($http_response_header); 

ec($html); 

printhr(); 

printarr($http_response_header); 

printhr(); 

示例代码2: 用fopen打开url, 

以get方式获取内容 

复制代码 代码如下:

$fp = fopen($url, 'r'); 

printarr(stream_get_meta_data($fp)); 

printhr(); 

while(!feof($fp)) { 

$result .= fgets($fp, 1024); 

echo "url body: $result"; 

printhr(); 

fclose($fp); 

示例代码3:用file_get_contents函数,以post方式获取url 

复制代码 代码如下:

?php 

$data = array ('foo' = 

'bar'); 

$data = http_build_query($data); 

$opts = array ( 

'http' 

= array ( 

'method' = 'POST', 

'header'= "Content-type: 

application/x-www-form-urlencoded" . 

"Content-Length: " . strlen($data) . 

"", 

'content' = $data 

), 

); 

$context = 

stream_context_create($opts); 

$html = 

file_get_contents('', false, $context); 

echo $html; 

示例代码4:用fsockopen函数打开url,以get方式获取完整的数据,包括header和body 

复制代码 代码如下:

function get_url 

($url,$cookie=false) { 

$url = parse_url($url); 

$query = 

$url[path]."?".$url[query]; 

ec("Query:".$query); 

$fp = fsockopen( 

$url[host], $url[port]?$url[port]:80 , $errno, $errstr, 30); 

if (!$fp) { 

return false; 

} else { 

$request = "GET $query HTTP/1.1"; 

$request .= "Host: $url[host]"; 

$request .= "Connection: Close"; 

if($cookie) $request.="Cookie: $cookie\n"; 

$request.=""; 

fwrite($fp,$request); 

while(!@feof($fp)) { 

$result .= @fgets($fp, 

1024); 

fclose($fp); 

return $result; 

//获取url的html部分,去掉header 

function GetUrlHTML($url,$cookie=false) { 

$rowdata = get_url($url,$cookie); 

if($rowdata) 

$body= 

stristr($rowdata,""); 

$body=substr($body,4,strlen($body)); 

return $body; 

return false; 

?

php里怎么替换指定的一段url?

一是PHP获取当前页面的网址:

代码如下:

//获得当前的脚本网址

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;

}

另一个是PHP替换网址中query部分的某变量的值比如 ,我们要设$url中的key=321;

其实有几种情况:

$url='′;

或$url=';

或$url='′;

等等。虽然情况很多,但PHP处理起来非常简单,如下:

复制代码 代码如下:

/* 将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);

}

不过替换是这样写的

代码如下:

?php

/**

*使用例程:可用于分页类或页面中的替换等

$url = "add_jd.php?pid=4tb=gm_jdpage=1";

echo( "原始的URL:" . $url );

echo( 'br/' );

echo( "字符串参数:" . url::replace( $url , "pid=10,page=2") );

echo( 'br/' );

echo( "数组型参数:" . url::replace( $url , array('pid'=10,'page'=5)) );

//echo( urlReplace( $url , array('pid'=10,'page'=5)) );

*/

/**

* url replace

* @param string $url 需要替换的URL字符串,一般为aaa.php?abc=def,也可以带上路径,象

* @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;

}

}

虽然考虑了一些东西,但也仅仅是个很一般的解决方法

以下是一些补充资料:

例: 我需要 获取当前的 的URL 地址

$url_this = "http://".$_SERVER ['HTTP_HOST'].$_SERVER['PHP_SELF'];

echo $url_this;

则显示 :

服务器变量:$_SERVER

注: 在 PHP 4.1.0 及以后版本使用。之前的版本,使用 $HTTP_SERVER_VARS。

$_SERVER 是一个包含诸如头部(headers)、路径(paths)和脚本位置(script locations)的数组。数组的实体由 web 服务器创建。不能保证所有的服务器都能产生所有的信息;服务器可能忽略了一些信息,或者产生了一些未在下面列出的新的信息。这意味着,大量的这些变量在 CGI 1.1 specification 中说明,所以您应该仔细研究它。

这是一个“superglobal”,或者可以描述为自动全局变量。这只不过意味这它在所有的脚本中都有效。在函数或方法中您不需要使用 global $_SERVER; 访问它,就如同使用 $HTTP_SERVER_VARS 一样。

$HTTP_SERVER_VARS 包含着同样的信息,但是不是一个自动全局变量。(注意: $HTTP_SERVER_VARS 和 $_SERVER 是不同的变量,PHP 处理它们的方式不同。)

如果设置了 register_globals 指令,这些变量也在所有脚本中可用;也就是,分离了 $_SERVER 和 $HTTP_SERVER_VARS 数组。相关信息,请参阅安全的相关章节 使用 Register Globals。这些单独的全局变量不是自动全局变量。

您或许会发现下面列出的某些 $_SERVER 元素并不可用。注意,如果以命令行方式运行 PHP,下面列出的元素几乎没有有效的(或是没有任何实际意义的)。

“PHP_SELF”

当前正在执行脚本的文件名,与 document root相关。举例来说,在URL地址为 的脚本中使用 $_SERVER['PHP_SELF'] 将会得到 /test.php/foo.bar 这个结果。

如果 PHP 以命令行方式运行,该变量无效。

“argv”

传递给该脚本的参数。当脚本运行在命令行方式时,argv 变量传递给程序 C 语言样式的命令行参数。当调用 GET 方法时,该变量包含请求的数据。

“argc”

包含传递给程序的命令行参数的个数(如果运行在命令行模式)。

“GATEWAY_INTERFACE”

服务器使用的 CGI 规范的版本。例如,“CGI/1.1”。

'SERVER_NAME'

当前运行脚本所在服务器主机的名称。如果该脚本运行在一个虚拟主机上,该名称是由那个虚拟主机所设置的值决定。

'SERVER_SOFTWARE'

服务器标识的字串,在响应请求时的头部中给出。

“SERVER_PROTOCOL”

请求页面时通信协议的名称和版本。例如,“HTTP/1.0”。

“REQUEST_METHOD”

访问页面时的请求方法。例如:“GET”、“HEAD”,“POST”,“PUT”。

“QUERY_STRING”

查询(query)的字符串。

“DOCUMENT_ROOT”

当前运行脚本所在的文档根目录。在服务器配置文件中定义。

“HTTP_ACCEPT”

当前请求的 Accept: 头部的内容。

“HTTP_ACCEPT_CHARSET”

当前请求的 Accept-Charset: 头部的内容。例如:“iso-8859-1,*,utf-8”。

“HTTP_ACCEPT_ENCODING”

当前请求的 Accept-Encoding: 头部的内容。例如:“gzip”。

“HTTP_ACCEPT_LANGUAGE”

当前请求的 Accept-Language: 头部的内容。例如:“en”。

“HTTP_CONNECTION”

当前请求的 Connection: 头部的内容。例如:“Keep-Alive”。

“HTTP_HOST”

当前请求的 Host: 头部的内容。

“HTTP_REFERER”

链接到当前页面的前一页面的 URL 地址。不是所有的用户代理(浏览器)都会设置这个变量,而且有的还可以手工修改 HTTP_REFERER。因此,这个变量不总是正确真实的。

“HTTP_USER_AGENT”

当前请求的 User_Agent: 头部的内容。该字符串表明了访问该页面的用户代理的信息。一个典型的例子是:Mozilla/4.5 [en] (X11; U; Linux 2.2.9 i586)。您也可以使用 get_browser() 得到这个信息。

“REMOTE_ADDR”

正在浏览当前页面用户的 IP 地址。

'REMOTE_HOST'

正在浏览当前页面用户的主机名。反向域名解析基于该用户的 REMOTE_ADDR。

注: 必须配置 Web 服务器来建立此变量。例如 Apache 需要在 httpd.conf 中有 HostnameLookups On。参见 gethostbyaddr()。

“REMOTE_PORT”

用户连接到服务器时所使用的端口。

“SCRIPT_FILENAME”

当前执行脚本的绝对路径名。

“SERVER_ADMIN”

该值指明了 Apache 服务器配置文件中的 SERVER_ADMIN 参数。如果脚本运行在一个虚拟主机上,则该值是那个虚拟主机的值。

“SERVER_PORT”

服务器所使用的端口。默认为“80”。如果你使用 SSL 安全连接,则这个值为您所设置的 HTTP 端口。

“SERVER_SIGNATURE”

包含服务器版本和虚拟主机名的字符串。

“PATH_TRANSLATED”

当前脚本所在文件系统(不是文档根目录)的基本路径。这是在服务器进行虚拟到真实路径的映像后的结果。

“SCRIPT_NAME”

包含当前脚本的路径。这在页面需要指向自己时非常有用。

“REQUEST_URI”

访问此页面所需的 URI。例如,“/index.html”。

“PHP_AUTH_USER”

当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的用户名。

“PHP_AUTH_PW”

当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是用户输入的密码。

“AUTH_TYPE”

当 PHP 运行在 Apache 模块方式下,并且正在使用 HTTP 认证功能,这个变量便是认证的类型。

请问php如何能根据url地址拷贝该网页的所有内容+图片并生成一个本地文件?

复制+粘贴

针对你说的无法复制问题,是不是以下情况:

1、限制右键选中复制?

这个问题是因为网页脚本中有禁止鼠标右键动作的脚本,很好解决,换个浏览器(GreenBrowser - 绿色浏览器)就可以了,里面有解除鼠标右键禁止功能,这样你想怎么复制就怎么复制。

2、你直接用鼠标拖曳选中?

其实,可以用快捷键的方式来选中,复制的,如下:

把你所要发送的网页打开,Ctrl+A一下(这是全体选中,包括网页的全部以及滚动条以下的内容),再Ctrl+C复制。

然后再在你要编辑的信件中Ctrl+V粘贴,这样就能把网页中的内容全部都写在邮件中,包括所有的图片链接,其实等于是把这个网页都搬进了信件里,别人要想查看内容还是以网页的形式链接出去的。

选择浏览器上方菜单“文件”另存为

保存在你制定的文件夹内

再打开你保存的文件夹

会发现里面有两个文件

一是**.html

一是**.files

PHP怎么让直接复制URL的转跳到主页

不可能不行的, 把你写的代码贴上来....

-----------------------------------------------------

第一次登陆. $_SESSION['isLogined'] = true;

记录一下...

当复制URL打开新链接的时候(就是你说的直接进入main.php的时候).

if (isset($_SESSION['isLogined'])){ 说明是复制进来的......就注销,然后跳转呗 }

我觉得你在一个浏览器, 去做这些没什么意思.. 因为一个浏览器相对于服务器来说. 用的

是一个会话.... 无论这个浏览器开了多少选项卡......