Monthly Archives: October 2005

如何挂载硬盘其他分区,且不要放在桌面上

可以将WINDOWS分区放在/windows中 

代码:
sudo mkdir /windows
sudo mkdir /windows/winc
sudo mkdir /windows/wind
sudo mkdir /windows/wine
sudo mkdir /windows/winf
sudo mkdir /windows/wing

然后修改/etc/fstab实现自动挂载,并且中文无乱码

#sudo gedit /etc/fstab 

代码:

/dev/hda1    /windows/winc    ntfs
user,nls=utf8,umask=0     0      0
/dev/hda5    /windows/wind    ntfs
user,nls=utf8,umask=0     0      0
/dev/hda6    /windows/wine    ntfs
user,nls=utf8,umask=0     0      0
/dev/hda7    /windows/winf    ntfs
user,nls=utf8,umask=0     0      0
/dev/hda8    /windows/wing    ntfs
user,nls=utf8,umask=0     0      0 

如果是FAT32格式,就用
/dev/hda7 /windows/winf vfat
user,utf8,umask=000 0 0

最后打开 程序-》系统工具-》配置,找到apps->nautilus->desktop
最后一项不要选就可以了,其他的你最好也选择下,会感觉比较舒服点

ubuntu更新地址

deb ftp://ftp.sjtu.edu.cn/sites/archive.ubuntu.com hoary main restricted universe multiverse

deb-src ftp://ftp.sjtu.edu.cn/sites/archive.ubuntu.com hoary main restricted universe multiverse

deb ftp://ftp.sjtu.edu.cn/sites/archive.ubuntu.com hoary-security main restricted universe multiverse

deb-src ftp://ftp.sjtu.edu.cn/sites/archive.ubuntu.com hoary-security main restricted universe multiverse

deb ftp://ftp.sjtu.edu.cn/sites/archive.ubuntu.com hoary-updates main restricted universe multiverse

deb-src ftp://ftp.sjtu.edu.cn/sites/archive.ubuntu.com hoary-updates main restricted universe multiverse

deb ftp://ftp.sjtu.edu.cn/sites/archive.ubuntu.com hoary-backports main restricted universe multiverse

Ubuntu快速设置指南

本文仅仅适用于采用i386安装光盘安装的系统,部分内容并不适合Amd64和PPC安装。
因为中间部分包没有相应的Amd64和PPC的对应包,因此会出现找不到该包的情况。
如果你是属于这样的系统,请到论坛咨询。

当你刚刚安装完毕之后,我们来花10分钟设置一下系统,让其有一个更加舒适的中文环境。

当你安装完毕后,进入,不论你进入的是中文,还是英文,都来和我一起来创建一个合适的环境。
如果您看到 "$", 的符号, 意思是你必须在终端状态下运行此命令. (应用程序 -> 系统工具 -> 终端)
"sudo" 的意思是为超级用户执行. "sudo" 需要提供密码 "Password:". 请输入您指定的用户密码
如果厌烦反复键入 "sudo" 可以通过键入 "sudo -s -H" 和您的密码转换到超级用户
修改你的源,并升级到最新的系统: 
sudo gedit /etc/apt/sources.list在编辑器里,删除所有东西,并在加上下面的行: 
deb http://archive.ubuntu.org.cn/ubuntu hoary main restricted universe multiverse
deb http://archive.ubuntu.org.cn/ubuntu hoary-security main restricted universe multiverse
deb http://archive.ubuntu.org.cn/ubuntu hoary-updates main restricted universe multiverse
deb http://archive.ubuntu.org.cn/ubuntu-cn hoary main universe multiverse restricted
deb http://archive.ubuntu.org.cn/ubuntu hoary-backports main universe multiverse restricted
deb http://archive.ubuntu.org.cn/backports hoary-extras main universe multiverse restricted

保存,关闭编辑器
系统升级(如果出现需要输入[Y/n] 或 [y/N] 一律输入 y 并 回车): 
sudo apt-get update
sudo apt-get dist-upgrade设置本地local环境: 
sudo dpkg-reconfigure locales  确保 zh_CN.UTF-8 被选择,同时也默认local为 zh_CN.UTF-8 
安装中文语言支持: 
sudo apt-get install language-pack-zh language-pack-zh-base language-support-zh
安装中文字体(如果出现需要输入[Y/n] 或 [y/N] 一律输入 y 并 回车):

