php中if怎么写,eval函数用法总结?
eval定义和用法
eval() 函数把字符串按照 PHP 代码来计算。
该字符串必须是合法的 PHP 代码,且必须以分号结尾。
如果没有在代码字符串中调用 return 语句,则返回 NULL。如果代码中存在解析错误,则 eval() 函数返回 false。
语法
eval(phpcode)
参数 描述
phpcode 必需。规定要计算的 PHP 代码。
提示和注释
注释:返回语句会立即终止对字符串的计算。
注释:该函数对于在数据库文本字段中供日后计算而进行的代码存储很有用。
例子
$string
$time
$str
echo$str
eval$str$str
echo$str
输出:
This is a $string $time morning!
This is a beautiful winter morning!
eval() 函数在CodeIgniter框架里也有用到。在 /system/database/DB.php 文件中,根据系统的配置动态的定义了一个类 CI_DB,具体代码片段如下:
if ( ! isset($active_record) OR $active_record == TRUE)
{
require_once(BASEPATH.'database/DB_active_rec.php');
if ( ! class_exists('CI_DB'))
{ // www.jbxue.com
eval('class CI_DB extends CI_DB_active_record { }');
}
}
else
{
if ( ! class_exists('CI_DB'))
{
eval('class CI_DB extends CI_DB_driver { }');
}
}
require_once(BASEPATH.'database/drivers/'.$params['dbdriver'].'/'.$params['dbdriver'].'_driver.php');
// Instantiate the DB adapter
$driver = 'CI_DB_'.$params['dbdriver'].'_driver';
$DB = new $driver($params);
本函式可将字符串之中的变量值代入,通常用在处理数据库的数据上。参数 code_str 为欲处理的字符串。值得注意的是待处理的字符串要符合 PHP 的字符串格式,同时在结尾处要有分号。使用本函式处理后的字符串会沿续到 PHP 程序结束。
如何将我的php脚本以守护进程的方式一直运行?
写好php脚本。建议定期检测内存占用,核心逻辑就不写了。这个跟业务有关。 if(memory_get_usage()>100*1024*1024){ exit(0);//大于100M内存退出程序,防止内存泄漏被系统杀死导致任务终端 } 假设该php文件的路径为/root/
run.php
打开终端 setsid php /root/run.php
> /dev/null & 编辑进程监控脚本,当进程不存在时,自动重启 /root/monitor.sh
#!/bin/bash alive=`ps aux|grep root\/run|grep -v grep|wc -l` if [ $alive -eq 0] then php /root/run.php
> /dev/null & fi 添加计划任务(每分钟检测一次) crontab -e * * * * * /root/monitor.sh
> /dev/null &php怎么连websocket?
那是因为,还没有握手成功,并且这个in的处理不是针对客户端的是针对服务端的这样修改在websocket.class.php添加这两行if(!$this->users[$k]['hand']){//没有握手进行握手$this->handshake($k,$buffer);$eventreturn=array('k'=>$k,'sign'=>$sign);$this->eventoutput('handsuccess',$eventreturn);}在server.php加一个elseif}elseif('handsuccess'==$type){//第一次握手成功$websocket->write($event['sign'],'welcome');}
php单例模式该如何实现?
PHP 单例模式的实现
单例设计模式为了解决在一个应用中只有一个实例【比如数据库实例】,并且禁止clone 复制
在PHP中可以继承单例模式来使用单例模式的特性,避免每次创建一个类都要创建一个对象
一般Sigleton类的实现 参考【https://stackoverflow.com/questions/3126130/extending-singletons-in-php】
但是上面参考链接其实也有一点问题 【然后我自己添加了一个回答:) 看到的点个赞奥】
————————————————
一般单例模式的实现
class Singleton
{
private static $instance;
private function __construct() {}
final protected function __clone() {} #不允许被重写并且会被子类继承
public static function getInstance()
{
if (! self::$instance instanceof self) {
self::$instance = new self();
}
return self::$instance;
}
}
// $s = new Singleton();#Fatal error: Call to private Singleton::__construct()
$s1 = Singleton::getInstance();
$s2 = Singleton::getInstance();
var_dump($s1,$s2); #object(Singleton)#1 (0) { } object(Singleton)#1 (0) { }
#测试出来两个实例是同一个对象
#测试clone 对象,会报错,说明真的只有一个对象存在于应用中
// $s2 = clone $s1; #Fatal error: Call to protected Singleton::__clone()
————————————————
上面的代码看上去没有任何问题但是如果我们想让单例模式可以被继承,让子类也具有单例模式的特性,就会出错
Java 中构造函数是私有的不能被继承,默认情况下Java的子类会在构造函数中调用父类的无参数构造方法
PHP 可以继承,哪怕父类是私有构造器
下面是测试 PHP代码
class A extends Singleton
{
}
$a = new A();#Fatal error: Call to private Singleton::__construct() 调用了父类的private 的构造函数
#如果子类中没有构造函数就使用父类的构造方法,如果有自己的构造方法,就不会自动调用父类的构造方法,需要显式调用 parent::__construct();
#所以还是需要调用 静态方法获得实例
$a = A::getInstance();
var_dump($a);#object(Singleton)#1 (0) { } #出毛病了,实例化之后还是Singleton对象
#解决方法使用PHP动态绑定,关键字static 除了静态方法之外下面罗列动态绑定的特性
有三个特性
1) 在非静态环境下,所调用的类即为该对象实例所属的类【就代表了这个实例】
2) 由于 $this-> 会在同一作用范围内尝试调用私有方法,而 static:: 则可能给出不同结果。 [$this 可以调用同一范围的私有变量方法 static 相当于类名 比如说 A::$instance,就不行]
如果 static::function 或者static::$instance 调用的是同一个类里面的方法不管是不是private 都ok 但是如果是不同类的 就会报错
猜测性小结: 只要static 调用的元素不在同一个类里面 private 就会报错
3) 另一个区别是 static:: 只能用于静态属性 不是方法【方法都可以调用)
所以最后单例模式可以写成如下格式
需要注意的 使用 self:: 或者 __CLASS__ 对当前类的静态引用,取决于定义当前方法所在的类
#定义一个抽象类 被其他类继承
abstract class Singleton
{
protected static $instance; // 这里必须是protected 如果要让子类继承 其次protected才能被 static 调用
private function __construct(){}
final protected function __clone(){}
public static function getInstance()
{
if (! static::$instance instanceof static) {
static::$instance = new static();
}
return static::$instance
$a = A::getInstance();
$b = B::getInstance();
$c = B::getInstance();
$d = A::getInstance();
$e = A::getInstance();
var_dump($a,$b,$c,$d,$e);
#object(A)#1 (0) { }
#object(B)#2 (0) { }
#object(B)#2 (0) { }
#object(A)#1 (0) { }
#object(A)#1 (0) { }
————————————————
小结:
public static function getInstance()
{
if (! static::$instance instanceof static) {
static::$instance = new static();
}
return static::$instance;
}
# 上面方法中必须使用static::$instance 不能使用self::$instance 的原因是子类动态调用的是子类的静态属性
# 静态属性必须是 protected 原因是 动态调用关键字static 调动不是在一个原生类里面的private的属性时相当于直接 类名::$instance
# 子类必须重定义 protected static $instance; 否则使用的是父类的静态属性。
大家还有不懂得可以私信给我解答
如何写出难被pj的域名授权和站点限制呢?
域名授权代码可封装进函数,或者进行加密,对于常用的PHP加密形式,都有其pj的方法,比如ZendGuard、ionCube等,如果授权的域名较多,可以在项目中增加域名字段,将域名写入数据库再进行读取和校验。
工具/原料电脑PHP编程器方法/步骤1、在线校验域名授权的方法,客户端代码:
1)写入客户端代码(php代码):
PHP
<?php
//获取不带端口号的域名前缀$servername = trim($_SERVER['SERVER_NAME']);
//获取服务端授权文件校验
$verifyurl = file_get_contents('http://www.abc.com/zb_users/upload/copyright.php?domain='.$servername);
if(!empty($verifyurl)){
echo "已授权!"; //授权成功
}else{
die("未授权!"); //授权失败
}
?>
2、写入服务端代码(php代码)
<?php
//获取域名$domain = $_GET['domain'];
//授权域名列表
$Array = array('127.0.0.1','localhost');
//校验结果echo in_array($domain, $Array) ? 'yes' : '';
?>
2、独立校验域名授权的方法:
(PHP代码)
<?php
function allow_domain(){
$is_allow=false;
//获取不带端口号的域名前缀
$servername=trim($_SERVER['SERVER_NAME']);
//授权域名列表
$Array=array("localhost","127.0.0.1");
//遍历数组
foreach($Array as $value){
$value=trim($value);
$domain=explode($value,$servername);
if(count($domain)>1){
$is_allow=true;
break;
} }
if(!$is_allow){
die("域名未授权!"); //授权失败
}else{
echo "域名已授权!"; //授权成功
}
}
allow_domain();
?>