来源:http://www.example.net.cn/2007/04/tuniu_copy.html
作者:于敦德
昨天还在看谷歌输入法跟搜狗输入法较劲,你来我往,好不热门,没想到今年互联网的开局竟然是以这种方式。
昨天晚上,同事给我一个网址,发现途牛旅游网的度假频道又被人抄袭了,我们的心里很是高兴。
度假频道专门为大众提供全国各大城市出发的度假线路预定,不同于携程网的机票加酒店,途牛的度假线路是大家最熟悉的,就在大家身边的旅行社参团或者独立成团线路预定。
途牛 度假线路页

某网站 度假线路页

途牛 度假线路比较页

某网站 度假线路比较页

途牛 文案细节

某网站 文案细节

为什么高兴呢?这证明我们的眼光是正确的,证明又多了一个伙伴认同了我们的理念加入到我们的阵营里来。我们开创了一个新的时代,在线旅游在经历过了高端市场的订票,订房后又迎来了更为广大的大众旅游预订市场。
我们继承并发扬了大众旅游的光荣传统,我们不是一个人在战斗,不是一个人!
这个网站不是第一个模仿我们的,也绝不会是最后一个模仿我们的。我们相信,只有充分的竞争才能让我们进步的更快。
虽然不断的有网站在模仿,但我们的创新永不停歇,无论是表面上的创新,还是深层次理念上的进步,我们始终保持着大规模的领先。后来的竞争让我们更加清醒,帮助我们去逐步建立起壁垒。
不过我也很为他们担心,毕竟跟随者成功的机会很小,要超越我们取得成功将会是多么困难的一件事情。
在线旅游市场正在变得日益成熟,随着携程开创了在线机票,酒店预定模式,以及艺龙、遨游、芒果的加入,在线旅游预定逐渐深入人心,为这个市场进一步深入发展奠定了良好的基础。
同时,我们认识到随着人均收入的提高,城镇化进程的加速,生活节奏的加快,以及旅游基础设施的逐步完善,奥运会、世博会的召开,老百姓对旅游的需求正在前所未有的增长,在线旅游预定以其透明、高效、舒适的优点日益被老百姓所接受,这个市场将在最近几年呈现井喷式的增长。
我们对未来的发展充满信心,让抄袭和模仿来的更猛烈一些吧。
我们的口号是:
//校验是否全由数字组成
代码
1. function isDigit(s)
2. {
3. var patrn=/^[0-9]{1,20}$/;
4. if (!patrn.exec(s)) return false
5. return true
6. }
//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串
代码
1. function isRegisterUserName(s)
2. {
3. var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;
4. if (!patrn.exec(s)) return false
5. return true
6. }
history.go(0);
location.reload();
location=location;
location.assign(location);
document.execCommand('Refresh');
window.navigate(location);
location.replace(location);
document.URL=location.href;
1、计划任务概说;
2、cron;
2.1 cron 的安装和启动;
2.1.1 在Redhat 或 Fedora等RPM包管理的系统的安装;
2.1.2 在Slackware系统中的安装;
2.1.3 cron 的开启、停止、重新启动方法;
2.2 cron 配置文件;
2.2.1 全局性配置文件;
2.2.2 cron 配置计划任务的书写格式
2.2.3 关于同一时间,同时执行多个任务的定义方法;
2.2.4 对于用户自身的cron 配置文件的说明;
3、计划任务的应用范围;
1、计划任务概说;
计划任务,是任务在约定的时间执行已经计划好的工作,这是表面的意思。在Linux中,我们经常用到 crond 服务器来完成这项工作。cron服务器可以根据配置文件约定的时间来执行特定的作务。比如我们可以在配置文件中约定每天早上4点,对httpd 服务器重新启动,这就是一个计划任务;
下面我们先来说说cron;
2、cron;
在Linux系统中,计划任务一般是由cron承担,我们可以把cron设置为开机时自动启动。cron启动后,它会读取它的所有配置文件(全局性配置文件/etc/crontab,以及每个用户的计划任务配置文件),然后cron会根据命令和执行时间来按时来调用度工作任务。
2.1 cron 的安装和启动;
在一般情况下,cron都是系统默认安装的,我们要学会查看软件包是否已经安装;
2.1.1 在Redhat 或 Fedora等RPM包管理的系统的安装;
判断系统是否已经安装cron相关的包
Fedora 5.0 系统的情况;
其它版本的Fedora及Redhat的系统和这相似;
[root@localhost ~]# rpm -qa |grep cron
vixie-cron-4.1-54.FC5
anacron-2.3-36.1
crontabs-1.10-7.1
其中vixie-cron软件包是cron的主程序,您可以通过下面的命令来了解它,其它软件包同理;
[root@localhost beinan]# rpm -ql vixie-cron
crontabs 软件包是用来安装、卸装、或列举用来驱动 cron 守护进程的表格的程序。cron 守护进程检查 crontab 文件来查看某个指定命令被调度执行的时间。如果命令已经调度,守护进程就会执行它们。了解crontabs软件包都安装了些什么,应该用下面的命令;
[root@localhost beinan]# rpm -ql crontabs
如果没有安装,可以从光盘中找出文件名带有cron字样的软件包来安装。
[root@localhost ~]# rpm -ivh vixie-cron-4.1-54.FC5*
[root@localhost ~]# rpm -ivh crontabs*
也可以用yum 来在线安装;
[root@localhost ~]# yum install vixie-cron
[root@localhost ~]# yum install crontabs
2.1.2 在Slackware系统中的安装;
在Slackware中cron软件包是 dcron,您可以在光盘中找出来安装它;
查看是否已经安装了dcron软件包,您可以这样查看。在这里能列出软件包详细的安装情况;
[root@localhost ~]# more /var/adm/packages/dcron*
如果没有安装,请用下面的命令来安装。在第一张安装盘中找出dcron软件包;
[root@localhost ~]# installpkg dcron*.tgz
2.1.3 cron 的开启、停止、重新启动方法;
cron配置文件被修改后,想让新文件生效,必须重新crond服务器,有两种方法可供选择;
第一种 在Fedora或Redhat 等以RPM包管理的系统中;
[root@localhost ~]# /etc/init.d/crond start
[root@localhost ~]# /etc/init.d/crond stop
[root@localhost ~]# /etc/init.d/crond restart
如果想在Fedora 和 Redhat 或以这些发行版为基础克隆的发行版,如果想自动开机运行,请用下面的办法;
[root@localhost ~]# chkconfig --levels 35 crond on
第二种:通用
[root@localhost ~]# pgrep crond 注:判断crond 是否在运行;
[root@localhost ~]# pkill crond 注:杀掉正在运行中的crond;
[root@localhost ~]# pgrep crond 注:查看是否被杀掉了;
[root@localhost ~]# /usr/sbin/crond 注:运行crond;
2.2 cron 配置文件;
cron 是一个服务器程序,我们都知道Linux的服务器的配置,大多是通过配置文件来完成的,cron自然也不例外,在Redhat/Fedora 等系统中它的全局性配置文件是/etc/crontab;在Slackware系统中,全局性文件是 /var/spool/cron/crontabs/root 。每个用户也有自己的cron配置文件,我们可以通过crontab -e 来编辑它;
2.2.1 全局性配置文件;
下面是一个全局性的配置文件例子,以Fedora Core 5为例;
[root@localhost ~]# more /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
HOME=/
# run-parts
1 * * * * root run-parts /etc/cron.hourly
#
2 4 * * * root run-parts /etc/cron.daily
#
22 4 * * 7 root run-parts /etc/cron.weekly
#
42 4 1 * * root run-parts /etc/cron.monthly
#
0,5,10,15,20,25,30,35,40,45,50,55 * * * * root /usr/bin/mrtg /etc/mrtg/mrtg.cfg
对于全局性配置文件,我们要用root权限来更改,一般是通过crontab -e 来修改。但有时也并不一定是这样的,比如Fedora Core 5 如果通过crontab -e 修改的是root用户的cron 配置文件。所以我们要在Fedora Core 5中修改全局性配置文件可以用vi 编辑器来修改。vi的用法请参考:《文件编辑器 vi》
在全局性配置文件中,定义了可执行命令的路径环境变量,所用SHELL类型的定义等,这些大多不用修改;我们经常添加的是计划任务或修改任务执行的时间等;
在全局性配置文件中,我们发现有类似这些行;
1 * * * * root run-parts /etc/cron.hourly 注:表示每个小时的第一分钟,开始执行/etc/hourly目录下的可执行程序或脚本;
2 4 * * * root run-parts /etc/cron.daily 注:表示每天的4点2分,开始执行/etc/cron.daily目录下的可执行程序或脚本;
22 4 * * 7 root run-parts /etc/cron.weekly 注:每年第7个周4点我22分,开始执行 /etc/cron.weekly目录下的可执行程序或脚本;
42 4 1 * * root run-parts /etc/cron.monthly 注:每月第1天的4点42分,开始执行/etc/cron.monthly目录下的可执行程序或脚本;
这些行是用来在同一时间批量执行任务的,我们在以后的例子中独立出来解说,在这里只是让大家心中有数;
2.2.2 cron 配置计划任务的书写格式
分钟 小时 日 月 周 [用户名] 命令
说明:
第一段应该定义的是:分钟,表示每个小时的第几分钟来执行。范围是从0-59
第二段应该定义的是:小时,表示从第几个小时来执行,范围是从0-23
第三段应该定义的是:日期,表示从每个月的第几天执行,范围从1-31
第四段应该定义的是:月,表示每年的第几个月来执行,范围从1-12
第五段应该定义的是:周,表示每周的第几天执行,范围从0-6,其中 0表示星期日。
每六段应该定义的是:用户名,也就是执行程序要通过哪个用户来执行,这个一般可以省略;
第七段应该定义的是:执行的命令和参数。
注:其中用户名可是省略,用户名定义的是程序用哪个用户来执行,比如mysql服务器,我们可以定义成以mysql用户来启动、停止、重新启动,这时要写上用户名;不过对于cron来说意义不是太大,因为每个用户都有自己的cron配置文件。有些程序的启动必须用到root用户,这时我们就可以修改 root用户的cron配置文件就行了。在每个用户的配置文件中,不必指定用户名。
我们可以把计划任务写在全局性配置文件中,如果您想把一个计划放入全局性配置文件中,就得改发行版所对应的cron全局配置文件,比如Fedora 5的全局性配置文件是/etc/crontab文件;
每个用户也能定义自己的cron配置文件,用crontab -e 命令来定义;
举一例:让机器在每天8点30分重新启动;
关于时间格式中有7个字段。我们可以直接更改或者添加,当然这是系统任务调用。举个例子,比如我在每天的早上8点30分重新启动机器,就可以在
/etc/crontab中加入下面的两句,第一句就是注释了。以#号开始,后面写一个自己能知道这是什么任务的备注;
# reboot OS
30 8 * * * root /sbin/reboot
第一段应该定义的是:分钟,表示每个小时的第几分钟来执行。范围是从0-59
第二段应该定义的是:小时,表示从第几个小时来执行,范围是从0-23
第三段应该定义的是:日期,表示从每个月的第几天执行,范围从1-31
第四段应该定义的是:月,表示每年的第几个月来执行,范围从1-12
第五段应该定义的是:周,表示每周的第几天执行,范围从0-6,其中 0表示星期日。
每六段应该定义的是:用户名,也就是执行程序要通过哪个用户来执行,这个一般可以省略;
第七段应该定义的是:执行的命令和参数。
对比上面的例子就知道,30是不是分钟??8是不是小时?如果有*代表的地方,表示全部,也就是说,每个月,每天,每星期都要执行。root 表示用root用户执行,命令是/sbin/reboot ,也就是说,系统在每天 8点30分重新启动;
我们可以把每天8点30分重新启动的计划任务写入cron全局性配置文件中,也可以定义在root用户自己的cron配置文件中。如果定义在root自己的配置文件,请用root身份来执行 crontab -e 来修改配置文件;crontab -e 进入修改配置文件的过程,其实和vi的用法一样,请参看vi 的用法:《文件编辑器 vi》
让配置文件生效:如果让配置文件生效,还得重新启动cron,切记,既然每个用户下的cron配置文件修改后。也要重新启动cron服务器。
在Fedora 和Redhat中,我们应该用;
[root@localhost ~]# /etc/init.d/crond restart
如果让crond 在开机时运行,应该改变其运行级别;
[root@localhost ~]# chkconfig --levels 35 crond on
在Slackware中,如果开机自动运行;
查看/etc/rc.d/rc.M文件是否有如的行,如果没有就加上,大多是有的;
# Start crond (Dillon's crond):
if [ -x /usr/sbin/crond ]; then
/usr/sbin/crond -l10 >>/var/log/cron 2>&1
如果想让立即让cron重启生效,也可以用下面的办法;
[root@localhost ~]# pgrep crond 注:查看crond服务器是否运行;
2022
[root@localhost ~]# pkill crond 注:杀死crond;
[root@localhost ~]# pgrep crond 注:查看crond是否退出;
[root@localhost ~]# /usr/sbin/crond 注:启动crond;
[root@localhost ~]# pgrep crond 注:查看crond 是否已经运行得起来了;
3883
2.2.3 关于同一时间,同时执行多个任务的定义方法;
我们在前面已经说过,在全局性配置文件中,有类似如下的段落;
1 * * * * root run-parts /etc/cron.hourly 注:表示每个小时的第一分钟,开始执行/etc/hourly目录下的可执行程序或脚本;
2 4 * * * root run-parts /etc/cron.daily 注:表示每天的4点2分,开始执行/etc/cron.daily目录下的可执行程序或脚本;
22 4 * * 7 root run-parts /etc/cron.weekly 注:每年第7个周4点我22分,开始执行 /etc/cron.weekly目录下的可执行程序或脚本;
42 4 1 * * root run-parts /etc/cron.monthly 注:每月第1天的4点42分,开始执行/etc/cron.monthly目录下的可执行程序或脚本;
举例来说,我想在每天5点10分来重新启动httpd 服务器,与此同时,我们也可以同时下载一个ISO文件。如果我们按书写计划任务的规则一条一条的来书写,并添加到全局是有点麻烦。不如写一个脚本放在 /etc/crond.daily目录中。然后把其权限设置为755 (关于权限的设置,请参考:《Linux 文件和目录的属性》)。
当然我们得改一改上面的 带有/etc/cron.daily那行,改为如下;
10 5 * * * root run-parts /etc/cron.daily
然后我们到/etc/crond.daily目录中创建两个文件,一个是用来重启httpd服务器的,如下;
[root@localhost cron.daily]# touch httpd.sh
[root@localhost cron.daily]# chmod 755 httpd.sh
[root@localhost cron.daily]# echo "/etc/init.d/httpd restart" > httpd.sh
[root@localhost cron.daily]# more httpd.sh
/etc/init.d/httpd restart
如果我想在每天5点20分下载FC5的镜像,可以再创建一个文件fc5down.sh
[root@localhost cron.daily]# touch fc5down.sh
[root@localhost cron.daily]# chmod 755 fc5down.sh
[root@localhost cron.daily]# echo "/usr/bin/wget [url]http://mirrors.kernel.org/fedora/core/5/i386/iso/FC-5-i386-DVD.iso[/url]" > fc5down.sh
[root@localhost cron.daily]# more fc5down.sh
/usr/bin/wget [url]http://mirrors.kernel.org/fedora/core/5/i386/iso/FC-5-i386-DVD.iso[/url]
然后我们重新启动一下crond就行了;
[root@localhost cron.daily]# pkill crond
[root@localhost cron.daily]# prep crond
[root@localhost cron.daily]# crond&
注意:我只是想说明一下,在同一时间执行多个计划任务的简单用法,并不是有意教给您每天早上都下载FC5的映像。我举这个例子是为了初学者了解这个功能。如果您有好多的任务在某一时刻执行,那就自己写脚本文件。放在/etc目录下的cron.hourly 、cron.daily 、cron.weekly 、cron.monthly 目录中。凡是放进这些目录的可执行脚本,都能在约定的时间内准确执行。每个目录有每个目录的用途;
2.2.4 对于用户自身的cron 配置文件的说明;
每个用户都有自己的cron配置文件,通过crontab -e 就可以编辑,一般的情况下,在Fedora和Redhat的发行版,我们编辑好用户的cron配置文件保存退出后,系统会自动就存放于 /var/spool/cron/目录中,文件以用户名命名。在Slackware中是位于/var/spool/cron/crontabs/目录中。其它的发行版都差不多,有点类似。自己找找吧;查看用户的计划任务是crontab -l
crontab -e 注:编辑用户的cron配置文件;
crontab -l 注:查看用户的计划任务;
比如我用beinan用户来运行crontab -e ;
[beinan@localhost ~]$ id 注:判断所用用户身份;
uid=500(beinan) gid=500(beinan) groups=500(beinan)
[beinan@localhost ~]$ crontab -e 注:编辑用户beinan的计划任务;
我们在里面定义一个任务;
40 20 * * * /usr/bin/wget [url]http://mirrors.kernel.org/fedora/core/5/i386/iso/FC-5-i386-DVD.iso[/url]
保存退出后,我们用下面的命令来查看beinan用户的计划任务;
[beinan@localhost ~]$ crontab -l
40 20 * * * /usr/bin/wget [url]http://mirrors.kernel.org/fedora/core/5/i386/iso/FC-5-i386-DVD.iso[/url]
配置好后,我们还要重新启动crond服务器,每个用户cron配置文件的改动都得重新启动crond服务器;前面已经说过了,这里省略;值得注意的是重启crond服务器,需要root权限,您可以用su命令切换到root 用户,然后再来重启crond;
在Fedora或Redhat等以RPM包管理的发行版中;
[beinan@localhost ~]$ su
口令:
[root@localhost beinan]# /etc/init.d/crond restart
停止 crond: [确定]
启动 crond: [确定]
也可以先杀死crond,再运行crond命令的办法来启动;
[root@localhost beinan]# pkill crond
[root@localhost beinan]# pgrep crond
[root@localhost beinan]# /usr/sbin/crond
[root@localhost beinan]# pgrep crond
6664
3、计划任务的应用范围;
计划任务主要是让系统自动完成一些工作。比如我们可以让系统自动在某一时刻清理或备份httpd服务器的日志,然后重新启动httpd服务器,这对网络管理员来说是很重要的。也可以让系统自动清空位于/tmp目录的垃圾文件。
另外值得一提的是,LinuxSir.Org 有很多子站,每个子站都有RSS,能让这些站点的RSS相互投递,也是用cron来完成,比如是在早上4点左右开始执行这个任务。这是一个极为耗费资源的过程,如果不是放在在线人少的时候,基本无法完成,所以只能放在早上进行。作为SIR的管理员,不可能每天早上4点起来点鼠标来完成这些事吧。所以最好的办法就是通过cron来自动运行,以在服务器最清闲的时候来完成这项工作;
最近频繁从hotmail上收到一家公司的垃圾邮件,还挺人性化的。第一封是用我msn上中学同学的口气写的,慰问一下春节什么时候回家。刚看标题还挺高兴的,远大大洋彼岸的老同学还想到我了,打开一看,有个网站的链接地址,让我点进去看更多内容。呵呵,本身就是做互联网的,对这一张很熟悉了,于是不予理睬。过了几天,又来了一封邮件,标题是“你怎么不理我啊”,内容还是一样。继续删除之。接下来的几天又陆续收到几封邮件,标题成了“今年过年回家吗?”。不明白真相的人,说不定就点了链接。
现在的网站在推广上可谓是费劲心机啊,不过还真佩服他们,这么人性化的垃圾邮件也亏他们想的出来。这让我想起了最近手机一直收到的垃圾短信一样。从最初直接的广告,过渡到暧昧的语言,然后又过渡到朋友的问候,最近收到的是模仿运营商的口气写的:“你上个月的话费金额达到我们抽奖的标准,......”。哈哈,我一个月的话费还不到50,这也能抽奖,那天上还真的掉馅饼了。最近的垃圾短信越来越来频繁,越来越容易让人上当,真想抽这些SP运营商。打电话到联通投诉,竟然说不归他们管,我ft,难道这些广告从天上掉到我手机上的。天天看新闻说整治不规范的SP,怎么越整治越多了,现在政府的办事效率真TMD不能相信。到最后拉出几个替罪羊就说整治取得了很大的成果。就象今天晚上刚看到msn中的一条新闻一样,“国家重拳打击网络侵权 公布十大典型案件”。。。。。。无语啊!
睡觉......
1月30日中午,中国互联网协会发布了《INTERNET GUIDE 2007中国互联网调查报告》的10个分类领域市场规模数据和增长率,包括互联网招聘、电子邮件、游戏资讯、交友服务、网络安全、数字杂志、旅行预定市场等。此前中国互联网协会已经公布了综合门户、博客、网络广告等前10个领域数据。
本次调查于2006年6月开始,12月底结束,历时半年,是中国互联网发展领域每年一度规模最大的市场调查。本次调查为第三届,由中国互联网协会主办,由DCCI互联网数据中心负责实施。
报告显示,在10个公布的所有热点领域中,其2007年的增长率均超过了30%,其中互联网音乐服务(不包括彩铃等SP业务)的增长率达到了132%,显示了良好的发展前景。
中国互联网协会30日公布的10个热点领域的市场规模和2007年增长率,依次为:
2006中国互联网旅行预订服务商营收规模达13.6亿元,2007预计增长41.2%
2006中国互联网房地产服务服务商营收规模达5.6亿元,2007预计增长30.4%
2006中国互联网人才招聘服务服务商营收规模达13.7亿元,2007预计增长40.5%
2006中国互联网电子邮件服务服务商营收规模达8亿元,2007预计增长18.5%
2006中国互联网游戏资讯服务服务商营收规模达1亿元,2007预计增长48%
2006中国互联网音乐服务营收规模1.38亿元,2007预计增长132%
2006中国互联网视频点播/直播市场营收规模达6亿元,2007预计增长33.3%
2006中国互联网交友服务营收规模3.85亿元,2007预计增长51.2%
2006中国互联网网络安全服务商营收规模58.5亿元,2007预计增长38.5%
2006中国互联网数字杂志服务商营收规模1.02亿元,2007预计增长56.9%
新浪科技讯 1月10日上午10:30,中国互联网协会发布了《INTERNET GUIDE 2007中国互联网调查报告》,其中包括综合门户、博客、搜索引擎、网络广告、网络游戏、电子商务、即时通讯等50个细分领域的用户达到率及市场规模,这也是2006年度中国互联网多项关键市场数据首度披露。
本次调查于2006年6月开始,12月底结束,历时半年,是中国互联网发展领域每年一度规模最大的市场调查。本次调查为第三届,由中国互联网协会主办,由DCCI互联网数据中心负责实施。
报告指出,用户年到达率指某项互联网服务过去一年中所到达的使用过该服务的用户的数量占中国互联网用户总规模的相对比例,该比例最大不超过100%,统计以单一用户(而非IP)为基本单位。
互联网协会今日公布了10个热点领域的用户年达到率数据排名,依次为:
一,门户:新浪:55.53% 网易:51.31% 腾讯:48.02%
二,博客:新浪:32.86% Qzone:19.28% MSN:15.8%
独立博客:博客网:11.66% 中国博客网:11.65% 博易:3.32%
三,即时通讯:QQ:78.73% MSN:34.37% 新浪UC:11.38%
四,搜索:百度:80.79% Google:36.38% 雅虎:25.99%
五,汽车网站:新浪汽车:16.76% 搜狐汽车:11.65% 太平洋汽车:10.67%
独立汽车网站:太平洋汽车网:10.67% 中国汽车网:8.89% 汽车之家:7.94%
六,
网络游戏运营商:QQ:36.89% 联众:20% 盛大:19.86%
独立网络游戏运营商:联众:20% 盛大:19.86% 世纪天成:10.3%
七,播客/视频分享:土豆网:9.86% 优酷:8.91% Mofile:8.7%
八,C2C电子商务:淘宝网:55.29% eBay易趣:36.51% 拍拍网:20.48%
九,不同媒介网络广告:电子邮件广告:14.84% 门户广告:14.39% 新闻网站广告:13.99%
十,地图服务:百度:32.55%
中国电子地图网:18.95% 图行天下:10.76%
独立地图服务商:中国电子地图网:18.95% 图行天下:10.76% 中华地图网:10.1%
我今天想跟大家讲一个小故事:
深圳公司的西侧洗手间比其它楼层的洗手间特别,只有二间,男女共用、先到先得、注意锁门就行。洗手间里都有手纸篓,在过去的一周里我跟清洁工进行了一场看不见的互动。因为,我发现里面那间的手纸篓是放在你的左后方的,不知道你们使用那洗手间时有什么感觉没有?就是当你扔手纸的时候,你必需逆时针扭身,手纸从你面前划过才能扔进纸篓;或者顺时针向后扭身而且还必须认真看着才能把手纸扔进纸篓,否则扔出界就不好了,你还得再拾一下。这种方式你们不觉得别扭和难受吗?除非你们是左撇子罗,嘿嘿。。。
这是个用户体验问题,可能我之前一直使用的是外面那间,也没啥感觉,当我最近开始用另一间的时候,感受马上不同!所以,我把纸篓踢到另一边,就是你的右后方。第二天我发现又跑回原位的,肯定是清洁工干的,她印象中纸篓是放在左后方的,所以要移回去。我又把它踢到另一边,第三天发现它又回原位了。当然,我还是把它踢到另一边。第四天一整天,我发现它没移动过,这意味着什么?就是那清洁工已经意识到这是“用户需求”,这是一种强烈的需求,她不去坚持。大家可以去看看,如果纸篓在左后方,这清洁工就是个坚执的人,如果一直放在右后方,那她就是明事理有感觉的人,如果她的leader知道这件小事,应该表扬她!不过,我们的同事为什么没有人去“改变它”?!
OK,大家一直看过来的时候有没有什么感觉?这二间洗手间就是二个网站,符合用户使用习惯的在使用时没有什么感觉,那是好事,那证明网站的设计已经融入了用户的习惯中去,已经成为用户生活中的一部份,就象左手摸右手。而当用户离开这个“网站”去另一个同质化的“网站”时,虽然“网站”基本功能是一样的,却会因为一个“手纸篓”的摆放位置而使这个用户产生很大的不便。或许用户会参与改进体验,提一些善意的建议(把纸篓踢到另一边),我们的策划人员、开发人员,就是清洁工,如果一而再再而三的不吸引用户体验建议,那这个洗手间(网站)的使用率就会低,如果再发生点其它问题的话,估计就就没人会用了。而大家有没有想过,这样主动的用户会有多少?我相信更多的是抛弃这个“网站”,那我们的推广成本无形中会增加多少?
我们早已知道,网站的质量在Google中起关键作用。高级Google工程师Matt Cutts在他的blog中多次提到,“优质”对于Google至关重要,无论是内容还是连接。
不过,创建内容和连接并不一定要经历痛苦的过程。网站搭建者们开始趋于从某些角度考虑如何组织内容。所以,让我们放开创新的思维,来想一想所有这些给网站添加优质内容的方法吧。
请先记住以下几点:
你只是被你自己的想法和你的网站限制住了。尝试着往完全不同的方向探索一下。
你的网站内容应该是写给你的顾客看,而不是给你。网站内容也不是写给搜索引擎的,它们不是你的目标群体。
把你的网站想象成一幅完整的画,一个有生命的会呼吸的整体。它会持续成长,而不是停滞不前。
现在我们进入正题了:面向目标群体的优质内容。
1,事件日历。对于房地产网站,它可用于展示新开房屋信息;对于在线书店,可用于介绍新书签名会、作者见面会等;对于收藏类网站,可用于介绍最近的聚会活动等……确保访客能添加他们自己的事件到日历中去。
2,地图。考虑给房地产网站、捕猎/捕鱼网站、露营网站、酒店或者其他任何户外休闲网站建一个地图。在地图的底部添加内容来描述该地图并说明它的意图。
3,售前/售后经历。如果你的顾客能就你提供的产品或服务写一小段文字,或者探讨你的产品/服务带来的好处,就再好不过了。你可以把它们作为成功的证明放在网站上。
4,来自顾客的图片。你可以为已有顾客设立一个特别的地方,让他们能够在你的网站贴出自己的图片和日志等等。这个方法比较适合度假网站、休闲网站、婚姻网站、宝宝网站、摄影工作室等等。想一想,在Halloween网站该怎么做?花卉网站呢?
5,在线填色画。发挥你的想象力。如果你将一些度假物品做成填色画,孩子们就可以在旅程开始前给它们填完色然后贴到他们在网上专有的版块。旅程结束后,他们的父母又可以贴上度假的图片和日志。这样,一个属于他们的度假纪念“网站”(其实完全是建立在你的网站上)就成为了你这个度假网站的招牌。他们会怎么使用这个“网站”呢?他们会告诉朋友、爷爷奶奶、叔叔婶婶等等。他们会在其他地方给这个“网站”做连接。你可以把这个招牌作为独特的核心卖点来跟对手竞争。你将会获得以往顾客过来的连接和未来顾客的浏览。你会赢得优势。如果网站可以作孩子们的文章,你可以想很多增添填色画的方法,或者类似的针对孩子的创造性活动。
6,blog或论坛当然会给网站增添新内容。
7,令你的目标群体感兴趣的文章或者新页面。有规律的写出新内容——你的目标应该是每周1-2篇。
8,在站内主页展示专家问答。请个专家来回答问题,然后每周在主页贴出一问一答(或者每天都贴出,自由控制)。把站上以往的问答做个可搜索的归档。
9,产品评测。如果你的行业有产品或软件需要评测,可考虑写一些公正的评测文章。将文章发布到自己的网站和在线刊物上。读者永远都会对完整的公正评测感兴趣,因为作者不失偏颇的列出产品的优点与弱点。如果你手头的是风景区业务,应该如何去“评测”呢?作为专家的你将会使用什么产品呢?为什么?
10,小提示。如果你的产品或服务适合用小提示,就写一个系列并把它们发布到你的网站上。作为新闻信来发送。邀请使用你的产品的读者也来写小提示/技巧,如果他们提交过来,就给他们一些购买其他产品的优惠/折扣。
11,常见问题。常见问题(FAQ)是你的目标群体想要了解的内容。当你从读者那里收到提问,就在FAQ里面添加新的问答内容,使它保持更新。
12,使用手册/指引。人们喜欢看使用手册。如果你正在线销售抽水马桶部件,为何不写一份关于“如何在卫生间安装抽水马桶”的指导手册呢?为你的顾客提供便利,客人就会源源不断。撰写一系列的使用手册。做一个网络上的“厕所超人”。听着这好像不够有魅力,不过如此一来你就会被高度关注,并能将网站访问流量转化为销售,你会在互联网以外魅力十足。
13,能够解决实际问题的内容。人们为何访问互联网?为了寻找信息或者对比购物。如果你能为你的访客解决这些问题,就帮他们达到了目的。举例说,你在卖东方的小毯子。你的潜在顾客可能正寻求点子如何装饰她的办公室。她的办公室很狭小,她想要增加点颜色。墙壁的大部分都被窗子和金属书橱占据了。如果你创造出一系列内容/图片来展现你的东方小毯子能如何的解决她的问题,其中一个例子里提到长条形的东方地毯。这些内容不但包含图片,还有文字描述各个问题并给出解决方案。你的潜在顾客自然能从搜索引擎里找到你的页面。
14,历史数据。这次假设你是销售钢管的。钢管的历史是怎样的?创建一个页面专门介绍一下它的历史吧。事实上,你还应该创建关于以下内容的页面:钢管和铜管以及其他种类的金属管的比较;为何会生锈;钢的硬度如何;钢管的实际价值(钢管是如何在近乎每个建筑物中使用的,等等);钢的寿命;等等等等,所有这些构成一个版块,将是整个网站非常有价值的组成。
注意,问题来了。这些内容对钢管公司的目标群体是否也有有价值?试想一个目标群:全美国的职业教育培训班。这对他们来说可是个有利资源。如果他们连接到这个网站,都是.edu的网站,是不是会给网站很高的连接欢迎度?想一想看。我们谈的是优质的内容和优质连接。
再举个一个历史数据的例子,圣西蒙岛上的一家旅店。这样一家旅店当然应该在它的网站上提供关于这个岛屿的历史和旅游信息等等。
一家销售Mustang软管部件的网站该如何运用这个策略?销售婚纱礼服的网站呢?
15,采访。制造内容的最简单手段。采访你所在行业内的一位专家。给他列出问题,让专家用自己的话回答。除了纠正拼写错误或者语法错误,不要删改专家的回答。与专家坦诚相待,并保持采访文章的完整性。写出一系列采访文章,并在你的网站主要页面上高亮表示出来。
16,季节性文章。你的行业是否也有“季节性”?如果有,季节性文章常常会很受欢迎。
17,统计。在你的网站上提供统计数据也是一种增加内容的方式。如果统计数据不是来自你自己,则往往会告诉你信息是从哪里来的。引用这些信息来源!金融或者资产抵押网站如何运用这个策略?
18,建议专栏。这可以用在约会网站,也可用在其他网站。SEO网站如何运用此战略?室内装潢网站或者整形手术网站呢?
19,每月冠军。假设你经营一个销售插花的网站。邀请你的顾客发送过来他们用你的花设计的花束的照片等等。把照片公布在网上。每个月选出一个优胜者,并把他的照片放在网站的显要页面。给优胜者颁发价值25美元的礼品作为获奖证书。
20,用花店的例子,制作一些关于如何插花的视频教程。确保观众照着教程做的时候所有的材料都可以在你的店里买到。
21,还是拿花店举例。邀请顾客提供一些心得,比如他们是如何制作插花的,用到了哪些材料,以及照片等等。把这些信息放到你的网站上。相关的材料就连接到你的在线商店。发挥创意。在你的行业里你该怎么做?如果你有一个戏装网站,该怎么做?艺术品网站呢?动动脑筋,把这个策略用到狩猎或者捕鱼网站。
22,每月送出一封新闻信,附上你想告诉顾客的那些信息。可以是来自顾客的小技巧、销售中的产品、假期计划、每月冠军等等。把过去的新闻信也贴在网站上,增加内容。
23,重要人物的传记。如果与你的行业相关,你就可以这么做。比如你经营一个关于美国内战历史的网站或者一个旧书店,这就非常有用。
24,新闻事件。因你的所在行业而异。
25,与社群相关的页面。如果这是个本地网站,比如,你可以在社群相关的页面或者blog上讨论本地的餐馆、棒球联盟、校园开幕式等等。
我们还只是列举出这些点子,开了个头。所有都要根据你的所在行业、你的产品或者服务而不同。你还需要集思广益。
结论…
创建内容时记住“优质”。上面这些点子应该可以帮你开始了。
然后也想想下面这些问题。如果你开始创建优质内容,接下来是什么?优质的连接。其他网站会开始连向你的内容,因为你做了你该做的:为你的顾客提供了他们所需。他们需要看到优质的、持续更新的信息。你成了可信赖的信息来源。
不要试图走“捷径”。成功来自辛勤的劳动。
关于作者:
Robin Nobles是搜索引擎营销专栏作家,她在北美的Training of Search Engine Workshops多处分支机构担当主讲,后者甚至已经将业务扩张到欧洲。
原文:25 Ways to Add Quality Content to Your Web Site
翻译:孙波(Flavien)
来源:http://weblog.flaviensun.com
window.navigate("URL")适用于IE,firefox不支持navigate 方法
所以采用location.href=URL;在IE和firefox下均能运行
在做列车时刻表时遇到的问题
表名:train_lines_part
字段:
line_id 列车车次
station_id 站台ID
。。。。其他略
想查询经过站台2和站台4的所有列车
方法一:
SELECT * , count( * ) AS num FROM `train_lines_part` WHERE station_id =2 OR station_id =4 GROUP BY line_id HAVING num =2
方法二:
select a.line_id from train_lines_part a,train_lines_part b where a.station_id=2 and b.station_id=4 and a.line_id=b.line_id
方法三:
SELECT * FROM (select * from train_lines_part where station_id=2) as from_station where station_id=4
方法一查询花费 0.0008 秒
方法二查询花费 0.0013 秒
方法三查询花费 0.0008 秒
字符描述
\
将下一个字符标记为一个特殊字符、或一个原义字符、或一个后向引用、或一个八进制转义符。例如,'n' 匹配字符 "n"。'\n' 匹配一个换行符。序列 '\' 匹配 "" 而 "\(" 则匹配 "("。
^
匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 '\n' 或 '\r' 之后的位置。
$
匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性,$ 也匹配 '\n' 或 '\r' 之前的位置。
*
匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。 * 等价于{0,}。
+ 匹配前面的子表达式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。
?
匹配前面的子表达式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 中的"do" 。? 等价于 {0,1}。
{n}
n 是一个非负整数。匹配确定的 n 次。例如,'o{2}' 不能匹配 "Bob" 中的 'o',但是能匹配 "food" 中的两个 o。
{n,}
n 是一个非负整数。至少匹配n 次。例如,'o{2,}' 不能匹配 "Bob" 中的 'o',但能匹配 "foooood" 中的所有 o。'o{1,}' 等价于 'o+'。'o{0,}' 则等价于 'o*'。
{n,m}
m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。刘, "o{1,3}" 将匹配 "fooooood" 中的前三个 o。'o{0,1}' 等价于 'o?'。请注意在逗号和两个数之间不能有空格。
?
当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。例如,对于字符串 "oooo",'o+?' 将匹配单个 "o",而 'o+' 将匹配所有 'o'。
.
匹配除 "\n" 之外的任何单个字符。要匹配包括 '\n' 在内的任何字符,请使用象 '[.\n]' 的模式。
(pattern)
匹配pattern 并获取这一匹配。所获取的匹配可以从产生的 Matches 集合得到,在VBScript 中使用 SubMatches 集合,在JScript 中则使用 {CONTENT}… 属性。要匹配圆括号字符,请使用 '\(' 或 '\)'。
(?:pattern)
匹配 pattern 但不获取匹配结果,也就是说这是一个非获取匹配,不进行存储供以后使用。这在使用 "或" 字符 (|) 来组合一个模式的各个部分是很有用。例如, 'industr(?:y|ies) 就是一个比 'industry|industries' 更简略的表达式。
(?=pattern)
正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如, 'Windows (?=95|98|NT|2000)' 能匹配 "Windows 2000" 中的 "Windows" ,但不能匹配 "Windows 3.1" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始。
(?!pattern)
负向预查,在任何不匹配Negative lookahead matches the search string at any point where a string not matching pattern 的字符串开始处匹配查找字符串。这是一个非获取匹配,也就是说,该匹配不需要获取供以后使用。例如'Windows (?!95|98|NT|2000)' 能匹配 "Windows 3.1" 中的 "Windows",但不能匹配 "Windows 2000" 中的 "Windows"。预查不消耗字符,也就是说,在一个匹配发生后,在最后一次匹配之后立即开始下一次匹配的搜索,而不是从包含预查的字符之后开始
x|y
匹配 x 或 y。例如,'z|food' 能匹配 "z" 或 "food"。'(z|f)ood' 则匹配 "zood" 或 "food"。
[xyz]
字符集合。匹配所包含的任意一个字符。例如, '[abc]' 可以匹配 "plain" 中的 'a'。
[^xyz]
负值字符集合。匹配未包含的任意字符。例如, '[^abc]' 可以匹配 "plain" 中的'p'。
[a-z]
字符范围。匹配指定范围内的任意字符。例如,'[a-z]' 可以匹配 'a' 到 'z' 范围内的任意小写字母字符。
[^a-z]
负值字符范围。匹配任何不在指定范围内的任意字符。例如,'[^a-z]' 可以匹配任何不在 'a' 到 'z' 范围内的任意字符。
\b
匹配一个单词边界,也就是指单词和空格间的位置。例如, 'er\b' 可以匹配"never" 中的 'er',但不能匹配 "verb" 中的 'er'。
\B
匹配非单词边界。'er\B' 能匹配 "verb" 中的 'er',但不能匹配 "never" 中的 'er'。
\cx
匹配由x指明的控制字符。例如, \cM 匹配一个 Control-M 或回车符。 x 的值必须为 A-Z 或 a-z 之一。否则,将 c 视为一个原义的 'c' 字符。
\d
匹配一个数字字符。等价于 [0-9]。
\D
匹配一个非数字字符。等价于 [^0-9]。
\f
匹配一个换页符。等价于 \x0c 和 \cL。
\n
匹配一个换行符。等价于 \x0a 和 \cJ。
\r
匹配一个回车符。等价于 \x0d 和 \cM。
\s
匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。
\S
匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。
\t
匹配一个制表符。等价于 \x09 和 \cI。
\v
匹配一个垂直制表符。等价于 \x0b 和 \cK。
\w
匹配包括下划线的任何单词字符。等价于'[A-Za-z0-9_]'。
\W
匹配任何非单词字符。等价于 '[^A-Za-z0-9_]'。
\xn
匹配 n,其中 n 为十六进制转义值。十六进制转义值必须为确定的两个数字长。例如, '\x41' 匹配 "A"。'\x041' 则等价于 '\x04' & "1"。正则表达式中可以使用 ASCII 编码。.
\num
匹配 num,其中 num 是一个正整数。对所获取的匹配的引用。例如,'(.)' 匹配两个连续的相同字符。
\n
标识一个八进制转义值或一个后向引用。如果 \n 之前至少 n 个获取的子表达式,则 n 为后向引用。否则,如果 n 为八进制数字 (0-7),则 n 为一个八进制转义值。
\nm
标识一个八进制转义值或一个后向引用。如果 \nm 之前至少有is preceded by at least nm 个获取得子表达式,则 nm 为后向引用。如果 \nm 之前至少有 n 个获取,则 n 为一个后跟文字 m 的后向引用。如果前面的条件都不满足,若 n 和 m 均为八进制数字 (0-7),则 \nm 将匹配八进制转义值 nm。
\nml
如果 n 为八进制数字 (0-3),且 m 和 l 均为八进制数字 (0-7),则匹配八进制转义值 nml。
\un
匹配 n,其中 n 是一个用四个十六进制数字表示的 Unicode 字符。例如,\u00A9 匹配版权符号 (?)。
var strDate="2006-12-21";
var arys= new Array();
arys=strDate.split('-');
var startdate=new Date(arys[0],parseInt(arys[1]-1),arys[2]);
注意:Date.getMonth的值范围为0~11(对应1月~12月)
Date.getDay的值范围为0~6(对应星期日~星期六)
在IE中不能使用setAttribute对结点属性进行设置。
例如document.getElementById('content').setAttribute("style","color:#ffffff;");
在ie下无法运行,在firefox下可正常使用,可以使用替代的方法,如
document.getElementById('content').style.color="#ffffff";
在style中的“font-size”用
document.getElementById('content').style.font-size="12px";将出现错误,可使用下面代码:
document.getElementById('content').style.fontSize="12px";
页面打印时,一个table在一页显示不完时,整个table将跳到下一页显示;
一个div超过一页时,超出部分将不显示出来。