sudo apt-get install ttf-arphic-newsung
sudo apt-get install ttf-vera-yuan安装输入法,你可以在SCIM和fcitx输入法中任选一种安装
SCIM: 
sudo apt-get install scim scim-gtk2-immodule scim-modules-socket scim-modules-table scim-pinyin scim-tables-zh scim-input-pad 
sudo sh -c " echo ‘export XMODIFIERS=@im=SCIM ; export GTK_IM_MODULE="scim" ; scim -d ‘ > /etc/X11/Xsession.d/95xinput "
sudo chmod +755 /etc/X11/Xsession.d/95xinput
fcitx: 
sudo apt-get install fcitx
sudo sh -c " echo ‘export XMODIFIERS=@im=fcitx ; export GTK_IM_MODULE="fcitx" ; 

fcitx ‘ > /etc/X11/Xsession.d/95xinput "
sudo chmod +755 /etc/X11/Xsession.d/95xinput

设置LC_ALL和其它属性: 
sudo gedit /etc/environment在编辑器里,将内容修改如下: 
LANGUAGE="zh_CN:zh:en_US:en"LC_ALL=zh_CN.UTF-8LANG=zh_CN.UTF-8GST_ID3_TAG_ENCODING=GBK保存,关闭编辑器
好了,注销一下电脑。(系统 -> 注销 -> 注销) 这时候,输入法 (按 Ctrl + 空格 键激活输入法) 都应该可以使用了,并且整个界面都是中文的了。

进一步设置:
安装JAVA环境(如果出现需要输入[Y/n] 或 [y/N] 一律输入 y 并 回车): 
sudo apt-get install sun-j2re1.5安装QQ:

wget -c http://lumaqq.linuxsir.org/download/2004/lumaqq_2004-linux_gtk2_x86_no_jre.tar.gz
sudo tar zxvf lumaqq_2004-linux_gtk2_x86_no_jre.tar.gz -C /opt/
wget -c http://lumaqq.linuxsir.org/download/patch/lumaqq_2004_patch_2005.05.09.13.55.zip
sudo unzip -o lumaqq_2004_patch_2005.05.09.13.55.zip -d /opt/LumaQQ/lib
sudo chown -R root:root /opt/LumaQQ/
sudo chmod -R 755 /opt/LumaQQ/
sudo gedit /usr/share/applications/LumaQQ.desktop在新增的文件内加入下面这几行 
[Desktop Entry]Name=LumaQQComment=QQ ClientExec=/opt/LumaQQ/lumaqqIcon

=/opt/LumaQQ/QQ.pngTerminal=falseType=ApplicationCategories=Application;Network;保存编辑过的文件 
安装完成后的快捷方式在(应用程序 -> internat -> LumaQQ)。

安装更好的多媒体播放驱动(如果出现需要输入[Y/n] 或 [y/N] 一律输入 y 并 回车): 
sudo apt-get install beep-media-player totem-xine w32codecs gstreamer0.8-plugins
在实际使用中,将所有的声音输出改为 esd 输出,如果不知如何修改,也可以参考如何混音 
安装英汉辞典(如果出现需要输入[Y/n] 或 [y/N] 一律输入 y 并 回车): 
sudo apt-get install stardict stardict-common stardict-cdict-gb stardict-cedict-gb stardict-hanzim stardict-langdao-ce-gb stardict-langdao-ec-gb stardict-oxford-gb stardict-xdict-ce-gb stardict-xdict-ec-gb安装完成后的快捷方式在(应用程序 -> 附件 -> 星际译王)

安装bt软件(如果出现需要输入[Y/n] 或 [y/N] 一律输入 y 并 回车):

sudo apt-get install azureus安装完成后的快捷方式在(应用程序 -> Internet -> azureus)
高级设置:
升级你的内核,让系统更快. 如果你的电脑是Inter芯片,则用如下命令: 
sudo apt-get install linux-686如果是AMD芯片,则使用: 
sudo apt-get install linux-k7

IIS网站防盗链下载的解决方案

