I am LAZY bones?
AN ancient AND boring SITE

分类: 'CLI软件' 的归档

彩色命令行

看了坛子里ee的帖子,试了下下面这个脚本,发现彩色的命令行很好玩,但不知哪里有更详细的资料。

再帖张图:


邮件里面收到winmail.dat附件的解决办法- tnef

不知广大ubuntuer有没有收到过带个winmail.dat的邮件,我想在公司用ubuntu办公的一定收到过不少这种麻烦邮件。而你完全不知道这个附件如何打开,甚至更惨的是原本附件在邮件中的文件也不幸被这个winmail.dat吃掉了。你也许会询问这封邮件的发件人,这个时候对方多半也是一头雾水,因为人家用Outlook用的好好的,从来没有听说过这个问题,说得直白一点,就是完全不知道你在说什么。
那么winmail.dat到底是个啥东西呢?是M$的工具在编码打包你的邮件进行发送时,如果按照默认指定的RTF格式,会把格式信息按照MS自己的一套标准存放在邮件体中(在此,强烈BS M$的这种做法),造成非Outlook客户端不认识,无法正确解析。
你当然可以要求你的发件人不要用Outlook,或者不要用rtf格式,纯文本或HTML均可。但是如果你做不到这点,也还是有办法的。那就是使用 tnef。
安装:

代码:
sudo apt-get install tnef

使用:

代码:
tnef winmail.dat

你也可以先用tnef -t winmail.dat 来看看包含的文件。
由于发件人用的大多是windows,一般这样得到的附件在utf8的linux下,文件名都会是乱码,无奈再用convmv转一下文件名的编码:

代码:
convmv -f gbk -t utf8 –notest *

至此大功告成。

再用一行总结一下以上过程:

代码:
tnef winmail.dat && tnef -t winmail.dat | xargs convmv -f gbk -t utf8 –notest

再写点关于ssh的

一、gnome终端ssh登录服务器时提示密码慢的解决办法:
原帖:http://forum.ubuntu.org.cn/viewtopic.php?t=47794&highlight=

原先用gnome终端ssh登录服务器时,输入ssh命令到提示可以输入密码大概要等20多秒,后来查到说是由于

引用:
IP地址反向解析
禁用掉就好了

解决办法就是:

引用:
系统->系统管理->网络->常规,把自动服务探测关闭

验证有效~
而且那选项本来就标着“这是一个潜在的安全隐患”估计还是实验性的东东吧!
二、用 RSA 密钥代替密码验证身份,无须每次连接都输密码的办法
1.再本机执行

代码:
ssh-keygen -t rsa

先会提示密钥对保存位置,默认为(~/.ssh/id_rsa),接受默认选项。
然后会提示输入一个短语用于代替密码,这里如果以后不想每次都输密码的话,就直接回车,留空。
会再次让你输入上面的内容,继续回车留空。
这时候密钥对就生成好了,文件在~/.ssh/id_rsa和~/.ssh/id_rsa.pub
2.将本机刚才生成的~/.ssh/id_rsa.pub文件里面的内容添加到远程机的登录用户的~/.ssh/authorized_keys文件下面,如果该文件不存在,可以手工创建一个。
3.完成,现在ssh远程机的话,就直接登录了 Very Happy
不过要保证本机的~/.ssh/id_rsa文件的安全哦~万一这个文件被盗,后果将是很严重滴~~~

nautilus 查看图像文件

记得以前红帽子的时候,nautilus既可以用来当文本浏览器,又可以用来当图像查看器的,不知道为什么ubuntu里面的Nautilus 2.18.1没有这些功能,Nautilus 2.2.4都有这功能的。
而且这边有几个tif文件,在Nautilus 2.2.4里面可以正常打开,复制到ubuntu里面以后,居然没一个程序可以正确打开了,这估计是tif文件本身有问题,Nautilus 2.2.4有一定的容错能力。
后来装了个这个包“libtiff-opengl”里面有个命令行下的查看器,倒是可以打开这些文件,只是开了-w以后会有如下输出:

引用:
lily@LLY:~/00/06$ tiffgt -w f05080616260539.tif
Fax3Decode1D: Warning, f05080616260539.tif: Premature EOL at line 861 of strip 0 (got 0, expected 1728).

打开其他正常的tif就没有这行信息,这也说明是tif文件本身的问题。
寻找一个可以容错的图像查看器中。。。

mySQL 的一些应用(命令行)

创建一个名为databasename的数据库:

或者可以进入mysql交互界面再建立:

建立一个名为theuser,密码为thepass的用户,对databasename数据库有任何权限,并限制此用户不能来自远程:

建立一个名为theuser,密码为thepass的用户,对databasename数据库只有读权限,但是此用户可以来自远程:

执行一个SQL文件:

========20090928 update========
补充一个忘记mysql的root密码的解决方法:参考这里
如果 MySQL 正在运行,要首先停掉:

启动 MySQL 的“安全模式”:

就可以不需要密码就进入 MySQL 了。
然后就是

现在可以杀掉 safe_mysqld 进程,用正常方法启动 MySQL 了。

apt-file

# apt-file search filename——查找包含特定文件的软件包(不一定是已安装的),这些文件的文件名中含有指定的字符串。
apt-file是一个独立的软件包。您必须先使用apt-get install来安装它,然後运行apt-file update(这步会很慢,而且没有提示,需要点耐心)。
如果apt-file search filename输出的内容太多,您可以尝试使用apt-file search filename | grep -w filename(只显示指定字符串作为完整的单词出现在其中的那些文件名)或者类似方法,例如:apt-file search filename | grep /bin/(只显示位于诸如/bin或/usr/bin这些文件夹中的文件,如果您要查找的是某个特定的执行文件的话,这样做是有帮助的)。
apt-get update 系统软件包更新

记录日志用的小脚本

高手不要笑,简单得不能再简单了:

代码:
~$ cat ~/bin/work
#!/bin/shif [ -z $1 ]; then
echo “useage : basename $0 \”what you have done!\””;
exit 1;
fi
echo date $1 >> /media/sda5/0/日志.txt;

文件名乱码的转换方法

代码:
convmv -f gbk -t utf8 –notest -r 目录名
convmv -f gbk -t utf8 –notest 文件名

GBK -> UTF-8
注意: notest参数会直接覆盖原文件,执行前最好去掉这个参数,看看产生的信息对不对。

编译的ffmpeg居然还是不认识aac音频编码,郁闷中。

换了手机之后,新的手机可以放3gp格式的视频了,于是想把一些东西转成3gp玩玩,倒也没觉得在手机上看有什么意思,纯属玩玩。于是装了源里的ffmpeg,用如下命令转了一试不行。

代码:
ffmpeg -i test.wmv -ar 8000 -ac 1 -acodec aac -vcodec h263 -s 352×288 -r 12 -b 60 -ab 12 -y test.3gp

提示Unknown codec ‘aac’。
于是svn了ffmpeg的源代码打算自己编译,按照这里的办法:http://blog.5ilinux.com/archives/2006/08/ffmpeg.html
但可能由于年代已经不同了,很多配置选项都已经不能用了,像他说的:–enable-faac已经不支持了,改成–enable-libfaac了。这样编译以后,再转,居然还是提示一样的错误,还是Unknown codec ‘aac’,郁闷,下次在研究研究。

在文件中查找

原来在文件中查找这么简单,就一个 -r 呵呵。

代码:
grep -r “what” where

grep的其他有用的参数:
-i 忽略大小写
-w 整字匹配
-x 整行匹配
-b 显示在第几个字节找到
-n 显示在第几行找到
-c 只显示每个文件的匹配行数