Laravel Model常用属性


$table = ‘应当操作的表名’;
$primaryKey= ‘主键’;
$timestamps = false;//是否创建crearte_at与update_at字段
$fillable = [ ‘可批量填充的字段’];
$guarded= [ ‘不可批量填充的字段’];
$hidden = [ ‘模型转换为数组时应当隐藏的字段’];
$visable = [‘模型转换为数组时应当显示的字段’];
$appends = [ ‘模型转换为数组时应当追加的虚拟字段’ // 例如访问器];
$with = [ ‘应预加载的关联关系’,];
$attributes= [ ‘字段名’ => ‘字段默认值’];
$casts= [‘字段名’ => ‘数据类型转换的目标类型’];
$dates = [ ‘应当被转换为日期时间的字段’];
$touches = [ ‘模型更新时应当一并更新的关联关系’];
$dispatchesEvents = [ ‘模型事件’=>’自定义事件’(设置模型事件与自定义事件的映射)];

Beanbun 加 Cookie

$cookieJar = \GuzzleHttp\Cookie\CookieJar::fromArray([‘PHPSESSION’ => ‘abc’], ‘.test.com’);
$beanbun->setDownloader(null, [‘cookies’ => $cookieJar]);

vagrant up提示”Couldn’t open file /path/to/base”的错误解决方法

在vagrant使用命令vagrant up启动虚拟机时

出错:

原因分析:

在使用vagrant init命令初始化配置文件的时候未指定虚拟机名称,也就是命令:vagrant box add BoxName boxpath中的BoxName。

解决办法:

1.再来一遍,重新生成Vagrantfile配置文件

2.修改Vagrantfile文件中config.vm.box参数:

将base修改为你的虚拟机名称。

Navicat Premium 15 激活教程

【转自简书:https://www.jianshu.com/p/aca31d8f4c5b,收藏一下】

最近Navicat Premium 15发布了, 让我们来看看如何安装永久激活版,安装软件包和注册机见文末
阅读顺序

  • Navicat Premium 15 安装
  • Navicat Premium 15激活教程

如果15装不了,就装里面的12,步骤都是一样的!

一、Navicat Premium 15 安装

进入安装页面直接疯狂点下一步直到安装成功即可,当然你可以自己选择安装目录

二.Navicat Premium 15激活教程

使用注册机前一定要先退出所有杀毒软件(包括Windows Defender),再打开注册机,否则会一直报错哦!

 

打开注册机(Navicat Keygen Patch v5.6.0 DFoX.exe)完成以下配置:

1.Patch

 

如果是Navicat 12就选 v12,其他选项和步骤不变!!

在 1) Patch 中选择Backup、Host、Navicat v15这三个,默认也是选择了这三个;勾选这三个后点击Patch;
点击Patch按钮并找到Navicat Premium 15的安装目录的navicat.exe文件

【注:本人默认安装navicat的路径,所以并未看到这个界面,不影响后续的激活】

出现以下提示说明Patch成功了,但别高兴的太早,这还只是第一步

2.License. Product and Language
2)License里选中Enterprise、在Produce里选择Premium、在Languages里选择Simplified Chinese(简体中文)

3.Resale License
3)Resale License保持默认选择即可

 

4.Keygen / Offline Activation
点击Generate按钮就会生成一个许可证秘钥,将许可证秘钥复制后就打开Navicat Premium 15

 

点击【注册】前,断网!!!

点击【注册】前,断网!!!

也就是让你拔网线!!!

然后打开Navicat Premium 15,一个是试用14天,一个是注册,这里我们点击注册

粘贴刚刚注册机生成的许可证秘钥,然后点击激活

点击激活后会提示因为激活服务器暂时不可用,所以你的许可证未能激活,我们就选择手动激活。

点击手动激活后会生成一个请求码

复制请求码到注册机中的Request Code里面,之后点击Activation Code下面的Generate按钮就会生成一个激活码

生成激活码:

将激活码复制到Navicat Premium 15中的激活码框框里,点击激活即可完成激活

成功激活
 

Apache:: No space left on device: Couldn’t create accept lock

解决方案:
demo$ for semid in `ipcs -s | grep demo | cut -f2 -d" "`;
> do ipcrm -s $semid; done

最全的常用正则表达式大全——包括校验数字、字符、一些特殊的需求等等

很多不太懂正则的朋友,在遇到需要用正则校验数据时,往往是在网上去找很久,结果找来的还是不很符合要求。所以我最近把开发中常用的一些正则表达式整理了一下,在这里分享一下。给自己留个底,也给朋友们做个参考。