什么是盗链

  “盗链”的定义是:此内容不在自己服务器上,而通过技术手段,绕过别人放广告有利益的最终页,直接在自己的有广告有利益的页面上向最终用户提供此内容。 常常是一些名不见经传的小网站来盗取一些有实力的大网站的地址(比如一些音乐、图片、软件的下载地址)然后放置在自己的网站中,通过这种方法盗取大网站的空间和流量。

  为什么会产生盗链

  一般浏览有一个重要的现象就是一个完整的页面并不是一次全部传送到客户端的。如果请求的是一个带有许多图片和其它信息的页面,那么最先的一个Http请求被传送回来的是这个页面的文本,然后通过客户端的浏览器对这段文本的解释执行,发现其中还有图片,那么客户端的浏览器会再发送一条Http请求,当这个请求被处理后那么这个图片文件会被传送到客户端,然后浏览器回将图片安放到页面的正确位置,就这样一个完整的页面也许要经过发送多条Http请求才能够被完整的显示。基于这样的机制,就会产生一个问题,那就是盗链问题:就是一个网站中如果没有起页面中所说的信息,例如图片信息,那么它完全可以将这个图片的连接到别的网站。这样没有任何资源的网站利用了别的网站的资源来展示给浏览者,提高了自己的访问量,而大部分浏览者又不会很容易地发现,这样显然,对于那个被利用了资源的网站是不公平的。一些不良网站为了不增加成本而扩充自己站点内容,经常盗用其他网站的链接。一方面损害了原网站的合法利益,另一方面又加重了服务器的负担。

  我遇到的盗链

  我的网站遇到最多的是两类盗链,一是图片盗链,二是文件盗链。曾经有一个访问量极大的网站盗链我网站的图片,一天竟然消耗了数G的流量。同时,我站放的不少几十兆的大型软件也常遭到文件盗链,大量消耗我站资源。

  盗链的解决方案

  其实通过WEB服务器的URL过滤技术,这个伤脑筋的问题会很容易得到解决。  

  如果WEB服务器用的是APACHE的话,那么使用APACHE自带的Url Rewrite功能可以很轻松地防止各种盗链,其原理是检查REFER,如果REFER的信息来自其他网站则禁止访问所需要的资源。

  那么,IIS支持UrlRewrite吗?

  答案很简单,不支持。但是我们可以通过安装第三方服务器扩展让IIS支持。 

  目前有一种产品能比较好地支持IIS的UrlRewrite,名字叫ISAPI_Rewrite。 

  下载地址在: http://www.helicontech.com/download/

  这里只有ISAPI Rewrite的一个LITE版本是免费的,其它都是trial版本。ISAPI Rewrite Lite的版本功能不支持虚拟站点配置,元数据监测和自动缓存清理。 但是基本的UrlRewrite功能都支持。

  如何进行UrlRewrite的设置? 

  isapi_rewrite利用正则表达式进行替换规则的表示。 

  下面是一个简单的例子,我想让我们的用户输入 http://localhost/test-12314.html 实际上访问的是 http://localhost/test.asp?id=12314 。那么我们的匹配表达式应该是 /test-([0-9]*).html 对应的格式化表达式应该为 /test.asp?id=$1 。 

  进行正则表达式的编写的时候,可以利用isapi_rewrite提供的正则表达式测试工具(默认安装提供),进行调试。做好了匹配表达式和格式化表达式,我们可以把它们放到安装目录下的httpd.ini里面。文件保存后,不需重新启动iis即可生效。 

  对于我的网站,我防盗链的方法是在httpd.ini里面加入如下语句

RewriteCond Host: (.+)

