@52fhy
        
        2016-02-28T02:12:35.000000Z
        字数 6359
        阅读 489
    PHP
php加载文件方式: 
1、include,include_once,requice,requice_one常规加载 
2、__autoload() 
3、spl_autoload_register()
假设我们有一个类文件A.php,里面定义了一个名字为A的类:
<?phpclass A {public function __construct() {echo 'Got it.';}}
然后我们有一个index.php需要用到这个类A,常规的写法就是
<?phprequire('A.php');$a = new A();
但是有一个问题就是,假如我们的index.php需要包含的不只是类A,而是需要很多类,这样子就必须写很多行require语句,有时候也会让人觉得不爽。
不过在php5之后的版本,我们就不再需要这样做了。 
在php5中,试图使用尚未定义的类时会自动调用__autoload函数,所以我们可以通过编写__autoload函数来让php自动加载类,而不必写一个长长的包含文件列表。
例如在上面那个例子中,index.php可以这样写:
<?phpfunction __autoload($class){$file = $class . '.php';if (is_file($file)) {require_once($file);}}$a = new A();
当然上面只是最简单的示范,__autoload只是去include_path寻找类文件并加载,我们可以根据自己的需要定义__autoload加载类的规则。注意:由于__autoload()是个函数,只能存在一次。
但现在问题来了,如果在一个系统的实现中,如果需要使用很多其它的类库,这些类库可能是由不同的开发人员编写的,其类名与实际的磁盘文件的映射规则不尽相同。这时如果要实现类库文件的自动加载,就必须在__autoload()函数中将所有的映射规则全部实现,这样的话__autoload()函数有可能 会非常复杂,甚至无法实现。最后可能会导致__autoload()函数十分臃肿,这时即便能够实现,也会给将来的维护和系统效率带来很大的负面影响。在这种情况下,难道就没有更简单清晰的解决办法了吧?答案当然是:NO!
spl_autoload_register() 满足了此类需求。 它实际上创建了 autoload 函数的队列,按定义时的顺序逐个执行。相比之下, __autoload() 只可以定义一次。
bool spl_autoload_register ([ callable $autoload_function [, bool $throw = true [, bool $prepend = false ]]] )
我们继续改写上面那个例子:
<?phpfunction loader($class){$file = $class . '.php';if (is_file($file)) {require_once($file);}}spl_autoload_register('loader');$a = new A();
或者直接使用匿名函数:
<?phpspl_autoload_register(function($file){$file = $class . '.php';if (is_file($file)) {require_once($file);}});$a = new A();
这样子也是可以正常运行的,这时候php在寻找类的时候就没有调用__autoload而是调用我们自己定义的函数loader了。同样的道理,下面这种写法也是可以的:
<?phpclass Loader {public static function loadClass($class){$file = $class . '.php';if (is_file($file)) {require_once($file);}}}spl_autoload_register(array('Loader', 'loadClass'));//spl_autoload_register(array(__CLASS__, 'loadClass'));//spl_autoload_register(array($this, 'loadClass'));$a = new A();
autoload.php
<?phpdefine('SDK_PATH', __DIR__);require_once SDK_PATH . '/common/functions.php';require_once SDK_PATH . '/common/config.php';spl_autoload_register(function ($class) {if (false !== stripos($class, 'YJC\Wechat')) {require_once __DIR__ . '/' . str_replace('\\', DIRECTORY_SEPARATOR, substr($class, 10)) . '.php';}});/*function __autoload($class){if (false !== stripos($class, 'YJC\Wechat')) {require_once __DIR__ . '/' . str_replace('\\', DIRECTORY_SEPARATOR, substr($class, 10)) . '.php';}}*/
建议入口文件里养成定义绝对地址SDK_PATH的习惯,这样require不会出错。
示例2:
define("BASE_PATH", realpath(dirname(__FILE__) . '/../../'));define("CONF_PATH", BASE_PATH . '/config/');define("APPLICATION_PATH", BASE_PATH . '/src/application/');define("APP_CONTROLLOR", APPLICATION_PATH . 'controller/');define("APP_DAO", APPLICATION_PATH . 'dao/');define("APP_ENTITY", APPLICATION_PATH . 'entity/');define("APP_LIBS", APPLICATION_PATH . 'libs/');define("APP_MODEL", APPLICATION_PATH . 'model/');spl_autoload_register('auto_load_class');function auto_load_class($class){if(strpos($class,'DaConf') === 0){$file = CONF_PATH . $class;}else if(strpos($class,'Controller') > 0){$file = APP_CONTROLLOR . $class;}else if(strpos($class,'Dao') > 0){$file = APP_DAO . $class;}else if(strpos($class,'Model') > 0){$file = APP_MODEL . $class;}else{if(file_exists(APP_ENTITY . $class . '.php')){$file = APP_ENTITY . $class;}else{$file = APP_LIBS . $class;}}$file = $file . '.php';if(file_exists($file)){require_once($file);}else{throw new Exception("Class $class auto load fail, please check the file $file");}}
| 名称 | 说明 | 
|---|---|
__LINE__ | 
 文件中的当前行号。 | 
