摘自PHP手册[6] – URL函数

来源:互联网 发布:c 串口接收数据 编辑:程序博客网 时间:2024/05/22 03:12

简介:处理 URL 字符串:编码、解码与解析。下面天涯进行详细的举例说明。

base64_encode — 使用 MIME base64 对数据进行编码
base64_encode() returns 使用 base64 对 data 进行编码。设计此种编码是为了使二进制数据可以通过非纯 8-bit 的传输层传输,例如电子邮件的主体。
Base64-encoded 数据要比原始数据多占用 33% 左右的空间。

  1. <?php
  2. $str = 'This is an encoded string';
  3. // VGhpcyBpcyBhbiBlbmNvZGVkIHN0cmluZw==
  4. echo base64_encode($str);
  5. ?>

base64_decode — 对使用 MIME base64 编码的数据进行解码
base64_decode() 对 encoded_data 进行解码,返回原始数据,失败则返回 FALSE。返回的数据可能是二进制的。

  1. <?php
  2. $str = 'VGhpcyBpcyBhbiBlbmNvZGVkIHN0cmluZw==';
  3. // This is an encoded string
  4. echo base64_decode($str);
  5. ?>

get_headers — 取得服务器响应一个 HTTP 请求所发送的所有标头
get_headers() 返回一个数组,包含有服务器响应一个 HTTP 请求所发送的标头。如果失败则返回 FALSE 并发出一条 E_WARNING 级别的错误信息。
如果将可选的 format 参数设为 1,则 get_headers() 会解析相应的信息并设定数组的键名。

  1. <?php
  2. //天涯PHP博客 http://blog.phpha.com
  3. $phpha1 = get_headers('http://blog.phpha.com');
  4. $phpha2 = get_headers('http://blog.phpha.com', 1);
  5. print_r($phpha1);
  6. print_r($phpha2);
  7. ?>
  8. //输出如下:
  9. Array
  10. (
  11. [0] => HTTP/1.1 200 OK
  12. [1] => Server: nginx/1.2.2
  13. [2] => Date: Tue, 06 Nov 2012 10:17:59 GMT
  14. [3] => Content-Type: text/html; charset=UTF-8
  15. [4] => Connection: close
  16. [5] => X-Powered-By: PHP/5.3.8
  17. [6] => X-Pingback: http://blog.phpha.com/xmlrpc.php
  18. [7] => Via: 10.67.15.26
  19. [8] => Set-Cookie: saeut=124.127.138.35.1352197078737175; path=/; max-age=311040000
  20. )
  21. //天涯PHP博客 http://blog.phpha.com
  22. Array
  23. (
  24. [0] => HTTP/1.1 200 OK
  25. [Server] => nginx/1.2.2
  26. [Date] => Tue, 06 Nov 2012 10:17:59 GMT
  27. [Content-Type] => text/html; charset=UTF-8
  28. [Connection] => close
  29. [X-Powered-By] => PHP/5.3.8
  30. [X-Pingback] => http://blog.phpha.com/xmlrpc.php
  31. [Via] => 10.67.15.21
  32. [Set-Cookie] => saeut=124.127.138.35.1352197079055460; path=/; max-age=311040000
  33. )

get_meta_tags — 从一个文件中提取所有的 meta 标签 content 属性,返回一个数组
【天涯注】可以想象的到,某些网站可以方便的用此函数进行网站SEO信息的提取。

  1. <?php
  2. //天涯PHP博客 http://blog.phpha.com
  3. $phpha = get_meta_tags('http://blog.phpha.com');
  4. print_r($phpha);
  5. ?>
  6. //输出如下:
  7. Array
  8. (
  9. [keywords] => 天涯博客,PHP博客,PHP技术博客,PHP学习博客,PHP开发博客
  10. [description] => 天涯PHP博客是以PHP为主的学习博客,记载PHPER的学习历程,关注互联网最新发展动态。
  11. [generator] => WordPress 3.2.1
  12. )

http_build_query — 生成 URL-encode 之后的请求字符串

  1. <?php
  2. $url = array('c'=>'blog', 'a'=>'show', 'id'=>10, 'hello', 'world');
  3. // c=blog&a=show&id=10&0=hello&1=world
  4. echo http_build_query($url);
  5. // c=blog&a=show&id=10&phpha_0=hello&phpha_1=world
  6. echo http_build_query($url, 'phpha_');
  7. ?>

【天涯注】这个函数目前我用的最多的地方就是做各种API时,组合请求的url,非常的方便。
另外可以看到,对于数组内数字索引的成员,还可以指定前缀。

parse_url — 解析 URL,返回其组成部分
本函数解析一个 URL 并返回一个关联数组,包含在 URL 中出现的各种组成部分。本函数不是用来验证给定 URL 的合法性的,只是将其分解为下面列出的部分。不完整的 URL 也被接受,parse_url() 会尝试尽量正确地将其解析。

  1. <?php
  2. $url = 'http://tianya:phphadotcom@phpha.com/hello.php?id=10#nav';
  3. print_r(parse_url($url));
  4. ?>
  5. Array
  6. (
  7. [scheme] => http
  8. [host] => phpha.com
  9. [user] => tianya
  10. [pass] => phphadotcom
  11. [path] => /hello.php
  12. [query] => id=10
  13. [fragment] => nav
  14. )

rawurlencode — 按照 RFC 1738 对 URL 进行编码
rawurldecode — 对已编码的 URL 字符串进行解码
urlencode — 编码 URL 字符串
urldecode — 解码已编码的 URL 字符串

  1. <?php
  2. //天涯PHP博客 http://blog.phpha.com
  3. $url = 'http://blog.phpha.com tianya';
  4. echo urlencode($url);
  5. echo '<br />';
  6. echo rawurlencode($url);
  7. echo '<br />';
  8. echo urldecode($url);
  9. echo '<br />';
  10. echo rawurldecode($url);
  11. ?>
  12. 输出如下:
  13. http%3A%2F%2Fblog.phpha.com+tianya
  14. http%3A%2F%2Fblog.phpha.com%20tianya
  15. http://blog.phpha.com tianya
  16. http://blog.phpha.com tianya

可以看到,urlencode与rawurlencode的区别在于:
urlencode() 会把空格编码为加号(+),rawurlencode() 则把空格编码为 %20
urldecode()和rawurldecode() 则为对应的解码函数。

来源: http://blog.phpha.com/archives/898.html
标签: PHP  url  手册  系统函数

Posted under: PHP,PHP手册

Tagged as: PHP,url, 手册, 系统函数


原创粉丝点击