首页 > 编程技术 > php

php实现301永久重定向和302临时重定向方法

发布时间:2016-11-25 15:42

在服务器中301与302对于搜索引擎来讲一个是永久的跳新的地址了,一个是告诉你暂时到了一个新地址了,那么我们在php中怎么实现301永久重定向和302临时重定向呢,下面我们一起来看看方法的实现程序。


实现重定向的原理很简单,就是Web服务器返回个HTTP header给浏访问者,PHP发送HTTP header这个功能是由header()函数来实现的。301, 302, 404 这些状态码是在HTTP协议中约定好的,所以不用打破沙锅问“为什么是301而不是3001”。扯多了,回到正题。

PHP 301重定向:

 代码如下 复制代码

header('HTTP/1.1 301 Moved Permanently'); 

Header( "Location: http://www.111cn.net/" ); 

exit();

或者

 代码如下 复制代码

    <?php
    //301永久重定向

    $http_protocol = $_SERVER['SERVER_PROTOCOL'];   //http协议版本

    //如果是其他协议,则默认为HTTP/1.0
    if ( 'HTTP/1.1' != $http_protocol && 'HTTP/1.0' != $http_protocol )
        $http_protocol = 'HTTP/1.0';

    //响应301状态码
    header("$http_protocol 301 Moved Permanently");

    //指定重定向的URL
    $new_url = 'http://www.111cn.net/';
    header("Location:$new_url");
    ?>

PHP 302重定向:

 代码如下 复制代码

header("Location: http://www.hzhuti.com/"); 

exit();

顺到把PHP 404错误也附带上:

 代码如下 复制代码

header("HTTP/1.1 404 Not Found"); 

exit();

这里关于php 301与302重定向就讲到了这里了,下面附一下apache做法

例:

APACHE

 代码如下 复制代码

Redirect 301 /old/old.htm http://www.111cn.net/new.htm
Redirect permanent /one http://111cn.net/two
RedirectMatch 301 (.*).gif$ http://www.111cn.net/images/$1.jpg


2.使用mod_rewrite重写URL方式

APACHE

 代码如下 复制代码

Options +FollowSymLinks
RewriteEngine on
RewriteCond %{HTTP_HOST} ^111cn.net
RewriteRule ^(.*)$ http://www.111cn.net/$1 [R=permanent,L]

关于apache htaccess这里就不介绍人了与mod_rewrite重写URL方式几乎是完全一样的哦。

在应用开发中有不少朋友会碰到session无效了或session丢失问题,下面我来整理一些导致PHP Session丢失无效问题与解决方法。

 前两天玩了一下云边的轻博客,觉得东西比较小巧,自己也想弄个东西,就直接放到服务器里装了,结果啊!!!$_SESSION丢失了好几天~
情况描述:

    $_SESSION只能在当前的访问里有效,第二次请求就像之前执行过<per>www.111cn.net session_destroy()</per>

一样,$_SESSION里的内容会没了,就一个

    array();


下面是我对这个问题的查找目标路线:
1. session_start(): 想到每一次访问里都能用$_SESSION来写值存值,马上就撤掉了;
2. session过期:但发现在代码里这么一行

 代码如下 复制代码

    ini_set('session.gc_maxlifetime',$lefttime);

,所以也不是这个原因;
3. cookie禁用了:查看了一上浏览器里的cookie 的储存,也没有什么被禁用,程序里写的值在,用打印了一下$_COOKIES都在,也排除了;
4. speedphp里的问题:网上找了一遍相关的关键字也没有发现类似的情况,多的就是讲在一次写入里丢失了一个$_SESSION变量,跟我这个情况不一样,然后又自己加了行session_start();跟其它的一些调试变量及打印,但还是没有结果,于也排除;
5. 求助网友:发了一条求助信息“session只能在当前访问里有效,第二次访问时感觉就像执行了session_destroy(),之前所有内容都没有了,会是哪些原因?求思路…”,啊那个叫“秦淮公子(234427967) 20:32:45 磁盘不能写了”回了果么一条,立马去/etc下打开php.ini看session的存放路径,一路cd进去,神速“ll”,啊!!!!当时就无语了啊,看着

 代码如下 复制代码

    drwxrwx--- 2 root apache xxxx ....

当时就无语了。

 代码如下 复制代码

    chmod 777 session

后,纠结解除~
结论:SESSION丢失,记得先从目录权限开始

中文处理在php中处理总是不那么完美经常会碰到中文处理时乱码或为空问题,下面我在处理json时也碰到同样的问题,后来整理一个完美解决 json_encode 中文乱码或为空程序类。
 代码如下 复制代码

/**************************************************************
    *
    * 使用特定function对数组中所有元素做处理
    * @param string &$array 要处理的字符串
    * @param string $function 要执行的函数
    * @return boolean $apply_to_keys_also 是否也应用到key上
    * @access public
    *
    *************************************************************/
    function arrayRecursive(&$array, $function, $apply_to_keys_also = false)
    {
    static $recursive_counter = 0;
    if (++$recursive_counter > 1000) {
    die('possible deep recursion attack');
    }
    foreach ($array as $key => $value) {
    if (is_array($value)) {
    arrayRecursive($array[$key], $function, $apply_to_keys_also);
    } else {
    $array[$key] = $function($value);
    }
    if ($apply_to_keys_also && is_string($key)) {
    $new_key = $function($key);
    if ($new_key != $key) {
    $array[$new_key] = $array[$key];
    unset($array[$key]);
    }
    }
    }
    $recursive_counter--;
    }
    /**************************************************************
    *
    * 将数组转换为JSON字符串(兼容中文)
    * @param array $array 要转换的数组
    * @return string 转换得到的json字符串
    * @access public
    *
    *************************************************************/
    function JSON($array) {
    arrayRecursive($array, 'urlencode', true);
    $json = json_encode($array);
    return urldecode($json);
    }
    
    $array = array
    (
    'Name'=>'络恩',
    'Age'=>24
    );
    
    
    echo JSON($array);
