laravel 5.4 改变了默认的数据库字符集,现在utf8mb4包括存储emojis支持。如果你运行MySQL v5.7.7或者更高版本,则不需要做任何事情。 当你试着在一些MariaDB或者一些老版本的的MySQL上运行 migrations 命令时,你可能会碰到下面这个错误:
1 2 3 4 5 |
[Illuminate\Database\QueryException] SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes (SQL: alter table users add unique users_email_unique(email)) [PDOException] SQLSTATE[42000]: Syntax error or access violation: 1071 Specified key was too long; max key length is 767 bytes |
我们可以在 AppServiceProvider.php 文件里的 boot 方法里设置一个默认值:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 |
<?php namespace App\Providers; use Illuminate\Support\ServiceProvider; use Illuminate\Support\Facades\Schema; class AppServiceProvider extends ServiceProvider { /** * Bootstrap any application services. * * @return void */ public function boot() { Schema::defaultStringLength(191); } /** * Register any application services. * * @return void */ public function register() { // } } |
from:https://www.cnblogs.com/betx/p/6544090.html
View Details1、首先打开php.ini文件,修改post_max_size设定POST数据所允许的最大限制值,php中默认post_max_size=2M;在php.in文件中按Ctrl+F,然后输入post_max_size,找到post_max_size将其改为自己需要上传限制文件的大小,比如改为post_max_size=300M; 2、修改完之后并不能上传较大的文件,则继续修改php.ini中的参数upload_max_filesize,其表示为上传文件的最大值。默认值upload_max_filesize=8M,修改为upload_max_filesize=300M; 3、如果上传仍然有问题,则继续修改。可能跟上传时间有关系。找到php.ini文件中的max_execution_time,默认值max_execution_time=30,其意思就是该页面最长执行的时间为30s,30s之后则上传停止,从而导致上传失败。修改为max_execution_time=0;0表示没有限制。 附: 另外要注意的是,post_max_size 应该大于upload_max_filesize 。 from:https://blog.csdn.net/rision666/article/details/51590803
View Details测试文件 test.php <?php echo "hello world."; ?> 1.加密方法: <?php /* eval() 函数把字符串按照 PHP 代码来计算。该字符串必须是合法的 PHP 代码,且必须以分号结尾。 strtr() 字符替换 把字符串中的字符 "ia" 替换为 "eo":strtr("Hilla Warld","ia","eo"); */ function T_rndstr($length = "") { //返回随机字符串 $str = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"; if ($length == "") { return str_shuffle($str); } else { return substr(str_shuffle($str), -$length); } } $T_k1 = T_rndstr(); //随机密匙1 $T_k2 = T_rndstr(); //随机密匙2 $vstr = file_get_contents("./test.php"); //要加密的文件 $v1 = base64_encode($vstr); $c = strtr($v1, $T_k1, $T_k2); //根据密匙替换对应字符 $c = $T_k1 . $T_k2 . $c; //$qn变量功能下面会讲解 $isqs = 3; if ($isqs == "1") { // 1 取随机字符串为变量名 […]
View Details方法一、简单安装(通过yum) 1.安装epel-release rpm -ivh http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm 2.安装PHP7的rpm源 rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm 3.安装PHP7 yum install php70w 方法二、编译安装 1.下载php7 wget -O php7.tar.gz http://cn2.php.net/get/php-7.1.1.tar.gz/from/this/mirror 2.解压php7 tar -xvf php7.tar.gz 3.进入php目录 cd php-7.0.4 4.安装依赖包 # 直接复制下面一行(不包括本行) yum install libxml2 libxml2-devel openssl openssl-devel bzip2 bzip2-devel libcurl libcurl-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel gmp gmp-devel libmcrypt libmcrypt-devel readline readline-devel libxslt libxslt-devel 5.编译配置(如果出现错误,基本都是上一步的依赖文件没有安装所致) 嫌麻烦的可以从这一步起参考PHP官方安装说明:http://php.net/manual/zh/install.unix.nginx.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
./configure \ --prefix=/usr/local/php \ --with-config-file-path=/etc \ --enable-fpm \ --with-fpm-user=nginx \ --with-fpm-group=nginx \ --enable-inline-optimization \ --disable-debug \ --disable-rpath \ --enable-shared \ --enable-soap \ --with-libxml-dir \ --with-xmlrpc \ --with-openssl \ --with-mcrypt \ --with-mhash \ --with-pcre-regex \ --with-sqlite3 \ --with-zlib \ --enable-bcmath \ --with-iconv \ --with-bz2 \ --enable-calendar \ --with-curl \ --with-cdb \ --enable-dom \ --enable-exif \ --enable-fileinfo \ --enable-filter \ --with-pcre-dir \ --enable-ftp \ --with-gd \ --with-openssl-dir \ --with-jpeg-dir \ --with-png-dir \ --with-zlib-dir \ --with-freetype-dir \ --enable-gd-native-ttf \ --enable-gd-jis-conv \ --with-gettext \ --with-gmp \ --with-mhash \ --enable-json \ --enable-mbstring \ --enable-mbregex \ --enable-mbregex-backtrack \ --with-libmbfl \ --with-onig \ --enable-pdo \ --with-mysqli=mysqlnd \ --with-pdo-mysql=mysqlnd \ --with-zlib-dir \ --with-pdo-sqlite \ --with-readline \ --enable-session \ --enable-shmop \ --enable-simplexml \ --enable-sockets \ --enable-sysvmsg \ --enable-sysvsem \ --enable-sysvshm \ --enable-wddx \ --with-libxml-dir \ --with-xsl \ --enable-zip \ --enable-mysqlnd-compression-support \ --with-pear \ --enable-opcache |
6.正式安装 make && make install 7.配置环境变量 vi /etc/profile 在末尾追加 PATH=$PATH:/usr/local/php/bin export PATH 执行命令使得改动立即生效 source /etc/profile 8.配置php-fpm
1 2 3 4 5 |
cp php.ini-production /etc/php.ini cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf cp /usr/local/php/etc/php-fpm.d/www.conf.default /usr/local/php/etc/php-fpm.d/www.conf cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm chmod +x /etc/init.d/php-fpm |
9.启动php-fpm /etc/init.d/php-fpm start 以上所述是小编给大家介绍的Centos7 安装 PHP7最新版的详细教程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持! […]
View Details还没安装 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 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