分类目录归档:日志

Laravel 5.4: Specified key was too long error

Laravel 5.4 made a change to the default database character set, and it’s now utf8mb4 which includes support for storing emojis. This only affects new applications and as long as you are running MySQL v5.7.7 and higher you do not need to do anything.

For those running MariaDB or older versions of MySQL you may hit this error when trying to run migrations:

[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

As outlined in the Migrations guide to fix this all you have to do is edit your AppServiceProvider.php file and inside the boot method set a default string length:

After that everything should work as normal. If you enjoyed this post be sure and join the weekly Laravel newsletter and never miss out on new releases, framework tips, and new tutorials.

延长phpmyadmin登录时间的方法

编辑 config.inc.php 文件,使用 http 登录模式,只要浏览器不关闭就可以继续使用。

让 vmware 共享文件夹自动加载的办法

因为新电脑不能直接安装 linux ,只能使用 vmware 内安装虚拟机。安装 vmware 扩展工具,才能使用图形加速,共享目录等功能。

设置了 共享文件夹 后,每次开机后都要连接共享,如果要实现自动加载,在 /etc/fstab 中添加以下代码:

share_name 是主机共享出来的目录名,/mnt/hgfs/access 是虚拟机内的访问路径。

yarn 在 linux 中出现 pngquant 创建失败的问题怎么解决

在 linux 中使用 yarn 安装组件时,出现以下错误:

安装 libpng-dev 组件就可以了:

在 Ubuntu 上配置和优化 Apache

你可以在 Apache 上做各种各样的配置,但是主要的和最常见的配置将在下面做出解释。

检查 Apache 是否正在运行

默认情况下,Apache 设置为在机器启动时自动启动,因此你不必手动启用它。你可以使用以下命令检查它是否正在运行以及其他相关信息:

check if apache is running
check if apache is running

并且你可以检查你正在使用的版本:

一种更简单的检查方法时访问服务器的 IP 地址,如果你得到默认的 Apache 页面,那么一切都正常。

继续阅读

Laravel 中 validation 验证应该怎么设置中文信息提示

首先复制 resources\lang\en 目录下边的 validation.php到新建的文件夹zh-cn中,用下面代码替换之前的代码,在 attributes 中设置字段,最后设置config下的app.php中修改 'locale' => 'zh-cn'

js中判断对象是否为空的方法

判断一个对象是否为空对象,本文给出三种判断方法:

  1. 最常见的思路,for…in…遍历属性,为真则为“非空数组”;否则为“空数组”

  1. 通过JSON自带的stringify()方法来判断:

JSON.stringify() 方法用于将 JavaScript 值转换为 JSON 字符串。

这里需要注意为什么不用toString(),因为它返回的不是我们需要的。

  1. ES6新增的方法Object.keys():

Object.keys()方法会返回一个由一个给定对象的自身可枚举属性组成的数组。

如果我们的对象为空,他会返回一个空数组,如下:

我们可以依靠Object.keys()这个方法通过判断它的长度来知道它是否为空。

laravel 的 $request 改值操作

laravel 的表单验证

使用 request 注入验证时,获取路由中的参数:

字段唯一性同时排除指定ID验证:

匹配字段验证(如输入两次密码是否一致):