@52fhy
2016-02-28T10:12:35.000000Z
字数 6359
阅读 397
PHP
php加载文件方式:
1、include,include_once,requice,requice_one常规加载
2、__autoload()
3、spl_autoload_register()
假设我们有一个类文件A.php,里面定义了一个名字为A的类:
<?php
class A {
public function __construct() {
echo 'Got it.';
}
}
然后我们有一个index.php需要用到这个类A,常规的写法就是
<?php
require('A.php');
$a = new A();
但是有一个问题就是,假如我们的index.php需要包含的不只是类A,而是需要很多类,这样子就必须写很多行require语句,有时候也会让人觉得不爽。
不过在php5之后的版本,我们就不再需要这样做了。
在php5中,试图使用尚未定义的类时会自动调用__autoload函数,所以我们可以通过编写__autoload函数来让php自动加载类,而不必写一个长长的包含文件列表。
例如在上面那个例子中,index.php可以这样写:
<?php
function __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 ]]] )
我们继续改写上面那个例子:
<?php
function loader($class){
$file = $class . '.php';
if (is_file($file)) {
require_once($file);
}
}
spl_autoload_register('loader');
$a = new A();
或者直接使用匿名函数:
<?php
spl_autoload_register(function($file){
$file = $class . '.php';
if (is_file($file)) {
require_once($file);
}
});
$a = new A();
这样子也是可以正常运行的,这时候php在寻找类的时候就没有调用__autoload而是调用我们自己定义的函数loader了。同样的道理,下面这种写法也是可以的:
<?php
class 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
<?php
define('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中新增) = |
示例:
<?php
echo __FILE__;//D:\phpsetup\www\htdocs\test\test.php
echo __DIR__;//D:\phpsetup\www\htdocs\test
echo __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.php
echo $_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` ;