RewriteCond Referer: (?!http://1. *).*

RewriteRule .*.(?:gif|jpg|png|exe|rar|zip) /block.gif [I,O]

  然后重启IIS,这时防盗链就开始起作用了,其他网站盗链过来的请求都会被拒绝。

  至此,我也终于可以摆脱了被盗链的烦恼了。

正则表达式学习笔记

1、正则表达式的三种形式
首先我们应该知道 Perl 程序中,正则表达式有三种存在形式,他们分别是:

匹配:m/<regexp>/ (还可以简写为 /<regexp>/ ,略去 m)

替换:s/<pattern>/<replacement>/

转化:tr/<pattern>/<replacemnt>/

这三种形式一般都和 =~ 或 !~ 搭配使用(其中 "=~" 表示相匹配,在整条语句中读作 does,"!~" 表示不匹配,在整条语句中读作 doesn’t),并在左侧有待处理的标量变量。如果没有该变量和 =~ !~ 操作符,则默认为处理 $_ 变量中的内容。
另外还有:

foreach (@array) { s/a/b/; } # 此处每次循环将从 @array 数组中取出一个元素存放在 $_ 变量中,并对 $_ 进行替换处理。
while (<FILE>) { print if (m/error/); } # 这一句稍微复杂一些,他将打印 FILE 文件中所有包含 error 字符串的行。

替换操作 s/<pattern>/<replacement>/ 还可以在末尾加上 e 或 g 参数,他们的含义分别为:

s/<pattern>/<replacement>/g 表示把待处理字符串中所有符合 <pattern> 的模式全部替换为 <replacement> 字符串,而不是只替换第一个出现的模式。
s/<pattern>/<replacement>/e 表示将把 <replacemnet> 部分当作一个运算符,这个参数用的不多。

2 正则表达式中的常用模式
下面是正则表达式中的一些常用模式。

/pattern/  结果  
. 匹配除换行符以外的所有字符 
x? 匹配 0 次或一次 x 字符串 
x* 匹配 0 次或多次 x 字符串,但匹配可能的最少次数 
x+ 匹配 1 次或多次 x 字符串,但匹配可能的最少次数 
.* 匹配 0 次或一次的任何字符 
.+ 匹配 1 次或多次的任何字符 
{m} 匹配刚好是 m 个 的指定字符串 
{m,n} 匹配在 m个 以上 n个 以下 的指定字符串 
{m,} 匹配 m个 以上 的指定字符串 
[] 匹配符合 [] 内的字符 
[^] 匹配不符合 [] 内的字符 
[0-9] 匹配所有数字字符 
[a-z] 匹配所有小写字母字符 
[^0-9] 匹配所有非数字字符 
[^a-z] 匹配所有非小写字母字符 
^ 匹配字符开头的字符 
$ 匹配字符结尾的字符 
d 匹配一个数字的字符,和 [0-9] 语法一样 
d+ 匹配多个数字字符串,和 [0-9]+ 语法一样 
D 非数字,其他同 d 
D+ 非数字,其他同 d+ 
w 英文字母或数字的字符串,和 [a-zA-Z0-9] 语法一样 
w+ 和 [a-zA-Z0-9]+ 语法一样 
W 非英文字母或数字的字符串,和 [^a-zA-Z0-9] 语法一样 
W+ 和 [^a-zA-Z0-9]+ 语法一样 
s 空格,和 [ntrf] 语法一样 
s+ 和 [ntrf]+ 一样 
S 非空格,和 [^ntrf] 语法一样 
S+ 和 [^ntrf]+ 语法一样 
b 匹配以英文字母,数字为边界的字符串 
B 匹配不以英文字母,数值为边界的字符串 
a|b|c 匹配符合a字符 或是b字符 或是c字符 的字符串 
abc 匹配含有 abc 的字符串 
(pattern) () 这个符号会记住所找寻到的字符串,是一个很实用的语法。第一个 () 内所找到的字符串变成 $1 这个变量或是 1 变量,第二个 () 内所找到的字符串变成 $2 这个变量或是 2 变量,以此类推下去。  
/pattern/i i 这个参数表示忽略英文大小写,也就是在匹配字符串的时候,不考虑英文的大小写问题。 
 如果要在 pattern 模式中找寻一个特殊字符,如 "*",则要在这个字符前加上  符号,这样才会让特殊字符失效 
3、正则表达式的八大原则
  如果在 Unix 中曾经使用过 sed、awk、grep 这些命令的话,相信对于正则表达式(Regular Expression)不会感到陌生。下面给大家介绍几条正则表达式使用过程中的 8 大原则。 

正则表达式在对付数据的战斗中可形成庞大的联盟——这常常是一场战争。我们要记住下面八条原则:

· 原则1:正则表达式有三种不同形式(匹配(m/ /),替换(s/ / /eg)和转换(tr/ / /))。

· 原则2:正则表达式仅对标量进行匹配( $scalar =~ m/a/; 可以工作; @array =~ m/a/ 将把@array作为标量对待,因此可能不会成功)。

· 原则3:正则表达式匹配一个给定模式的最早的可能匹配。缺省时,仅匹配或替换正则表达式一次( $a = ‘string string2’; $a =~ s/string/ /; 导致 $a = ‘string 2’)。

· 原则4:正则表达式能够处理双引号所能处理的任意和全部字符( $a =~ m/$varb/ 在匹配前把varb扩展为变量;如果 $varb = ‘a’ $a = ‘as’,$a =~ s/$varb/ /; 等价于 $a =~ s/a/ /; ,执行结果使 $a = " s" )。

· 原则5:正则表达式在求值过程中产生两种情况:结果状态和反向引用: $a=~ m/pattern/ 表示 $a 中是否有子串 pattern 出现,$a =~ s/(word1)(word2)/$2$1/ 则“调换”这两个单词。

· 原则6:正则表达式的核心能力在于通配符和多重匹配运算符以及它们如何操作。$a =~ m/w+/ 匹配一个或多个单词字符;$a =~ m/d/" 匹配零个或多个数字。

· 原则7:如果欲匹配不止一个字符集合,Perl使用 "|" 来增加灵活性。如果输入 m/(cat|dog)/ 则相当于“匹配字符串 cat 或者 dog。

· 原则8:Perl用 (?..) 语法给正则表达式提供扩展功能。

(想要学习所有这些原则?我建议大家先从简单的开始,并且不断的尝试和实验。