一、校验数字的表达式
1 数字:^[0-9]*$
2 n位的数字:^\d{n}$
3 至少n位的数字:^\d{n,}$
4 m-n位的数字:^\d{m,n}$
5 零和非零开头的数字:^(0|[1-9][0-9]*)$
6 非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(.[0-9]{1,2})?$
7 带1-2位小数的正数或负数:^(\-)?\d+(\.\d{1,2})?$
8 正数、负数、和小数:^(\-|\+)?\d+(\.\d+)?$
9 有两位小数的正实数:^[0-9]+(.[0-9]{2})?$
10 有1~3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$
11 非零的正整数:^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$
12 非零的负整数:^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$
13 非负整数:^\d+$ 或 ^[1-9]\d*|0$
14 非正整数:^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$
15 非负浮点数:^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$
16 非正浮点数:^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$
17 正浮点数:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
18 负浮点数:^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
19 浮点数:^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$

二、校验字符的表达式
1 汉字:^[\u4e00-\u9fa5]{0,}$
2 英文和数字:^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$
3 长度为3-20的所有字符:^.{3,20}$
4 由26个英文字母组成的字符串:^[A-Za-z]+$
5 由26个大写英文字母组成的字符串:^[A-Z]+$
6 由26个小写英文字母组成的字符串:^[a-z]+$
7 由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
8 由数字、26个英文字母或者下划线组成的字符串:^\w+$ 或 ^\w{3,20}$
9 中文、英文、数字包括下划线:^[\u4E00-\u9FA5A-Za-z0-9_]+$
10 中文、英文、数字但不包括下划线等符号:^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$
11 可以输入含有^%&',;=?$\"等字符:[^%&',;=?$\x22]+
12 禁止输入含有~的字符:[^~\x22]+

