CSS overflow 属性

作者:@ouyang 发布时间:2015年06月29日 阅读: 3,129 分类:学习笔记 暂无评论

有时候因为文字会破格溢出文字,有了overflow以后就安逸多了。并且大多数浏览器都支持该属性。

div
  {
  width:150px;
  height:150px;
  overflow:scroll;
  }

几个参数值
visible 默认值,内容不会修建。
hidden 内容被修剪,其余内容不可见。
scroll 内容被修剪,剩余内容以滚动条形式查看内容。
auto 如内容被修剪,其余以滚动条形式查看内容。
inherit 从父元素继承overflow属性。

参考地址:http://www.w3school.com.cn/jsref/prop_style_overflow.asp

Apache开启concat模块

作者:@ouyang 发布时间:2015年06月23日 阅读: 3,115 分类:Linux摘要,学习笔记 暂无评论

淘宝Tengine很早就有concat,但apache的concat有致命的缺陷可能导致php文件直接被下载(未经测试),所以一直没敢使用。
今天偶然发现国人修改的concatx,所以将其编译进服务器,问题貌似还是有(无法使用?v版本号),但已经非常不错了。
编译apache的concatx模块:

wget http://ajaxs.sinaapp.com/apache/modconcat/mod_concatx.c
ln -s /usr/local/apache/bin/apxs /usr/local/bin/apxs
apxs -c mod_concatx.c

编译安装concatx模块

apxs -iac mod_concatx.c

编译过程中会自动安装在apache模块目录中,并且conf/httpd.conf配置文件也会自动加上concatx的配置信息。
重启httpd

service httpd restart

查看httpd已经加载的模块

httpd -M
//在最后可以看到
concatx_module (shared)

这说明已经安装成功!可以正常使用了!

请求参数需要用两个问号('??')例如:
http://example.com/??style1.css,style2.css,css/style3.css,js/js.js

说明:concatx使用过程中如果当前目录下有index.php或index.html将无法使用。

[基础]if判断不为空的情况执行代码

作者:@ouyang 发布时间:2015年06月09日 阅读: 3,028 分类:学习笔记 暂无评论

{if !empty($description)}

摘要:{$description}

{/if}

if判断如$description不为空的情况下执行代码!

Directadmin开启共享IP支持SSL功能

作者:@ouyang 发布时间:2015年06月02日 阅读: 3,118 分类:Linux摘要 暂无评论

随着沃通的SSL证书免费,而且还有免费就3年的SSL证书,都是基于域名的。所以独立IP限制就不是那么重要了。
Directadmin开启SSL支持很简单!
第一步:

[root@localhost ~]sed -i '$a enable_ssl_sni=1' /usr/local/directadmin/conf/directadmin.conf

执行后可以用cat查看最尾有没有enable_ssl_sni=1,当然也可以手工vi加入!

阅读剩余部分...

敬告:请慎用腾讯云服务器

作者:@ouyang 发布时间:2015年05月14日 阅读: 3,208 分类:日积月累 暂无评论

腾讯基因里面就没有“服务”这两个字。

1、云技术落后,无法升级产品。
2、企业高大上,不顾客户感受。
3、无客服热线,只能在线咨询。

腾讯云的高姿态,必将注定失败!祝愿腾讯云一路走好。

增加CentOS的swap交换空间

作者:@ouyang 发布时间:2015年05月12日 阅读: 3,029 分类:Linux摘要 暂无评论

因为百度云服务器默认没有设置swap文件,所以需要建立一个swap交换空间。

 
第一步,执行建立swap一个8GB的交换文件

[root@localhost /]# dd if=/dev/zero of=swapfile bs=1024 count=8192000
8388608+0 records in
8388608+0 records out
8589934592 bytes (8.6 GB) copied, 33.4684 s, 257 MB/s

过十几秒钟,就建立OK了。
接下来执行:

[root@localhost /]# mkswap swapfile   #在swapfile文件上建立交换分区
[root@localhost /]# swapon swapfile   #激活swapfile文件

好了,swap文件到此激活完成。

[root@localhost /]# free -m
             total       used       free     shared    buffers     cached
Mem:          3830       3712        118          0         12       3491
-/+ buffers/cache:        207       3622
Swap:         7999          0       7999

可以看到swap已经生效了。

下步就是启动自动挂在了。

[root@localhost /]# vi /etc/fstab

最末行加入

/swapfile   swap    swap    defaults      0    0

保存OK。

Directadmin屏蔽暴力破解IP

作者:@ouyang 发布时间:2015年04月02日 阅读: 3,316 分类:Linux摘要 暂无评论

服务器都是基于CentOS和Directadmin的环境。但最为头疼的就是每天爆满的穷举破解。很是头疼。
所以翻阅官网说明,特此摘录:

第一步:

cd /etc/init.d
mv iptables iptables.bak
wget http://files.directadmin.com/services/all/iptables
chmod 755 iptables   
//此时一定要记得配置iptables的文件,不然你修改了SSH默认22端口是其他端口的话,你就杯具了。
/etc/init.d/iptables restart

第二步:

cd /usr/local/directadmin/scripts/custom
wget http://files.directadmin.com/services/all/block_ip.sh
wget http://files.directadmin.com/services/all/show_blocked_ips.sh
wget http://files.directadmin.com/services/all/unblock_ip.sh
chmod 700 block_ip.sh show_blocked_ips.sh unblock_ip.sh

第三步:

touch /root/blocked_ips.txt
touch /root/exempt_ips.txt

第四部:(自动封禁IP)

vi /usr/local/directadmin/scripts/custom/brute_force_notice_ip.sh

将一下内容填入进去:

#!/bin/sh
SCRIPT=/usr/local/directadmin/scripts/custom/block_ip.sh
ip=$value $SCRIPT
exit $?;

然后:wq保存
赋权限:

chmod 700 brute_force_notice_ip.sh

(前提一定要在custom文件夹下,不然赋不了权限,这个很基础。)
OK完成!现在也可以在后台设置屏蔽IP地址。

最全的常用正则表达式大全

作者:@ouyang 发布时间:2015年03月14日 阅读: 2,632 分类:发现分享 暂无评论

一、校验数字的表达式

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)$

阅读剩余部分...

Directadmin后台登陆显示License has expired.

作者:@ouyang 发布时间:2015年02月19日 阅读: 3,330 分类:Linux摘要 暂无评论

由于没有常登陆后台的习惯,发现显示License has expired.
经过查询是可恶的DA有效期过了,需要更新授权KEY。
DA本身就自带了sh脚本,通过下面两条命令即可解决:

/usr/local/directadmin/scripts/getLicense.sh [你的授权cid] [你的授权lic_id]
/etc/init.d/directadmin restart

编译个性化的openwrt固件

作者:@ouyang 发布时间:2015年02月13日 阅读: 4,032 分类:发现分享 暂无评论

当学会了搭建openwrt编译环境,肯定是想编译有一些自己想要的东西固件,要知道官方给的固件是很简洁的,不仅没有web界面(Luci-web),连无线默认都不是开启的,这也太不像个无线路由器的样子了。
我 们会使用make kernelconfig和make menuconfig这种方法来自定义软件包,不过,这样编译出来的固件仍然不具个性化,因为,无线仍然没有开启,像SSID、路由主机名、默认网关等等 这些还是openwrt官方的默认值。那么现在,我们就通过接下来的步骤做些个性化的修改。

阅读剩余部分...