__FILE__ | 
 文件的完整路径和文件名。如果用在被包含文件中,则返回被包含的文件名。自 PHP 4.0.2 起, __FILE__总是包含一个绝对路径(如果是符号连接,则是解析后的绝对路径),而在此之前的版本有时会包含一个相对路径。 | 
__DIR__ | 
 文件所在的目录。如果用在被包括文件中,则返回被包括的文件所在的目录。它等价于 dirname(__FILE__)。除非是根目录,否则目录中名不包括末尾的斜杠。(PHP 5.3.0中新增) = | 
示例:
<?phpecho __FILE__;//D:\phpsetup\www\htdocs\test\test.phpecho __DIR__;//D:\phpsetup\www\htdocs\testecho __LINE__;//4
$_SERVER['HTTP_REFERER'] 可以获取当前链接的上一个连接的来源地址,即链接到当前页面的前一页面的 URL 地址,可以做到防盗链作用,只有点击超链接(即<a href=...>) 打开的页面才有HTTP_REFERER环境变量, 其它如 window.open()、 window.location=...、window.showModelessDialog()等打开的窗口都没有HTTP_REFERER环境变量。
示例:
if(empty($_SERVER['HTTP_REFERER'])){exit('error');//来源地址为空,禁止调用}
$_SERVER['SERVER_NAME'] 获取当前页面主机名
示例:
//url:http://localhost/test.phpecho $_SERVER['SERVER_NAME'];//输出:localhost
<?//获取当前的域名:echo $_SERVER['SERVER_NAME'];//获取来源网址,即点击来到本页的上页网址echo $_SERVER["HTTP_REFERER"];$_SERVER['REQUEST_URI'];//获取当前域名的后缀$_SERVER['HTTP_HOST'];//获取当前域名dirname(__FILE__);//获取当前文件的物理路径dirname(__FILE__)."/../";//获取当前文件的上一级物理路径?>
应用示例:
/*** 获取当前URL** @return string*/function current(){$protocol = (!empty($_SERVER['HTTPS'])&& $_SERVER['HTTPS'] !== 'off'|| $_SERVER['SERVER_PORT'] === 443) ? 'https://' : 'http://';if(isset($_SERVER['HTTP_X_FORWARDED_HOST'])){$host = $_SERVER['HTTP_X_FORWARDED_HOST'];}else{$host = $_SERVER['HTTP_HOST'];}return $protocol.$host.$_SERVER['REQUEST_URI'];}
1、parse_str
格式:array parse_str(url,arr)
parse_str就是将一个url ?后面的参数转换成一个数组
2、http_build_query就是将一个数组转换成url ?后面的参数字符串,会自动进行urlencode处理
格式:string http_build_query(array formdata [,string numeric_prefix])
后面的给数组中没有指定键或者键为数字的加下标
使用jquery获取radio的值,最重要的是掌握jquery选择器的使用,在一个表单中我们通常是要获取被选中的那个radio项的值,所以要加checked来筛选,比如有以下的一些radio项:
<input type="radio" name="testradio" value="获取radio的值" />获取radio的值<input type="radio" name="testradio" value="获取checkbox的值" />获取checkbox的值<input type="radio" name="testradio" value="获取select的值" />获取select的值
要想获取某个radio的值有以下的几种方法,直接给出代码:
$('input[name="testradio"]:checked').val();$('input:radio:checked').val();$('input[@name="testradio"][checked]');$('input[name="testradio"]').filter(':checked');
差不多挺全的了,如果我们要遍历name为testradio的所有radio呢,代码如下:
$('input[name="testradio"]').each(function(){alert(this.value);});
如果要取具体某个radio的值,比如第二个radio的值,这样写:
$('input[name="testradio"]:eq(1)').val();
ini_set('display_errors', '1');error_reporting(E_ALL ^ E_NOTICE);
date_default_timezone_set("PRC");
@ini_set('memory_limit', '512M');@ini_set("max_execution_time", 0);//默认30秒
1、如果是整个表复制表达如下:
insert into table1 select*from table2
2、如果是有选择性的复制数据表达如下:
insert into table1(column1,column2,column3...) select column1,column2,colunm3... from table2
3、一个数据库中的表中的数据复制到另一个数据库中的一个表,使用方法如下:
insert into 数据库A.dbo.table1(col1,col2,col3...) select col1,col2,col3... from 数据库B.dbo.table2
ALTER TABLE `company`ADD `city_id` INT( 11 ) UNSIGNED NOT NULL DEFAULT '0' COMMENT '城市id' AFTER `type` ,ADD `city` VARCHAR( 25 ) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '城市' AFTER `city_id` ;