这里我整理了一些常用的ip地址api第三方jsonp接口了,像淘宝的这里就找到了,如果有找到的朋友在下面留方加上,我将补充上来。

腾讯IP地址查询接口:http://fw.qq.com/ipaddress
新浪IP地址查询接口:http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=js
搜狐IP地址查询接口:http://pv.sohu.com/cityjson
谷歌IP地址查询接口:http://j.maxmind.com/app/geoip.js
有道IP地址查询接口:http://www.youdao.com/smartresult-xml/search.s
1616 IP地址查询接口:http://w.1616.net/chaxun/iptolocal.php
126 http://ip.ws.126.net/ipquery
hao123 http://app.hao123.com/ipquery/getcity.php?rtype=2

下面我看一下测试腾讯IP地址aip

腾讯的IP地址API接口地址:http://fw.qq.com/ipaddress

返回的是数据格式为:

 代码如下 复制代码

var IPData = new Array(“58.218.198.205″,”",”江苏省”,”徐州市”);

使用JS代码进行调取:

 代码如下 复制代码

<script language="javascript" type="text/javascript"" width=100% src="http://fw.qq.com/ipaddress"></script>
<script>document.write("你的IP是:"+IPData[0]+",来自:"+IPData[2]);</script>

新浪IP地址查询接口返回的为

 代码如下 复制代码

var remote_ip_info = {"ret":1,"start":"123.68.0.0","end":"123.68.195.255","country":"u4e2du56fd","province":"u6e56u5357","city":"u957fu6c99","district":"","isp":"u94c1u901a","type":"","desc":""};

搜狐IP地址查询接口

 代码如下 复制代码

var returnCitySN = {"cip": "123.68.122.147", "cid": "430000", "cname": "湖南省"};

好了其它的我就不介绍了大家自行操作吧。

ip黑名单实现方法是先把要过滤的IP放在一个txt文件或数据库中,然后当我们访问时获取我们的IP地址然后进行遍历对比即可实现了。


学校的新闻系统要求有些新闻只开放校内ip浏览,于是重写了一个代码来实现此功能,实现后的结果是,只要把允许访问的ip列入ip.txt这个文件中即可,同时支持c类ip,例如:

ip.txt
192.168
211.67.188
211.67.191.25
代码如下:

 代码如下 复制代码

/*
* ip地址黑名单、白名单
* 判断访客地址的ip是否在ip.txt中,支持c类ip
* By xhat
*/

$ip = $_SERVER['REMOTE_ADDR'];
$ipArray = preg_replace("#rn?|n#","",file('ip.txt'));
foreach ($ipArray as $ipTest) {
if (substr_count($ip, $ipTest) != "0") {
echo "ok"; //执行相关命令
die();
}
}

?>

上面大家可以使用代码来骗过了,下面代码进行升级

 代码如下 复制代码

<?php
class block_ip {
var $Block_ip = array("192.168.1.1","210.10.2.1-20","222.34.4.*");
function __construct(){
}
function __destruct(){
}
private function makePregIP($str){
if (strstr($str,"-")) {
$aIP = explode(".",$str);
foreach ($aIP as $k=>$v) {
if (!strstr($v,"-")) {
$preg_limit .= makePregIP($v);
} else{
$aipNum = explode("-",$v);
for($i=$aipNum[0];$i<=$aipNum[1];$i++){
$preg .=$preg?"|".$i:"[".$i;
}
$preg_limit .=strrpos($preg_limit,".",1)==(strlen($preg_limit)-1)?$preg."]":".".$preg."]";
}
}
}else{
$preg_limit .= $str.".";
}
return $preg_limit;
}
private function getAllBlockIP(){
if ($this->Block_ip) {
foreach ($this->Block_ip as $k=>$v) {
$ipaddres = $this->makePregIP($v->start_ip);
$ip = str_ireplace(".",".",$ipaddres);
$ip = str_replace("*","[0-9]{1,3}",$ip);
$ipaddres = "/".$ip."/";
$ip_list[] = $ipaddres;
}
}
return $ip_list;
}
public function checkIP() {
$iptable = $this->getAllBlockIP();
$IsJoined = true;
//取得用户ip
$Ip = $this->get_client_ip();
$Ip = trim($Ip);
//剔除黑名单中的IP区段
if ($iptable) {
foreach($iptable as $value) {
if (preg_match("{$value}",$Ip)) {
$IsJoined = false;
break;
}
}
}
// www.111cn.net如果在ip黑名单中就执行如下操作
if( !$IsJoined ){
echo "IP Error";
exit;
}
}
private function get_client_ip(){
if (getenv("HTTP_CLIENT_IP") && strcasecmp(getenv("HTTP_CLIENT_IP"), "unknown"))
$ip = getenv("HTTP_CLIENT_IP");
else if (getenv("HTTP_X_FORWARDED_FOR") && strcasecmp(getenv("HTTP_X_FORWARDED_FOR"), "unknown"))
$ip = getenv("HTTP_X_FORWARDED_FOR");
else if (getenv("REMOTE_ADDR") && strcasecmp(getenv("REMOTE_ADDR"), "unknown"))
$ip = getenv("REMOTE_ADDR");
else if (isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], "unknown"))
$ip = $_SERVER['REMOTE_ADDR'];
else
$ip = "unknown";
return($ip);
}
}
?>

引用片段:

 代码如下 复制代码

$oBlock_ip = new block_ip();
$oBlock_ip->checkIP();

标签:[!--infotagslink--]

您可能感兴趣的文章: