首页 > 编程技术 > php

PHPCMS手机站伪静态设置详细教程

发布时间:2017-7-6 23:49

PHPCMS手机站伪静态怎么设置?本文详细介绍了PHPCMS手机站伪静态设置详细教程非常实用,有兴趣的同学快来看看吧!

1、打开/phpcms/modules/wap/functions/global.func.php

找到里面的这两个函数,如下图所示的注释掉的那行代码,在下面加入一行代码。

 代码如下复制代码

functionlist_url($typeid) {

  #returnWAP_SITEURL."&a=lists&typeid=$typeid";

  return"/list-$typeid".'.html'

}

functionshow_url($catid,$id,$typeid='') {

global$WAP;

if($typeid=='') {

 $types= getcache('wap_type','wap');

 foreach($typesas$type) {

  if($type['cat']==$catid) {

  $typeid=$type['typeid'];

  break;

  }

 }

  #returnWAP_SITEURL."&a=show&catid=$catid&typeid=$typeid&id=$id";

  return"/show-$catid-$typeid-$id-1".'.html'

}

 

2、打开/phpcms/modules/wap/index.php

找到第59行,如下图所示的注释掉的那行代码,在下面加入一行代码。

 代码如下复制代码

#define('URLRULE','index.php?m=wap&c=index&a=lists&typeid={$typeid}~index.php?m=wap&c=index&a=lists&typeid={$typeid}&page={$page}');

define('URLRULE','list-{$typeid}.html~list-{$typeid}-{$page}.html');

3、添加伪静态规则

我使用的是apache服务器,把apache服务器设置支持.htaccess文件,在网站根目录创建.htaccess文件,在里面添加代码:

 代码如下复制代码

RewriteEngine On 

RewriteRule ^list-([0-9]+)-([0-9]+) index.php?&a=lists&typeid=$1&page=$2

RewriteRule ^list-([0-9]+) index.php?&a=lists&typeid=$1;

RewriteRule ^show-([0-9]+)-([0-9]+)-([0-9]+) index.php?a=show&catid=$1&typeid=$2&id=$3;

这样,phpcms手机站就变成伪静态了。

.htaccess如何设置和创建可自行百度一下,方法都比较简单,这里就不细说了。

如果是nginx服务器,重写规则这样写:

 代码如下复制代码

rewrite ^/list-([0-9]+).html /index.php?&a=lists&typeid=$1last;

rewrite ^/show-([0-9]+)-([0-9]+)-([0-9]+)-1.html /index.php?a=show&catid=$1&typeid=$2&id=$3last;

小编分享的这篇文章介绍了PHP单例模式定义与使用实例详解,非常实用,有兴趣的同学可以参考一下本文。

先简单的介绍一下单例模式。单例模式就是在应用程序中保持某一个类实例只存在一个,而且不可以受外部环境的影响而生成这个类的第二个实例。它的优点,实际点见,如果在WEB开发中,保持单一个数据操作类实例的存在,可以减少不必要的多余连接数据库资源的消耗,对于大型的软件开发来说,可以使用单例来维持程序的状态,使不同操作实现同步,因为单例一直占据内存,而从不会有副本。

而对于PHP,使用单例最常用的场合莫过于写一个数据库操作类。不过在PHP中实现单例,有以下规则:

1)单例类必须拥有一个现式声明的构造函数,并且是私有的。

2)单例类必须有一个静态变量来存储类的实例,这样可以保持这个单例类就只有那么一个实例。

3)单例类必须提供一个静态方法,供其他所有的对象应用这个单例。

为什么要满足以上三个条件呢:

1)因为单例类在整个应用程序运行时,只能被创造一次,而且这种创造是不是通过外部调用而完成,而是自身完成。所以单例类是自己实例化自己,所以其构造函数必须是私有。任何其他外部对象都不可以再次构造一个单例类的副本。

2)因为单例类只能够自己实例化自己,而又要为所有外部应用提供自己的实例,所以类内部必须有一个可供外界访问,而又是唯一不变的访问存储对象点,所以要提供一个静态变量去存储单例类自己实例化自己的那个实例对象。

3)因为单例类的构造函数是私有的,所以单例类必须提供一个外部接口供外部环境调用单例类,所以必须有一个静态方法,它可以初始化单例类或者返回单例类的对象的引用。

一个简单的例子:

 代码如下复制代码

classDB{

   private$_link;

   //   保持单例类的静态变量

   static$_instance;

   //   私有的构造函数

   privatefunction__construct(){

       $this->_link = @mysqli_connect(__HOST__, __USER__, __PASSWORD__, __DATABASE__);

       if(! ($this->_link)){

          echo'Something wrong occurs on the database connection!' 

       }

   }

   //   防止单例类被克隆

   privatefunction__clone(){}

   //   外界访问单例类实例的接口

   publicstaticfunctiongetInstance(){

       if(! (self::$_instanceinstanceofself)){

          self::$_instance=newself();

       }

       returnself::$_instance;

   }

}

注意,以上定义的一个 __clone() 函数,防止单例类对象被克隆。

以下也是一个简单的数据库操作类的单例,供参考:

 代码如下复制代码

