Author: jpuyy

  • div+css学习中要注意的地方

    理念:
    CSS 允许你对布局进行完全地控制
    CSS能达到你想要的效果。例:关闭圆点是 CSS 的最基本的能力。它有能力使列表看起来和普通文本没有两样,也可以使列表看起来像图形导航栏,具有完整的反转效果。
    加强用html进行结构化,使用列表元素来标记列表,这样在所有设备里都会认为他是列表。
    XHTML 和 CSS 也会被误用和滥用,有时可能还不如html,思维要考虑如何用它们产生更有效的代码,要不只会是新垃圾代替旧垃圾。
    为你的网页减肥,尽量做到,就像没有女人会讨厌自已太瘦
    在W3C的描述中我们可以找到理解 div 元素的关键,“一种添加结构的通用机制。”

    使用 em 来设置字体大小

    如果要避免在 Internet Explorer 中无法调整文本的问题,许多开发者使用 em 单位代替 pixels。
    W3C 推荐使用 em 尺寸单位。1em 等于当前的字体尺寸。如果一个元素的 font-size 为 16 像素,那么对于该元素,1em 就等于 16 像素。在设置字体大小时,em 的值会相对于父元素的字体大小改变。

    以上段标记的css代码:

    如果要避免…………………小改变。

     

     

    font属性里可以将所有的写在一起,如
    p.ex2
    {
    font:italic bold 12px/20px arial,sans-serif;
    }
    10px/20px分别是字的大小和行间距,这样就可以不用line-height来设置了

    outline和border
    border在outline的里面
    边框外是外边距,边框内是内边距

    css 模型

    padding 上 右 下 左;
    当说到width时,实际上说的是内容的宽度,而不算内边距,外边距
    如果边框样式为 none,即边框根本不存在,那么边框就不可能有宽度,因此边框宽度自动设置为 0
    外边距合并指的是,当两个垂直外边距相遇时,它们将形成一个外边距。合并后的外边距的高度等于两个发生合并的外边距的高度中的较大者。

    使用id选择器要注意:
    一个html文档只能出现一次
    id=””中不能有空格
    id区分大小写
    id的规则

    id 值必须以字母或者下划线开始;不能以数字开始。虽然 W3C 验证不会捕获这个错误,但是 XML 解析器会的。同时,如果你将 id 与 JavaScript 在表单中配合使用,那么 id 名称和值必须是合法的 JavaScript 变量。空格和连字号,特别是连字号,是不被允许的。不仅如此,将下划线用于 class 或者 id 名都不是个好主意,这是由于在 CSS2.0(以及某些浏览器)中的限制。

    后代选择器会选所有的符合的元素
    子元素选择器会先挨着的元素,如选的不挨着,则无效

  • curl实战

    取得头信息

    curl --head 127.0.0.1
    curl -I 127.0.0.1

    取得http状态码(加-I只加载头信息,速度更快)
    -w后加变量,获取很多与请求相关的额外信息显示在屏幕上,如%{http_code}显示状态码,%{time_total} 响应时间, %{size_download}页面大小, %{content_type} 页面类型

    curl -s -o /dev/null -w "%{http_code}" http://jpuyy.com
    curl -s -o /dev/null -I -w "%{http_code}" http://jpuyy.com

    如果有一批url需要判断状态码,写入url_http_status.txt中,脚本如下:

    #!/bin/bash
    for i in `cat url_http_status.txt`
    do
    STATUS_CODE=`curl -o /dev/null -s -w %{http_code} $i`
    echo -e "$i:\t$STATUS_CODE"
    done

    使用安静模式

    --silent

    curl 跟踪 301跳转,使用参数 -L

    ➜  ~  curl -I http://www.jpuyy.com -L
    HTTP/1.1 301 Moved Permanently
    Server: nginx/1.0.15
    Date: Sun, 09 Nov 2014 10:40:15 GMT
    Content-Type: text/html; charset=UTF-8
    Connection: keep-alive
    X-Powered-By: PHP/5.3.3
    X-CF-Powered-By: WP 1.3.14
    X-Pingback: http://jpuyy.com/xmlrpc.php
    Location: http://jpuyy.com/
    
    HTTP/1.1 200 OK
    Server: nginx/1.0.15
    Date: Sun, 09 Nov 2014 10:40:16 GMT
    Content-Type: text/html; charset=UTF-8
    Connection: keep-alive
    Vary: Accept-Encoding
    X-Powered-By: PHP/5.3.3
    X-CF-Powered-By: WP 1.3.14
    X-Pingback: http://jpuyy.com/xmlrpc.php
    

    取得多个子域名信息

    curl http://site.{one,two,three}.com
    如:curl http://{bbs,ftp,nic}.cczu.edu.cn

    下载file1.txt-file100.txt

    ftp://ftp.numericals.com/file[1-100].txt
    ftp://ftp.numericals.com/file[001-100].txt (with leading zeros)
    ftp://ftp.letters.com/file[a-z].txt
    http://any.org/archive[1996-1999]/vol[1-4]/part{a,b,c}.html
    http://www.numericals.com/file[1-100:10].txt 10,20.....txt

    关于cookies

    The file specified with -b/–cookie is only used as input.No cookies will be stored in the file.

    用于读入

    To store cookies, use the -c/–cookie-jar option or you could even save the HTTP headers to a file using -D/–dump-header!

    curl --cookie "desktop=1;key2=value2" -v -o /dev/null http://jpuyy.com/

    curl伪造头信息

    curl --header "X-Forwarded-For:8.8.8.8" --header "Accept-Language: en" http://www.jpuyy.com

    curl模拟指定浏览器

    curl -A "Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:25.0) Gecko/20100101 Firefox/25.0" [URL]

    curl模拟指定的referer

    curl [URL] -e http://www.aavv.com
    或使用 --referer

    curl使用压缩

    curl -I "http://www.hao123.com" --compressed
    curl -I -H "Accept-Encoding: gzip, deflate" "http://www.hao123.com"

    curl执行post提交

    curl http://localhost:8000/wrap -d text=kadj+kdsj+kasdfj+kaslfdj+jkdasljf+skdfjal-yyyyksdjf-kasjd

    curl 带账号,basic 认证

    -u, --user <user:password>
    
    curl -L -i --user myuser:mypass http://abc.example.com/manage
    

    curl https出现错误

    curl -sS https://getcomposer.org/installer
    curl: (60) SSL certificate problem, verify that the CA cert is OK. Details:
    error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed
    More details here: http://curl.haxx.se/docs/sslcerts.html

    解决办法:
    http://curl.haxx.se/docs/caextract.html 下载 ca-bundle.crt到 /etc/pki/tls/certs/ca-bundle.crt

    curl 指定代理服务器

    curl http://jpuyy.com -x 211.61.47.19:80

    指定 socks5 代理服务器

    curl --socks5 127.0.0.1:1081 jpuyy.com/ip.php

    更多案例:http://www.thegeekstuff.com/2012/04/curl-examples/

    下载 github release tar.gz 包

    curl -L -O https://github.com/ansible/ansible/archive/v2.1.0.0-0.2.rc2.tar.gz

    获取 token,先准备一个认证文件 auth.json

    {
    "username":"jpuyy",
    "password":"pass"
    }
    

    发送请求

    curl -v -XPOST info.mysite.com/api/auth/token -d @auth.json -H 'Content-Type: application/json'
    

    根据认证的 token 放在 header 访问

    curl info.mysite.com/api/config/web.gui-H "Authorization: FuZzA2In0..."

    curl 返回 000 状态码表示超时

    curl 测试 websocket

    curl -i -N -H "Connection: Upgrade" -H "Upgrade: websocket" -H "Host: echo.websocket.org" -H "Origin: http://www.websocket.org" http://echo.websocket.org

    curl 下载断点重连

    curl -O -C - http://jpuyy.com/a.txt
    

    curl 自己指定域名的解析

    --resolve [DOMAIN]:[PORT]:[IP]
    curl https://jpuyy.com --resolve jpuyy.com:443:192.168.1.66
    

    curl 重复请求 100次

    curl 'https://jpuyy.com/abc?[1-100]'
    
  • 使用pkill踢掉linux用户

    先看看都哪些终端登陆

    root@ibm:~# w
    19:28:23 up 2 days, 12:12, 1 user, load average: 0.20, 0.29, 0.33
    USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
    root pts/0 192.168.1.102 19:12 1.00s 1.24s 0.02s w

    用户帐号/所用的终端/何处登陆/登陆时间/空闲时间/耗费的CPU/执行后耗费CPU/正在执行

    root pts/0 192.168.1.102 19:12 1.00s 1.24s 0.02s w

    上面可以看到只有我一个用户,使用如下命令会将我自己踢出:

    pkill -kill -t pts/0

    进而衍生出对pkill用法的整理

    pkill is used to send signals to Process (computing)processes. The pkill command allows the use of extended regular expression patterns and other matching criteria.

    pkill的使用是发送信号给进程,支持扩展正则表达式或其他匹配规则.

    pgrep, pkill – look up or signal processes based on name and other attributes。

    后面跟进程名而kill只能跟进程号,pkill还支持自动补全

    那么,如果说xxx有两个进程

    root     10976     1  0 Jul31 ?        00:00:00 xxx: master process usr/local/xxx/sbin/xxx
    www-data 10978 10976  0 Jul31 ?        00:00:00 xxx: worker process

    运行pkill xxx 会把他们全杀死,有时我们并不想要这样的结果,所以要认准了再用。

  • 我使用的几个wordpress插件

    用wordpress也老长时间了

    wordpress装插件很方便,有好多插件是国人开发便于中文用户使用的

    在这里我就记录下来整理一下

    当前用的主题是 PhilNa 1.0.9,作者为 yinheli 各方面我都比较满意

    有若干个控制字体的,用javascript来显示脚本 高亮文字的,我基本不用 。 一是咱没那么出息会那么多语言,二是wordpress的引号已经够我用的了

    插件:Akismet

    一款优秀的防垃圾评论插件。

    在Akismet配置里有说明,去申请一个key就好了。若您还没有 API key,您可从 Akismet.com 得到一个。

    插件:日志自动截断

    自动截断日志,可达到在首页显示一大段而不是全部显示的效果,可以选择截断的长度并去除所有脚本类的文字,使首页看起来美观

    插件:WP-Cumulus

    标签云插件,不支持中文,有人推出一个swf可以支持中文,但是我用了下比较卡,而且不好看,就没有用,我的tag全是英文的,也就简单的英文单词,也用不着中文

    插件:WP-DB-Backup

    设置好自动备份选项自动备份数据库的,用处大

    插件:Quotmarks Replacer

    有时候整理好的命令或代码拷贝的时候出现中文字符,用此插件解决引号等全角问题

    插件:Google Syntax Highlighter for WordPress

    平时用不大到,哪里有那么多代码可写,所以删掉了,有些东西就是,功能强大反而用不到. Supports C++, C#, CSS, Delphi, Java, JavaScript, PHP, Python, Ruby, SQL, VB, XML, and HTML.

    插件:Countdown Timer

    自动倒计时的功能,给懒人用的

    插件:cos-html-cache

    该插件会在页面第一次载入的时候产生和url对应的真正的html文件作为缓存,后面的运行将会直接载入该html从而大大的提高了页面的效率。有利有弊。也不用了,用了之后我的搜索框没法搜东西,于是用了谷歌的自定义搜索

    插件:Code Markup

    A filter that displays <code> blocks nicely while still allowing formatting.
    对于想显示的html标签代码,放入<code lang=”xhtml”></code>里面

    插件:All in One SEO Pack

    Out-of-the-box SEO for your WordPress blog. Options configuration panel | Upgrade to Pro Version | Donate | Support | Amazon Wishlist
    插件:Google XML Sitemaps
    This plugin will generate a special XML sitemap which will help search engines like Google, Yahoo, Bing and Ask.com to better index your blog.
    插件:Wireless-WordPress
    为你的WordPress增加wap主题模板功能,让你的WordPress博客拥有一个更加友好的UI.
    插件:WP-PageNavi分页导航
    增加了一个更美观实用的分页导航到你的WordPress博客
    插件:Random Pages Widget
    显示随机文章

  • nginx对某目录进行身份验证

    本例对web根目录下的phpmyadmin文件夹进行认证

    #cd /usr/local/nginx/conf
    #mkdir htpasswd

    在 nginx.conf 文件中对应的 server 段中 添加引用:
    location ^~ /phpmyadmin/ {
    auth_basic “database-login”;
    auth_basic_user_file /usr/local/nginx/conf/htpasswd/DBpass;
    }

    再在 相应目录中创建一个新文件DBpass
    此文件的书写格式是
    用户名:密码
    用户名 自己随意设置 无需加密

    密码必须使用函数 crypt(3) 加密

    方法一:

    用 htpasswd 工具来创建密码文件

    /usr/bin/htpasswd -c /usr/local/nginx/conf/htpasswd/DBpass jpuyy       //-c  Create a new file.创建一个文件 最后跟上用户名

    New password:
    Re-type new password:
    Adding password for user jpuyy

     

    方法二:

    使用perl 创建密码文件

    新建 一个 pw.pl 文件

    #!/usr/bin/perl
     use strict;
     my $pw=$ARGV[0] ;
     print crypt($pw,$pw)."\n";

    然后执行:
    chmod +x pw.pl
    ./pw.pl password
    papAq5PwY/QQM 就是password 的crypt()密码
    如果 不用
    ^~ /phpmyadmin/
    而用
    /phpmyadmin
    将只能对目录进行验证 直接访问其下的文件 将不会弹出登录验证

    昨天搞好后草草了事
    今天发现认证后php打不开,几经搜索资料,在location里要加上fast-cgi,注意两个location包含关系

    #对phpmyadmin进行认证
    location ^~/phpmyadmin/ {
       location ~ \.php$ { 	
    	fastcgi_pass   127.0.0.1:9000;
    	fastcgi_index  index.php;
    	fastcgi_param  SCRIPT_FILENAME  /web/$fastcgi_script_name;
    	include        fastcgi_params;
    	}
    
    	root   /web/;
    	index  index.php;
    	auth_basic "database-login";
    	auth_basic_user_file /usr/local/nginx/conf/htpasswd/DBpass;
    }
  • ip别名(ip alias)设置和应用

    A.ip别名(ip alias)的设置和取消

    最近看到web虚拟主机实现的方式有两种,一是设置ip别名 二是在server{}里设置(常用)

    所以特地整理学习一下ip 别名的设置

    ip别名(ip alias)是Linux内核的一个标准功能

    设置:

    #/sbin/ifconfig eth0:0 219.219.219.219 broadcast 219.219.219.255 netmask 255.255.255.0 up

    检验:

    #/sbin/ifconfig

    取消:

    #ifconfig eth0:0 down

    eth0后的取值 0~255

    后面跟的ip如果是和eth0所在网的ip同一网段,则本网内全能ping通

    如果是乱跟一通,则只能本机测试之用,也没有多大的意义

    B.ip别名(ip alias)的应用

    1.充分利用有限的资源

    本来两台差劲的电脑分别跑着两个应用,ip当然不同

    来了一台新的高级的服务器,想同时迁移这两个程序到这台主机,ip别名便派上了用场

    2.服务不间段

    两台服务器,主服务器的提供某服务

    主服务器不用真实的ip来提供服务

    当主服务器坏了时候,副服务器可以直接ip别名设置好顶上来

     

    在淘宝买了一个差劲的vps

    ifconfig 以后发现ip别名:

    venet0    Link encap:UNSPEC  HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
    UP BROADCAST POINTOPOINT RUNNING NOARP  MTU:1500  Metric:1
    RX packets:1352 errors:0 dropped:0 overruns:0 frame:0
    TX packets:1860 errors:0 dropped:0 overruns:0 carrier:0
    collisions:0 txqueuelen:0
    RX bytes:102537 (100.1 KiB)  TX bytes:1380885 (1.3 MiB)

    venet0:0  Link encap:UNSPEC  HWaddr 00-00-00-00-00-00-00-00-00-00-00-00-00-00-00-00
    inet addr:178.17.162.219  P-t-P:178.17.162.219  Bcast:0.0.0.0  Mask:255.255.255.255
    UP BROADCAST POINTOPOINT RUNNING NOARP  MTU:1500  Metric:1