三、特殊需求表达式
1 Email地址:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
2 域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(/.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+/.?
3 InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$
4 手机号码:^(13[0-9]|14[0-9]|15[0-9]|16[0-9]|17[0-9]|18[0-9]|19[0-9])\d{8}$ (由于工信部放号段不定时,所以建议使用泛解析 ^([1][3,4,5,6,7,8,9])\d{9}$)
5 电话号码("XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX):^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$
6 国内电话号码(0511-4405222、021-87888822):\d{3}-\d{8}|\d{4}-\d{7}
7 18位身份证号码(数字、字母x结尾):^((\d{18})|([0-9x]{18})|([0-9X]{18}))$
8 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
9 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\w{5,17}$
10 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$
11 日期格式:^\d{4}-\d{1,2}-\d{1,2}
12 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$
13 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$
14 钱的输入格式:
15 1.有四种钱的表示形式我们可以接受:"10000.00" 和 "10,000.00", 和没有 "分" 的 "10000" 和 "10,000":^[1-9][0-9]*$
16 2.这表示任意一个不以0开头的数字,但是,这也意味着一个字符"0"不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$
17 3.一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$
18 4.这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧.下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$
19 5.必须说明的是,小数点后面至少应该有1位数,所以"10."是不通过的,但是 "10" 和 "10.2" 是通过的:^[0-9]+(.[0-9]{2})?$
20 6.这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$
21 7.这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$
22 8.1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$
23 备注:这就是最终结果了,别忘了"+"可以用"*"替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里
24 xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$
25 中文字符的正则表达式:[\u4e00-\u9fa5]
26 双字节字符:[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
27 空白行的正则表达式:\n\s*\r (可以用来删除空白行)
28 HTML标记的正则表达式:< (\S*?)[^>]*>.*?|< .*? /> (网上流传的版本太糟糕,上面这个也仅仅能部分,对于复杂的嵌套标记依旧无能为力)
29 首尾空白字符的正则表达式:^\s*|\s*$或(^\s*)|(\s*$) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)
30 腾讯QQ号:[1-9][0-9]{4,} (腾讯QQ号从10000开始)
31 中国邮政编码:[1-9]\d{5}(?!\d) (中国邮政编码为6位数字)
32 IP地址:\d+\.\d+\.\d+\.\d+ (提取IP地址时有用)
33 IP地址:((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)) (由@飞龙三少 提供,感谢共享)

作者:zxin
出处:http://zxin.cnblogs.com/

Macbook经常提示无线蓝牙键盘更换电池,但状态栏看到键盘电量一直100%

用终端能看到比较真实的电量
蓝牙键盘电量:
ioreg -c AppleBluetoothHIDKeyboard |grep ‘”BatteryPercent” =’
蓝牙鼠标电量:
ioreg -c BNBMouseDevice |grep ‘”BatteryPercent” =’

Windows下正确配置cwRsync,每次向Linux同步代码时,不需输入密码

(已发内部论坛,重新整理转贴出来)
使用Visual Studio或者Source Insight来写后台代码时,必然会遇到代码如何从windows下同步到Linux开发机中进行编译的问题。常用方法有两种,一种是在Linux下配置Samba;另一种是使用Rsync来同步。
Samba毕竟是映射的网络硬盘,读写速度自然没有本机快,我个人不太喜欢直接用VS在其中工作。
在Windows下安装cwRsync客户端后,将Rsync的同步脚本作为一个快捷键,添加到VS的菜单栏中(我用的是Alt+T+U),代码有修改,则能很快的同步到Linux开发机中,不过烦人的是,每次都需输入密码。
通过添加ssh密钥,并正确配置同步脚本,即可解决。步骤如下:

1. 生成密钥
在Windows命令行中,执行C:\Program Files\cwRsync\bin>ssh-keygen.exe -t rsa ,根据提示,输入密钥文件路径名称,比如 C:\devkey.接着提示passphrase,可以不设置,直接回车。密钥文件生成到指定的目录中,私钥和公钥分别是devkey和devkey.pub。
2. 添加公钥到Linux
   登录到Linux开发机,进入目录 ~/.ssh/ ,将公钥 devkey.pub添加至该目录,并执行:
   $ cat devkey.pub >> authorized_keys
   $ chmod 700 authorized_keys
   (备注:关于Linux开发机下Key格式的问题,后面介绍。要保持添加的公钥同主机使用的SSH key格式一直,否则会失效)
3. 修改Windows同步脚本
   使用set命令设置HOME路径,并在ssh命令中使用-i参数指定刚才生成的私钥devkey。(根据个人需要设置同步目录)
   Windows批处理脚本示例:
REM ————BEGIN————
cd C:\Program Files\cwRsync\bin
c:
SETLOCAL
SET CWRSYNCHOME=%PROGRAMFILES%\cwRsync\bin
SET HOME=%HOMEDRIVE%%HOMEPATH%
rsync –perms –chmod a+rwx -avz –progress –exclude=”*svn*” –exclude=”project” -e “ssh -p 22 -l neilwu -i /cygdrive/c/devkey ” — “/cygdrive/e/test/” [email protected]:/data/home/neilwu/test/
pause
REM ————END————–

4. 运行同步脚本

P.S. 
1. 必须使用SET命令设置HOME路径,否则会有提示“Could not create directory  ‘/home/neilwu/.ssh’”。cwrsync的示例脚本里已经有说明:Set HOME variable to your windows home directory. That makes sure that ssh command creates known_hosts in a directory you have access. 因为cwRsync使用的是cygwin的库,只是从cygwin中抽取了这几个命令出来,ssh命令在执行时需要记录Host公钥信息,也可以使用选项UserKnownHostsFile 来指定known_hosts文件路径,不过Windows下新建一个名称中有”.”的文件夹要在CMD中用命令”mkdir .ssh”。
2. ssh可以指定选项 -o StrictHostKeyChecking=no,来禁用远程主机的公钥检查。不过如果key不变时,只在首次有用。
3. 建议脚本执行完后,最后用pause命令暂停,可以检查一下本次同步的文件
4. 关于Key
cwRsync使用的是OpenSSH,刚才产生的devpub.key格式如下:
ssh-rsa AAAAB3Nza…
要确认Key格式的话,在你的Linux开发机上生成一对Key即可。运行ssh-keygen -t rsa,例如,我的公钥是:
—- BEGIN SSH2 PUBLIC KEY —-
Comment: “2048-bit RSA, converted from OpenSSH by neil”
AAAAB3NzaC1yc2EAAAABIwAA…
可以看到是2048位的Key,而且pubkey是SSH2格式的。
所以要对刚才Windows下生成的进行格式转换:ssh-keygen -ef devkey.pub > newdevkey.pub,然后用newdevkey.pub添加到Linux开发机的~/.ssh2/目录下,
同时,echo “Key newdevkey.pub” >> ~/.ssh2/authorization

5. 参考资料
Manpage of SSH,rsync
http://everythinglinux.org/rsync/
https://blogs.oracle.com/jkini/entry/how_to_scp_scp_and
———————
作者:yubaibai1111
来源:CSDN
原文:https://blog.csdn.net/butterflydog/article/details/7464966
版权声明:本文为博主原创文章,转载请附上博文链接!

CentOS 7 防火墙配置80端口访问

查看防火墙是否开启
systemctl status firewalld

若没有开启则开启
systemctl start firewalld

查看所有开启的端口
firewall-cmd --list-ports

注:启动防火墙后,默认没有开启任何端口,需要手动开启端口

防火墙开启端口访问
firewall-cmd --zone=public --add-port=80/tcp --permanent
命令含义:  –zone #作用域    –add-port=80/tcp #添加端口,格式为:端口/通讯协议    –permanent #永久生效,没有此参数重启后失效

注:开启后需要重启防火墙才生效     【重启命令】:  firewall-cmd --reload

初始化mysql数据库提示缺少Data:dumper模块解决方法

初始化mysql数据库时出现下面错误,原因是缺少Data:dumper模块

[root@localhost 5.6.42]# ./scripts/mysql_install_db --user=mysql
FATAL ERROR: please install the following Perl modules before executing ./scripts/mysql_install_db:
Data::Dumper

解决方法 :安装autoconf库
命令:yum -y install autoconf //此包安装时会安装Data:Dumper模块

安装完autoconf库,再运行./scripts/mysql_install_db –user=mysql,问题消失!!!