还没安装 Composer 吗?请往下看如何安装 Composer 。 镜像用法 有两种方式启用本镜像服务: 系统全局配置: 即将配置信息添加到 Composer 的全局配置文件 config.json 中。见“方法一” 单个项目配置: 将配置信息添加到某个项目的 composer.json 文件中。见“方法二” 方法一: 修改 composer 的全局配置文件(推荐方式) 打开命令行窗口(windows用户)或控制台(Linux、Mac 用户)并执行如下命令: 复制
1 2 |
composer config -g repo.packagist composer https://packagist.phpcomposer.com |
方法二: 修改当前项目的 composer.json 配置文件: 打开命令行窗口(windows用户)或控制台(Linux、Mac 用户),进入你的项目的根目录(也就是 composer.json 文件所在目录),执行如下命令: 复制
1 2 |
composer config repo.packagist composer https://packagist.phpcomposer.com |
上述命令将会在当前项目中的 composer.json 文件的末尾自动添加镜像的配置信息(你也可以自己手工添加): 复制
1 2 3 4 5 6 7 |
"repositories": { "packagist": { "type": "composer", "url": "https://packagist.phpcomposer.com" } } |
以 laravel 项目的 composer.json 配置文件为例,执行上述命令后如下所示(注意最后几行): 复制
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
{ "name": "laravel/laravel", "description": "The Laravel Framework.", "keywords": ["framework", "laravel"], "license": "MIT", "type": "project", "require": { "php": ">=5.5.9", "laravel/framework": "5.2.*" }, "config": { "preferred-install": "dist" }, "repositories": { "packagist": { "type": "composer", "url": "https://packagist.phpcomposer.com" } } } |
OK,一切搞定!试一下 composer install 来体验飞一般的速度吧! 镜像原理: 一般情况下,安装包的数据(主要是 zip 文件)一般是从 github.com 上下载的,安装包的元数据是从 packagist.org 上下载的。 然而,由于众所周知的原因,国外的网站连接速度很慢,并且随时可能被“墙”甚至“不存在”。 “Packagist 中国全量镜像”所做的就是缓存所有安装包和元数据到国内的机房并通过国内的 CDN 进行加速,这样就不必再去向国外的网站发起请求,从而达到加速 composer install以及 composer update 的过程,并且更加快速、稳定。因此,即使 packagist.org、github.com 发生故障(主要是连接速度太慢和被墙),你仍然可以下载、更新安装包。 from:https://pkg.phpcomposer.com
View Detailspost提交数据时候显示如下:
1 2 3 |
The page <span class="hljs-keyword">has</span> expired due <span class="hljs-keyword">to</span> inactivity. Please refresh <span class="hljs-keyword">and</span> <span class="hljs-keyword">try</span> again |
这是由于在laravel框架中有此要求:任何指向 web 中 POST, PUT 或 DELETE 路由的 HTML 表单请求都应该包含一个 CSRF 令牌,否则,这个请求将会被拒绝。 eg:
1 2 3 4 5 6 |
<form method=<span class="hljs-string">"POST"</span> action=<span class="hljs-string">"/profile"</span>> {{ csrf_field() }} <span class="hljs-keyword">...</span> </form> |
from:http://blog.csdn.net/wuyoulv/article/details/78139632
View Detailserror_reporting的14个级别: E_ALL 所有错误和警告 E_COMPILE_ERROR 致命的编译时错误 E_COMPILE_WARNING 编译时警告 E_CORE_ERROR PHP开始启动时发生的致命错误 E_CORE_WARNING PHP开始启动时发生的警告 E_ERROR 致命的运行时错误 E_NOTICE 运行时注意消息 E_PARSE 编译时解析错误 E_RECOVERABLE_ERROR E_STRICT PHP版本可移植性建议(PHP5.0中引入) E_USER_ERROR 用户导致的错误 E_USER_NOTICE 用户导致的注意消息 E_USER_WARNING 用户导致的警告 E_WARNING 运行时警告
View Details=================自动加载================== 实现自动加载最简单的方式就是使用 __autoload 魔术方法。当需要使用的类没有被引入时,这个函数会在PHP报错前被触发,未定义的类名会被当作参数传入。至于函数具体的逻辑,这需要用户自己去实现。 首先创建一个 autoload.php 来做一个简单的测试:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
// 类未定义时,系统自动调用 function __autoload($class) { /* 具体处理逻辑 */ echo $class;// 简单的输出未定义的类名 } new HelloWorld(); /** * 输出 HelloWorld 与报错信息 * Fatal error: Class 'HelloWorld' not found */ |
通过这个简单的例子可以发现,在类的实例化过程中,系统所做的工作大致是这样的:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
/* 模拟系统实例化过程 */ function instance($class) { // 如果类存在则返回其实例 if (class_exists($class, false)) { return new $class(); } // 查看 autoload 函数是否被用户定义 if (function_exists('__autoload')) { __autoload($class); // 最后一次引入的机会 } // 再次检查类是否存在 if (class_exists($class, false)) { return new $class(); } else { // 系统:我实在没辙了 throw new Exception('Class Not Found'); } } |
明白了 __autoload 函数的工作原理之后,那就让我们来用它去实现自动加载。 首先创建一个类文件(建议文件名与类名一致),代码如下:
1 2 3 4 5 6 7 8 |
class [ClassName] { // 对象实例化时输出当前类名 function __construct() { echo '<h1>' . __CLASS__ . '</h1>'; } } |
(我这里创建了一个 HelloWorld 类用作演示)接下来我们就要定义 __autoload 的具体逻辑,使它能够实现自动加载:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
function __autoload($class) { // 根据类名确定文件名 $file = $class . '.php'; if (file_exists($file)) { include $file; // 引入PHP文件 } } new HelloWorld(); /** * 输出 <h1>HelloWorld</h1> */ |
=================命名空间================== 其实命名空间并不是什么新生事物,很多语言(例如C++)早都支持这个特性了。只不过 PHP 起步比较晚,直到 PHP 5.3 之后才支持。 命名空间简而言之就是一种标识,它的主要目的是解决命名冲突的问题。 就像在日常生活中,有很多姓名相同的人,如何区分这些人呢?那就需要加上一些额外的标识。 把工作单位当成标识似乎不错,这样就不用担心 “撞名” 的尴尬了。 这里我们来做一个小任务,去介绍百度的CEO李彦宏:
1 2 3 4 5 6 7 8 9 |
namespace 百度; class 李彦宏 { function __construct() { echo '百度创始人'; } } |
↑ 这就是李彦宏的基本资料了,namespace 是他的单位标识,class 是他的姓名。 命名空间通过关键字 namespace 来声明。如果一个文件中包含命名空间,它必须在其它所有代码之前声明命名空间。
1 2 |
new 百度\李彦宏(); // 限定类名 new \百度\李彦宏(); // 完全限定类名 |
↑ 在一般情况下,无论是向别人介绍 "百度 李彦宏" 还是 "百度公司 李彦宏",他们都能够明白。 在当前命名空间没有声明的情况下,限定类名和完全限定类名是等价的。因为如果不指定空间,则默认为全局(\)。
1 2 3 4 |
namespace 谷歌; new 百度\李彦宏(); // 谷歌\百度\李彦宏(实际结果) new \百度\李彦宏(); // 百度\李彦宏(实际结果) |
↑ 如果你在谷歌公司向他们的员工介绍李彦宏,一定要指明是 "百度公司的李彦宏"。否则他会认为百度是谷歌的一个部门,而李彦宏只是其中的一位员工而已。 这个例子展示了在命名空间下,使用限定类名和完全限定类名的区别。(完全限定类名 = 当前命名空间 + 限定类名)
1 2 3 4 5 6 7 8 9 10 |
/* 导入命名空间 */ use 百度\李彦宏; new 李彦宏(); // 百度\李彦宏(实际结果) /* 设置别名 */ use 百度\李彦宏 AS CEO; new CEO(); // 百度\李彦宏(实际结果) /* 任何情况 */ new \百度\李彦宏();// 百度\李彦宏(实际结果) |
↑ 第一种情况是别人已经认识李彦宏了,你只需要直接说名字,他就能知道你指的是谁。第二种情况是李彦宏就是他们的CEO,你直接说CEO,他可以立刻反应过来。 使用命名空间只是让类名有了前缀,不容易发生冲突,系统仍然不会进行自动导入。 如果不引入文件,系统会在抛出 "Class Not Found" 错误之前触发 __autoload 函数,并将限定类名传入作为参数。 所以上面的例子都是基于你已经将相关文件手动引入的情况下实现的,否则系统会抛出 " Class '百度\李彦宏' not found"。 =================spl_autoload================== 接下来让我们要在含有命名空间的情况下去实现自动加载。这里我们使用 spl_autoload_register() 函数来实现,这需要你的 PHP 版本号大于 5.12。 spl_autoload_register 函数的功能就是把传入的函数(参数可以为回调函数或函数名称形式)注册到 SPL […]
View Details胖大海(拉丁学名:SEMEN STERCULIAE LYCHNOPHORAE),别名 :大海、大海子、大洞果、大发梧桐科植物胖大海Sterculia lychnophora Hance 的干燥成熟种子。 呈纺锤形或椭圆形,长2~3cm,直径1~1.5cm。先端钝圆,基部略尖而歪,具浅色的圆形种脐,表面棕色或暗棕色,微有光泽,具不规则的干缩皱纹。外层果皮极薄,质脆,易脱落。中层果皮较厚,黑褐色,质松易碎,遇水膨胀成海绵状。断面可见散在的树脂状小点。内层果皮可与中层果皮剥离,稍革质,内有2片肥厚胚乳,广卵形;子叶2枚,菲薄,紧贴于胚乳内侧,与胚乳等大。气微,味淡,嚼之有黏性。 产于泰国、柬埔寨、马来西亚等国。4~6月果实成熟开裂时,采收种子,晒干用。多用于泡茶,可以起到降血压、润喉化痰的作用。 from:https://baike.baidu.com/item/胖大海/23420?fr=aladdin
View Detailsinclude与require有两点重要的区别: 1.无论require的位置如何,指定文件都将包含到出现require的脚本中。例如,即使require放在计算为假的if语句中,依然会包含指定文件。 2.require出错时,脚本将停止执行,而在使用include的情况下,脚本将继续执行。一种可能的错误是require语句不正确地引用了目标路径。
View Details\n 换行符 \r 回车 \t 水平制表符 \\ 反斜杠 \$ 美元符 \" 双引号 \[0-7]{1,3} 八进制记法 \x[0-9A-Fa-f]{1,2} 十六进制记法
View Details
1 2 3 4 5 6 |
$recipe = "spaghetti"; $$recipe = " & meatballs"; echo $recipe, $spaghetti; // spaghetti & meatballs echo "<br>"; echo $recipe, ${$recipe}; // spaghetti & meatballs |
View Details
首先来说一下为什么使用$_SERVER['HTTP_REFERER']会出现这个报错的原因。 我们大家都知道$_SERVER['HTTP_REFERER']用来获取当前页面的上一个页面地址,只有上一个页面存在,$_SERVER['HTTP_REFERER']才会被设置,如果没有上一个页面(比如用户直接在浏览器上输入当前页面地址打开页面,这时候就没有上一个页面了),$_SERVER['HTTP_REFERER']变量不会被设置。所以在使用这个变量时会报错。 解决办法: 1、关闭掉 NOTICE错误的警告
1 |
error_reporting(E_ALL ^ E_NOTICE); |
2、使用isset判断变量是否存在或设置
1 2 3 |
if(isset($_SERVER['HTTP_REFERER'])) { echo $_SERVER['HTTP_REFERER']; } |
3、在变量前面加上@
1 |
@$_SERVER['HTTP_REFERER'] |
小编在这里推荐大家使用第二种方法,因为第二种方法是从根本上解决了问题,第一种和第三种只是不让错误输出在浏览器上。 from:http://www.manongjc.com/article/1114.html
View Details