手机浏览 RSS 2.0 订阅 膘叔的简单人生 , 腾讯云RDS购买 | 超便宜的Vultr , 注册 | 登陆
浏览模式: 标准 | 列表2016年05月的文章

利用find和sed批量替换文件内容

 find的用法太多了。比如:

1、find . -name "*.php"|grep xxxx 这是判断文件名
2、find . -name "*.php"|xargs -n 50 grep "eval" 这是判断文件中是否有eval字符串,并列出来
还有更多,比如:
XML/HTML代码
  1. ====================================================  
  2. $find ~ -name "*.txt" -print    #在$HOME中查.txt文件并显示  
  3. $find .   -name "*.txt" -print  
  4. $find .   -name "[A-Z]*" -pri26nbsp;   #对匹配的文件使用cpio命令,将他们备份到磁带设备中  
  5. -prune                              #忽略某个目录  
  6.   
  7. =====================================================  
  8. $find ~ -name "*.txt" -print    #在$HOME中查.txt文件并显示  
  9. $find .   -name "*.txt" -print  
  10. $find .   -name "[A-Z]*" -print #查以大写字母开头的文件  
  11. $find /etc -name "host*" -print #查以host开头的文件  
  12. $find . -name "[a-z][a-z][0–9][0–9].txt"   -print #查以两个小写字母和两个数字开头的txt文件  
  13. $find . -perm 755 -print  
  14. $find . -perm -007 -exec ls -l {} \; #查所有用户都可读写执行的文件同-perm 777  
  15. $find . -type d -print  
  16. $find . ! -type d -print   
  17. $find . -type l -print  
  18.   
  19. $find . -size +1000000c -print       #查长度大于1Mb的文件  
  20. $find . -size 100c        -print      # 查长度为100c的文件  
  21. $find . -size +10 -print             #查长度超过期作废10块的文件(1块=512字节)  
  22.   
  23. $cd /  
  24. $find etc home apps   -depth -print | clio -ivcdC65536 -o /dev/rmt0  
  25. $find /etc -name "passwd*" -exec grep "cnscn" {} \; #看是否存在cnscn用户  
  26. $find . -name "yao*" | xargs file  
  27. $find . -name "yao*" | xargs echo   "" > /tmp/core.log  
  28. $find . -name "yao*" | xargs chmod o-w  
如果用find + sed就可以很方便的修改文件。比如:
XML/HTML代码
  1. find ./ -exec grep "xxx:80" '{}' \; -exec sed -i 's/xxx:80/\*:80/g' {} \;  

由于以前是直接写死IP的,文件也比较多,所以用find直接全文处理一下,轻松好多。

git将最后一次更新打包

 git将最后一次更新打包,这个命令在网上都是这样写的:

XML/HTML代码
  1. git archive -o update.zip HEAD $(git diff --name-only HEAD^)  

看起来没有什么问题,但事实上,如果你有一些unversion的文件,它也会打包进去,所以我是这样处理的:

XML/HTML代码
  1. git archive -o update.zip HEAD $(git diff $(git log --pretty=format:"%h" -1) --name-only HEAD^)  

嗯,将最后一次提交的内容进行打包。为什么会有这样的需求?是因为自己有git,客户那边没有,所以需要将最后一次,或者最后几次的内容进行打包输出

参考 :

1、https://git-scm.com/book/zh/v1/Git-%E5%9F%BA%E7%A1%80-%E6%9F%A5%E7%9C%8B%E6%8F%90%E4%BA%A4%E5%8E%86%E5%8F%B2

2、http://netkiller.github.io/project/git/ch13s02.html 导出指定版本区间的文件

3、http://blog.sae.sina.com.cn/archives/3003

 

 

composer引用本地git做为源库

PHP使用者大多对composer是又爱又恨,爱的是composer require后,很多类库不用去下载了,恨的是网速卡成翔,虽然国内有很多道友做了镜象,但对于bower库这些都还是整体更新。

那么,如何只利用composer的基本功能来为自己服务呢?composer的官网有介绍,只要在composer.json中加入几行代码就行了。。