classDB {

   /**

    * the database connection

    * @var   resource

    * @access private

    */

   private$_link;

   /**

    * the static instance of single db

    * @var   object

    * @access static

    */

   static$_instance;

   /**

    * construct the single object

    * @return null

    * @access private

    */

   privatefunction__construct(){

       $this->_link = @mysqli_connect(__HOST__, __USER__, __PASSWORD__, __DATABASE__);

       if(! ($this->_link)){

          echo'Something wrong occurs on the database connection!' 

       }

   }

   /**

    * empty clone

    * @return null

    * @access private

    */

   privatefunction__clone(){}

   /**

    * for other object to get the instance of db

    * @return self::instance

    * @access public

    */

   publicstaticfunctiongetInstance(){

       if(! (self::$_instanceinstanceofself)){

          self::$_instance=newself();

       }

       returnself::$_instance;

   }

   /**

    * query

    * @param  sql string

    * @param  message string

    * @return   resource

    * @access public

    */

   publicfunctionquery($sql,$message){

       $result= @mysqli_query($this->$_link,$sql)ordie($message. mysqli_error($this->$_link));

       return$result;

   }

   /**

    * mysqli_num_rows

    * @param  result resource

    * @return   int

    * @access public

    */

   publicfunctionnum($result){

       return@mysqli_num_rows($result);

   }

   /**

    * mysqli_fetch_array

    * @param  result resource

    * @return   array

    * @access public

    */

   publicfunctionfetchArr($result){

       return@mysqli_fetch_array($result);

   }

   /**

    * mysqli_insert_id

    * @return   int

    * @access public

    */

   publicfunctionlast_id(){

       return@mysqli_insert_id($this->_link);  

   }

   /**

    * close the database connection

    * @param  result resource

    * @return   null

    * @access public

    */

   publicfunctionclose(){

       @mysqli_close($this->_link);

   }

   /**

    * fetch once result from the specific sql query

    * @param  sql string

    * @param  message string

    * @return   array

    * @access public

    */

   publicfunctionfetchArrOnce($sql,$message){

       $result=$this->query($sql,$message);

       $row=$this->fetchArr($result);

       return$row;

   }

   /**

    * fetch all results from the specific sql query

    * @param  sql string

    * @param  message string

    * @return   array

    * @access public

    */

   publicfunctionfetchArrMore($sql,$message){

       $result=$this->query($sql,$message);

       $moreRow=array();

       while($row=$this->fetchArr($result)){

          $moreRow[] =$row;

       }

       return$moreRow;

   }

   /**

    * fetch the number of results from the specific sql query

    * @param  sql string

    * @param  message string

    * @return   array

    * @access public

    */

   publicfunctionfetchNum($sql,$message){

       $result=$this->query($sql,$message);

       $resultNum=$this->num($result);

       return$resultNum;

   }

   /**

    * mysqli_prepare

    * @param  sql string

    * @return   stmt object

    * @access public

    */

   publicfunctionprepare($sql){

       return@mysqli_prepare($this->_link,$sql);

   }

   /**

    * mysqli_stmt_execute

    * @param  stmt object

    * @param  message string

    * @return   bool

    * @access public

    */

   publicfunctionstmt_execute($stmt,$message){

       @mysqli_stmt_execute($stmt)ordie($message. mysqli_error($this->_link));

   }

}

使用:

 代码如下复制代码

define("__HOST__","localhost");

define("__USER__","root");

define("__PASSWORD__","");

define("__DATABASE__","eee");

$db= DB::getInstance();

小编推荐的这篇文章详细介绍了PHP第三方登录—QQ登录实现方法,非常实用,有兴趣的同学快来看看吧!

oAuth基本原理

接入QQ登录前置条件

申请AppID 和Appkey

登录QQ互联申请网站应用或移动应用接入

按照步骤申请成功后,创建应用即可看到对应的AppId和AppKey

引入官方SDK

添加测试回调地址

1、在本地添加一个虚拟主机**,比如域名为test.gz06.cn,然后在hosts文件中加入此域名

127.0.0.1       localhost test.gz06.cn

2、在QQ互联的应用信息编辑中将本地添加的测试回调域名加入到回调地址中,用 ; 好分隔,修改的时候要再次点击验证,然后保存即可

http://gz06.cn;http://test.gz06.cn/callback.php

3、引入官方SDK

4、SDK参数配置

访问下载到根目录下的SDK


http://test.gz06.cn/Connect2.1/

提示需要配置参数,点击进去

配置所需参数

小编推荐的这篇文章介绍了php计算给定日期所在周的开始日期和结束日期示例,非常实用,有兴趣的同学快来看看吧。
 代码如下 复制代码

<?php

/**

 * 取得给定日期所在周的开始日期和结束日期

 * @param string $gdate 日期,默认为当天,格式:YYYY-MM-DD

 * @param int $weekStart 一周以星期一还是星期天开始,0为星期天,1为星期一

 * @return array 数组array( "开始日期 ",  "结束日期");

 */

functiongetAWeekTimeSlot($gdate='',$weekStart= 0) {

 if(!$gdate){

 $gdate=date("Y-m-d");

 }

 $w=date("w",strtotime($gdate) );//取得一周的第几天,星期天开始0-6

 $dn=$w?$w-$weekStart: 6;//要减去的天数

 $st=date("Y-m-d",strtotime("$gdate  - ".$dn."  days ") );

 $en=date("Y-m-d",strtotime("$st  +6  days ") );

 returnarray($st,$en);//返回开始和结束日期

}

$timeSlot=getAWeekTimeSlot('2017-01-24',1);

echo"Week Start:{$timeSlot[0]}--->Week End: {$timeSlot[1]} ";

?>

运行结果如下:

Week Start:2017-01-23--->Week End: 2017-01-29

标签:[!--infotagslink--]

您可能感兴趣的文章: