分类: 'CLI软件' 的归档
邮件里面收到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远程机的话,就直接登录了
不过要保证本机的~/.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的数据库:
$ mysqladmin -uroot -pxxxx create databasename |
或者可以进入mysql交互界面再建立:
$ mysql -uroot -pxxxx mysql> CREATE DATABASE databasename; Query OK, 1 ROW affected (0.00 sec) mysql> |
建立一个名为theuser,密码为thepass的用户,对databasename数据库有任何权限,并限制此用户不能来自远程:
mysql> GRANT ALL ON databasename.* TO 'theuser'@'localhost' IDENTIFIED BY 'thepass'; Query OK, 0 ROWS affected (0.00 sec) mysql> |
建立一个名为theuser,密码为thepass的用户,对databasename数据库只有读权限,但是此用户可以来自远程:
mysql> GRANT SELECT ON databasename.* TO 'theuser'@'%' IDENTIFIED BY 'thepass'; |
执行一个SQL文件:
mysql> SOURCE filename.sql ....输出信息 mysql> |
========20090928 update========
补充一个忘记mysql的root密码的解决方法:参考这里。
如果 MySQL 正在运行,要首先停掉:
$ sudo /etc/init.d/mysql stop |
启动 MySQL 的“安全模式”:
$ safe_mysqld --skip-grant-tables & |
就可以不需要密码就进入 MySQL 了。
然后就是
$ mysql mysql> USE mysql mysql> UPDATE USER SET password=password("new_pass") WHERE USER="root"; mysql> FLUSH privileges; mysql> exit; |
现在可以杀掉 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 只显示每个文件的匹配行数
gcc命令行详解[转载]
gcc命令行详解[转载]
1.gcc包含的c/c++编译器
gcc,cc,c++,g++: gcc和cc是一样的,c++和g++是一样的。一般c程序就用gcc编译,c++程序就用g++编译。
2.gcc的基本用法
gcc test.c这样将编译出一个名为a.out的程序
gcc test.c -o test这样将编译出一个名为test的程序,-o参数用来指定生成程序的名字
3.为什么会出现undefined reference to ‘xxxxx’错误?
首先这是链接错误,不是编译错误,也就是说如果只有这个错误,说明你的程序源码本身没有问题,是你用编译器编译时参数用得不对,你没有指定链接程序要用到得库,比如你的程序里用到了一些数学函数,那么你就要在编译参数里指定程序要链接数学库,方法是在编译命令行里加入-lm。
4.-l参数和-L参数
-l参数 就是用来指定程序要链接的库,-l参数紧接着就是库名,那么库名跟真正的库文件名有什么关系呢?就拿数学库来说,他的库名是m,他的库文件名是libm.so,很容易看出,把库文件名的头lib和尾.so去掉就是库名了。
好了现在我们知道怎么得到库名了,比如我们自已要用到一个第三方提供的库名字叫libtest.so,那么我们只要把libtest.so拷贝到 /usr/lib里,编译时加上-ltest参数,我们就能用上libtest.so库了(当然要用libtest.so库里的函数,我们还需要与 libtest.so配套的头文件)。
放在/lib和/usr/lib和/usr/local/lib里的库直接用-l参数就能链接了,但如果库文件没放在这三个目录里,而是放在其他目录里,这时我们只用-l参数的话,链接还是会出错,出错信息大概是:“/usr/bin/ld: cannot find -lxxx”,也就是链接程序ld在那3个目录里找不到libxxx.so,这时另外一个参数-L就派上用场了,比如常用的X11的库,它放在 /usr/X11R6/lib目录下,我们编译时就要用-L/usr/X11R6/lib -lX11参数,-L参数跟着的是库文件所在的目录名。再比如我们把libtest.so放在/aaa/bbb/ccc目录下,那链接参数就是- L/aaa/bbb/ccc -ltest
另外,大部分libxxxx.so只是一个链接,以RH9为例,比如libm.so它链接到/lib/libm.so.x, /lib/libm.so.6又链接到/lib/libm-2.3.2.so,如果没有这样的链接,还是会出错,因为ld只会找libxxxx.so,所以如果你要用到xxxx库,而只有libxxxx.so.x或者libxxxx-x.x.x.so,做一个链接就可以了ln -s libxxxx-x.x.x.so libxxxx.so
手工来写链接参数总是很麻烦的,还好很多库开发包提供了生成链接参数的程序,名字一般叫xxxx-config,一般放在/usr/bin目录下,比如gtk1.2的链接参数生成程序是gtk-config,执行
gtk-config –libs
就能得到以下输出
“-L/usr/lib -L/usr/X11R6/lib -lgtk -lgdk -rdynamic -lgmodule -lglib -ldl -lXi -lXext -lX11 -lm”
这就是编译一个gtk1.2程序所需的gtk链接参数,xxx-config除了–libs参数外还有一个参数是–cflags用来生成头文件包含目录的,也就是-I参数,在下面我们将会讲到。你可以试试执行gtk-config –libs –cflags,看看输出结果。现在的问题就是怎样用这些输出结果了,最笨的方法就是复制粘贴或者照抄,聪明的办法是在编译命令行里加入这个`xxxx -config –libs –cflags`,比如编译一个gtk程序:gcc gtktest.c `gtk-config –libs –cflags`这样就差不多了。注意`不是单引号,而是1键左边那个键。
除了xxx-config以外,现在新的开发包一般都用pkg-config来生成链接参数,使用方法跟xxx-config类似,但xxx- config是针对特定的开发包,但pkg-config包含很多开发包的链接参数的生成,用pkg-config –list-all命令可以列出所支持的所有开发包,pkg-config的用法就是pkg-config pagName –libs –cflags,其中pagName是包名,是pkg-config–list-all里列出名单中的一个,比如gtk1.2的名字就是gtk+, pkg-config gtk+ –libs –cflags的作用跟gtk-config –libs –cflags是一样的。比如:gcc gtktest.c `pkg-config gtk+ –libs –cflags`。
5.-include和-I参数
-include用来包含头文件,但一般情况下包含头文件都在源码里用#i nclude xxxxxx实现,-include参数很少用。-I参数是用来指定头文件目录,/usr/include目录一般是不用指定的,gcc知道去那里找,但是如果头文件不在/usr/include里我们就要用-I参数指定了,比如头文件放在/myinclude目录里,那编译命令行就要加上- I/myinclude参数了,如果不加你会得到一个”xxxx.h: No such file or directory”的错误。-I参数可以用相对路径,比如头文件在当前目录,可以用-I.来指定。上面我们提到的–cflags参数就是用来生成-I 参数的。
6.-O参数
这是一个程序优化参数,一般用-O2就是,用来优化程序用的,比如gcc test.c -O2,优化得到的程序比没优化的要小,执行速度可能也有所提高(我没有测试过)。
7.-shared参数
编译动态库时要用到,比如gcc -shared test.c -o libtest.so
8.几个相关的环境变量
PKG_CONFIG_PATH:用来指定pkg-config用到的pc文件的路径,默认是/usr/lib/pkgconfig,pc文件是文本文件,扩展名是.pc,里面定义开发包的安装路径,Libs参数和Cflags参数等等。
CC:用来指定c编译器。
CXX:用来指定cxx编译器。
LIBS:跟上面的–libs作用差不多。
CFLAGS:跟上面的–cflags作用差不多。
CC,CXX,LIBS,CFLAGS手动编译时一般用不上,在做configure时有时用到,一般情况下不用管。
环境变量设定方法:
export ENV_NAME=xxxxxxxxxxxxxxxxx
9.关于交叉编译
交叉编译通俗地讲就是在一种平台上编译出能运行在体系结构不同的另一种平台上,比如在我们地PC平台(X86 CPU)上编译出能运行在sparc CPU平台上的程序,编译得到的程序在X86 CPU平台上是不能运行的,必须放到sparc CPU平台上才能运行。当然两个平台用的都是linux。这种方法在异平台移植和嵌入式开发时用得非常普遍。
相对与交叉编译,我们平常做的编译就叫本地编译,也就是在当前平台编译,编译得到的程序也是在本地执行。
用来编译这种程序的编译器就叫交叉编译器,相对来说,用来做本地编译的就叫本地编译器,一般用的都是gcc,但这种gcc跟本地的gcc编译器是不一样的,需要在编译gcc时用特定的configure参数才能得到支持交叉编译的gcc。
为了不跟本地编译器混淆,交叉编译器的名字一般都有前缀,比如sparc-xxxx-linux-gnu-gcc,sparc-xxxx-linux-gnu-g++ 等等
10.交叉编译器的使用方法
使用方法跟本地的gcc差不多,但有一点特殊的是:必须用-L和-I参数指定编译器用sparc系统的库和头文件,不能用本地(X86)的库(头文件有时可以用本地的)。
例子:
sparc-xxxx-linux-gnu-gcc test.c -L/path/to/sparcLib -I/path/to/sparcInclude