JavaScript代码
  1. "repositories":[  
  2.        {  
  3.            "type":"git",  
  4.            "url":"/var/www/gouki/test/"  
  5.        },  
  6.    ]  

上面的代码中/var/www/gouki/test,是我的一个git库。也是按照composer的标准来建的。里面只有一个composer.json文件:

JavaScript代码
  1. {  
  2.     "name":"gouki/test",  
  3.     "description":"test",  
  4.     "authors":[  
  5.         {  
  6.             "name":"gouki",  
  7.             "email":"xxxx@qq.com"  
  8.         }  
  9.     ],  
  10.     "minimum-stability":"dev",  
  11.     "require":{},  
  12.     "autoload":{  
  13.         "psr-4":{  
  14.             "gouki\\test\\":"src/" 
  15.         } 
  16.     }, 
  17.     "extra":{ 
  18.         "branch-alias":{ 
  19.             "dev-master":"1.0.x-dev"  
  20.         }  
  21.     }  
  22. }  

src目录下的代码中使用的namespace就是gouki\test,然后在原项目的composer.json中再加入:

JavaScript代码
  1. "require":{  
  2.         "gouki/test":"dev-master"  
  3.     },  

最后,运行一下composer update,你会看到项目的根目录下多了vendor目录,同时,vendor目录下也会多一个gouki/test的目录,至此项目引入成功,如果还不放心,那就看一下:vendor/composer/autoload_psr4.php中有没有gouki/test。

之所以这么做,就是因为前文所说的速度,当然也有小团队的成本。比如写个类,就可以直接composer进行加载了。

问题就这么来了,如果放到线上去,那上面的

XML/HTML代码
  1. "repositories":[    
  2.        {    
  3.            "type":"git",    
  4.            "url":"/var/www/gouki/test/"    
  5.        },    
  6.    ]   
  7. 需要改为:  
  8. "repositories":[    
  9.        {    
  10.            "type":"git",    
  11.            "url":"http://xxxx.xxx.xxx/git"    
  12.        },    
  13.    ]     

如果该git是public的,则不需要任何处理,如果git是需要登录的,则需要在项目的根目录下(和composer.json平级的目录)增加一个auth.json,里面也就两三行代码

JavaScript代码
  1. {    
  2.     "http-basic":{    
  3.         "http://xxxx.xxx.xxx/git":{    
  4.             "username":"",    
  5.             "password":""    
  6.         }    
  7.     }    
  8. }    

当然如果你是ssh免登陆的git则另计。至此一个小小的自建composer源就已经完成。

select 的 placeholder

select的placeholder其实是无效的。所以很多人想了一些奇技淫巧,比如利用HTML的标签:

XML/HTML代码
  1. <select>  
  2.     <option value="" disabled selected hidden>Please Choose</option>  
  3.     <option value="0">Open when powered (most valves do this)</option>  
  4.     <option value="1">Closed when powered, auto-opens when power is cut</option>  
  5. </select>  
这样就可以看得到,但点击下拉框的时候,就不在选项里了,可以到这里看效果:http://cssdeck.com/labs/hxovifav,
但其实这不应该出现在前端面前,prompt不就是针对select的吗?
 
select的placeholder的属性确实无效,它应该使用prompt!!!
象上面的代码就应该写成:
XML/HTML代码
  1. <select prompt="Plaese Choose">  
  2.     <option value="0"> 0 </option>  
  3.     <option value="1" 1 </option>  
  4. </select>  
很多资料里都应该有吧?
 
上面关于prompt的资料都错了。对不住各位,主要是在用Yii框架的时候,直接加入"prompt"属性就可以有这个效果,导致我这个对HTML不熟悉的人误解 了,经过@Deeka的指正,我发现,这是Yii自己的实现。比如:
 
PHP代码
  1. if (isset($tagOptions['prompt'])) {  
  2.     $prompt = $encode ? static::encode($tagOptions['prompt']) : $tagOptions['prompt'];  
  3.     if ($encodeSpaces) {  
  4.         $prompt = str_replace(' '' '$prompt);  
  5.     }  
  6.     $lines[] = static::tag('option'$prompt, ['value' => '']);  
  7. }  
他自己实现了这么一条空信息,我没细看,对不住各位