我的IT技术学习天地

这里有我想学的,这里有我所不知道的,这里有很多很多我想知道的……
 
平涛 @ 2009-05-27 20:44

1、"RPC服务无法启动":RPC服务没有启动,应该启动
2、“服务无响应或。。。”:world wide。。。这个服务没有启动。一般是因为iisadmin没有启动,即使启动了也没有用。那是因为安装了补丁KB939373,卸载后再启动iisadmin后即可启动www服务了。


 
平涛 @ 2009-05-18 00:12

(1) 类名首字母应该大写。字段、方法以及对象(句柄)的首字母应小写。对于所有标识符,其中包含的所有单词都应紧靠在一起,而且大写中间单词的首字母。例如:
ThisIsAClassName
thisIsMethodOrFieldName
若在定义中出现了常数初始化字符,则大写static final基本类型标识符中的所有字母。这样便可标志出它们属于编译期的常数。
Java包(Package)属于一种特殊情况:它们全都是小写字母,即便中间的单词亦是如此。对于域名扩展名称,如com,org,net或者edu等,全部都应小写(这也是Java 1.1和Java 1.2的区别之一)。

(2) 为了常规用途而创建一个类时,请采取"经典形式",并包含对下述元素的定义:

equals()
hashCode()
toString()
clone()(implement Cloneable)
implement Serializable

(3) 对于自己创建的每一个类,都考虑置入一个main(),其中包含了用于测试那个类的代码。为使用一个项目中的类,我们没必要删除测试代码。若进行了任何形式的改动,可方便地返回测试。这些代码也可作为如何使用类的一个示例使用。

(4) 应将方法设计成简要的、功能性单元,用它描述和实现一个不连续的类接口部分。理想情况下,方法应简明扼要。若长度很大,可考虑通过某种方式将其分割成较短的几个方法。这样做也便于类内代码的重复使用(有些时候,方法必须非常大,但它们仍应只做同样的一件事情)。

(5) 设计一个类时,请设身处地为客户程序员考虑一下(类的使用方法应该是非常明确的)。然后,再设身处地为管理代码的人考虑一下(预计有可能进行哪些形式的修改,想想用什么方法可把它们变得更简单)。
(6) 使类尽可能短小精悍,而且只解决一个特定的问题。下面是对类设计的一些建议:
■一个复杂的开关语句:考虑采用"多形"机制
■数量众多的方法涉及到类型差别极大的操作:考虑用几个类来分别实现
■许多成员变量在特征上有很大的差别:考虑使用几个类

(7) 让一切东西都尽可能地"私有"--private。可使库的某一部分"公共化"(一个方法、类或者一个字段等等),就永远不能把它拿出。若强行拿出,就可能破坏其他人现有的代码,使他们不得不重新编写和设计。若只公布自己必须公布的,就可放心大胆地改变其他任何东西。在多线程环境中,隐私是特别重要的一个因素--只有private字段才能在非同步使用的情况下受到保护。

(8) 谨惕"巨大对象综合症"。对一些习惯于顺序编程思维、且初涉OOP领域的新手,往往喜欢先写一个顺序执行的程序,再把它嵌入一个或两个巨大的对象里。根据编程原理,对象表达的应该是应用程序的概念,而非应用程序本身。

(9) 若不得已进行一些不太雅观的编程,至少应该把那些代码置于一个类的内部。

(10) 任何时候只要发现类与类之间结合得非常紧密,就需要考虑是否采用内部类,从而改善编码及维护工作(参见第14章14.1.2小节的"用内部类改进代码")。

(11) 尽可能细致地加上注释,并用javadoc注释文档语法生成自己的程序文档。

(12) 避免使用"魔术数字",这些数字很难与代码很好地配合。如以后需要修改它,无疑会成为一场噩梦,因为根本不知道"100"到底是指"数组大小"还是"其他全然不同的东西"。所以,我们应创建一个常数,并为其使用具有说服力的描述性名称,并在整个程序中都采用常数标识符。这样可使程序更易理解以及更易维护。

(13) 涉及构建器和异常的时候,通常希望重新丢弃在构建器中捕获的任何异常--如果它造成了那个对象的创建失败。这样一来,调用者就不会以为那个对象已正确地创建,从而盲目地继续。

(14) 当客户程序员用完对象以后,若你的类要求进行任何清除工作,可考虑将清除代码置于一个良好定义的方法里,采用类似于cleanup()这样的名字,明确表明自己的用途。除此以外,可在类内放置一个boolean(布尔)标记,指出对象是否已被清除。在类的finalize()方法里,请确定对象已被清除,并已丢弃了从RuntimeException继承的一个类(如果还没有的话),从而指出一个编程错误。在采取象这样的方案之前,请确定finalize()能够在自己的系统中工作(可能需要调用System.runFinalizersOnExit(true),从而确保这一行为)。

(15) 在一个特定的作用域内,若一个对象必须清除(非由垃圾收集机制处理),请采用下述方法:初始化对象;若成功,则立即进入一个含有finally从句的try块,开始清除工作。

(16) 若在初始化过程中需要覆盖(取消)finalize(),请记住调用super.finalize()(若Object属于我们的直接超类,则无此必要)。在对finalize()进行覆盖的过程中,对super.finalize()的调用应属于最后一个行动,而不应是第一个行动,这样可确保在需要基础类组件的时候它们依然有效。

(17) 创建大小固定的对象集合时,请将它们传输至一个数组(若准备从一个方法里返回这个集合,更应如此操作)。这样一来,我们就可享受到数组在编译期进行类型检查的好处。此外,为使用它们,数组的接收者也许并不需要将对象"造型"到数组里。

(18) 尽量使用interfaces,不要使用abstract类。若已知某样东西准备成为一个基础类,那么第一个选择应是将其变成一个interface(接口)。只有在不得不使用方法定义或者成员变量的时候,才需要将其变成一个abstract(抽象)类。接口主要描述了客户希望做什么事情,而一个类则致力于(或允许)具体的实施细节。

(19) 在构建器内部,只进行那些将对象设为正确状态所需的工作。尽可能地避免调用其他方法,因为那些方法可能被其他人覆盖或取消,从而在构建过程中产生不可预知的结果(参见第7章的详细说明)。

(20) 对象不应只是简单地容纳一些数据;它们的行为也应得到良好的定义。

(21) 在现成类的基础上创建新类时,请首先选择"新建"或"创作"。只有自己的设计要求必须继承时,才应考虑这方面的问题。若在本来允许新建的场合使用了继承,则整个设计会变得没有必要地复杂。

(22) 用继承及方法覆盖来表示行为间的差异,而用字段表示状态间的区别。一个非常极端的例子是通过对不同类的继承来表示颜色,这是绝对应该避免的:应直接使用一个"颜色"字段。

(23) 为避免编程时遇到麻烦,请保证在自己类路径指到的任何地方,每个名字都仅对应一个类。否则,编译器可能先找到同名的另一个类,并报告出错消息。若怀疑自己碰到了类路径问题,请试试在类路径的每一个起点,搜索一下同名的.class文件。

(24) 在Java 1.1 AWT中使用事件"适配器"时,特别容易碰到一个陷阱。若覆盖了某个适配器方法,同时拼写方法没有特别讲究,最后的结果就是新添加一个方法,而不是覆盖现成方法。然而,由于这样做是完全合法的,所以不会从编译器或运行期系统获得任何出错提示--只不过代码的工作就变得不正常了。

(25) 用合理的设计方案消除"伪功能"。也就是说,假若只需要创建类的一个对象,就不要提前限制自己使用应用程序,并加上一条"只生成其中一个"注释。请考虑将其封装成一个"独生子"的形式。若在主程序里有大量散乱的代码,用于创建自己的对象,请考虑采纳一种创造性的方案,将些代码封装起来。

(26) 警惕"分析瘫痪"。请记住,无论如何都要提前了解整个项目的状况,再去考察其中的细节。由于把握了全局,可快速认识自己未知的一些因素,防止在考察细节的时候陷入"死逻辑"中。

(27) 警惕"过早优化"。首先让它运行起来,再考虑变得更快--但只有在自己必须这样做、而且经证实在某部分代码中的确存在一个性能瓶颈的时候,才应进行优化。除非用专门的工具分析瓶颈,否则很有可能是在浪费自己的时间。性能提升的隐含代价是自己的代码变得难于理解,而且难于维护。

(28) 请记住,阅读代码的时间比写代码的时间多得多。思路清晰的设计可获得易于理解的程序,但注释、细致的解释以及一些示例往往具有不可估量的价值。无论对你自己,还是对后来的人,它们都是相当重要的。如对此仍有怀疑,那么请试想自己试图从联机Java文档里找出有用信息时碰到的挫折,这样或许能将你说服。

(29) 如认为自己已进行了良好的分析、设计或者实施,那么请稍微更换一下思维角度。试试邀请一些外来人士--并不一定是专家,但可以是来自本公司其他部门的人。请他们用完全新鲜的眼光考察你的工作,看看是否能找出你一度熟视无睹的问题。采取这种方式,往往能在最适合修改的阶段找出一些关键性的问题,避免产品发行后再解决问题而造成的金钱及精力方面的损失。

(30) 良好的设计能带来最大的回报。简言之,对于一个特定的问题,通常会花较长的时间才能找到一种最恰当的解决方案。但一旦找到了正确的方法,以后的工作就轻松多了,再也不用经历数小时、数天或者数月的痛苦挣扎。我们的努力工作会带来最大的回报(甚至无可估量)。而且由于自己倾注了大量心血,最终获得一个出色的设计方案,成功的快感也是令人心动的。坚持抵制草草完工的诱惑--那样做往往得不偿失

(3) 对于自己创建的每一个类,都考虑置入一个main(),其中包含了用于测试那 个类的代码。为使用一个项目中的类,我们没必要删除测试代码。若进行了任 何形式的改动,可方便地返回测试。这些代码也可作为如何使用类的一个示例 使用。

this is absolutly bad!

(4) 应将方法设计成简要的、功能性单元,用它描述和实现一个不连续的类接 口部分。理想情况下,方法应简明扼要。若长度很大,可考虑通过某种方式将 其分割成较短的几个方法。这样做也便于类内代码的重复使用(有些时候,方 法必须非常大,但它们仍应只做同样的一件事情)。

(5) 设计一个类时,请设身处地为客户程序员考虑一下(类的使用方法应该是 非常明确的)。然后,再设身处地为管理代码的人考虑一下(预计有可能进行 哪些形式的修改,想想用什么方法可把它们变得更简单)。
(6) 使类尽可能短小精悍,而且只解决一个特定的问题。下面是对类设计的一 些建议:
■一个复杂的开关语句:考虑采用"多形"机制
■数量众多的方法涉及到类型差别极大的操作:考虑用几个类来分别实现
■许多成员变量在特征上有很大的差别:考虑使用几个类

(7) 让一切东西都尽可能地"私有"--private。可使库的某一部分"公共化"(一个 方法、类或者一个字段等等),就永远不能把它拿出。若强行拿出,就可能破 坏其他人现有的代码,使他们不得不重新编写和设计。若只公布自己必须公布 的,就可放心大胆地改变其他任何东西。在多线程环境中,隐私是特别重要的 一个因素--只有private字段才能在非同步使用的情况下受到保护。

not necessary , pretotect or package level also fine in most case

(8) 谨惕"巨大对象综合症"。对一些习惯于顺序编程思维、且初涉OOP领域的新 手,往往喜欢先写一个顺序执行的程序,再把它嵌入一个或两个巨大的对象 里。根据编程原理,对象表达的应该是应用程序的概念,而非应用程序本身。

(9) 若不得已进行一些不太雅观的编程,至少应该把那些代码置于一个类的内 部。

(10) 任何时候只要发现类与类之间结合得非常紧密,就需要考虑是否采用内部 类,从而改善编码及维护工作(参见第14章14.1.2小节的"用内部类改进代 码")。

(11) 尽可能细致地加上注释,并用javadoc注释文档语法生成自己的程序文档。

(12) 避免使用"魔术数字",这些数字很难与代码很好地配合。如以后需要修改 它,无疑会成为一场噩梦,因为根本不知道"100"到底是指"数组大小"还是"其 他全然不同的东西"。所以,我们应创建一个常数,并为其使用具有说服力的描 述性名称,并在整个程序中都采用常数标识符。这样可使程序更易理解以及更 易维护。

(13) 涉及构建器和异常的时候,通常希望重新丢弃在构建器中捕获的任何异常- -如果它造成了那个对象的创建失败。这样一来,调用者就不会以为那个对象已 正确地创建,从而盲目地继续。

(14) 当客户程序员用完对象以后,若你的类要求进行任何清除工作,可考虑将 清除代码置于一个良好定义的方法里,采用类似于cleanup()这样的名字,明确 表明自己的用途。除此以外,可在类内放置一个boolean(布尔)标记,指出 对象是否已被清除。在类的finalize()方法里,请确定对象已被清除,并已丢弃 了从RuntimeException继承的一个类(如果还没有的话),从而指出一个编程 错误。在采取象这样的方案之前,请确定finalize()能够在自己的系统中工作 (可能需要调用System.runFinalizersOnExit(true),从而确保这一行为)。

(15) 在一个特定的作用域内,若一个对象必须清除(非由垃圾收集机制处 理),请采用下述方法:初始化对象;若成功,则立即进入一个含有finally从 句的try块,开始清除工作。

(16) 若在初始化过程中需要覆盖(取消)finalize(),请记住调用 super.finalize()(若Object属于我们的直接超类,则无此必要)。在对finalize() 进行覆盖的过程中,对super.finalize()的调用应属于最后一个行动,而不应是第 一个行动,这样可确保在需要基础类组件的时候它们依然有效。

(17) 创建大小固定的对象集合时,请将它们传输至一个数组(若准备从一个方 法里返回这个集合,更应如此操作)。这样一来,我们就可享受到数组在编译 期进行类型检查的好处。此外,为使用它们,数组的接收者也许并不需要将对 象"造型"到数组里。

(18) 尽量使用interfaces,不要使用abstract类。若已知某样东西准备成为一个 基础类,那么第一个选择应是将其变成一个interface(接口)。只有在不得不 使用方法定义或者成员变量的时候,才需要将其变成一个abstract(抽象) 类。接口主要描述了客户希望做什么事情,而一个类则致力于(或允许)具体 的实施细节。

they are total diffrent ,

(19) 在构建器内部,只进行那些将对象设为正确状态所需的工作。尽可能地避 免调用其他方法,因为那些方法可能被其他人覆盖或取消,从而在构建过程中 产生不可预知的结果(参见第7章的详细说明)。

(20) 对象不应只是简单地容纳一些数据;它们的行为也应得到良好的定义。

(21) 在现成类的基础上创建新类时,请首先选择"新建"或"创作"。只有自己的设 计要求必须继承时,才应考虑这方面的问题。若在本来允许新建的场合使用了 继承,则整个设计会变得没有必要地复杂。

(22) 用继承及方法覆盖来表示行为间的差异,而用字段表示状态间的区别。一 个非常极端的例子是通过对不同类的继承来表示颜色,这是绝对应该避免的: 应直接使用一个"颜色"字段。

(23) 为避免编程时遇到麻烦,请保证在自己类路径指到的任何地方,每个名字 都仅对应一个类。否则,编译器可能先找到同名的另一个类,并报告出错消 息。若怀疑自己碰到了类路径问题,请试试在类路径的每一个起点,搜索一下 同名的.class文件。

classpath is not that simple

(24) 在Java 1.1 AWT中使用事件"适配器"时,特别容易碰到一个陷阱。若覆盖了 某个适配器方法,同时拼写方法没有特别讲究,最后的结果就是新添加一个方 法,而不是覆盖现成方法。然而,由于这样做是完全合法的,所以不会从编译 器或运行期系统获得任何出错提示--只不过代码的工作就变得不正常了。

(25) 用合理的设计方案消除"伪功能"。也就是说,假若只需要创建类的一个对 象,就不要提前限制自己使用应用程序,并加上一条"只生成其中一个"注释。 请考虑将其封装成一个"独生子"的形式。若在主程序里有大量散乱的代码,用 于创建自己的对象,请考虑采纳一种创造性的方案,将些代码封装起来。

(26) 警惕"分析瘫痪"。请记住,无论如何都要提前了解整个项目的状况,再去 考察其中的细节。由于把握了全局,可快速认识自己未知的一些因素,防止在 考察细节的时候陷入"死逻辑"中。

(27) 警惕"过早优化"。首先让它运行起来,再考虑变得更快--但只有在自己必须 这样做、而且经证实在某部分代码中的确存在一个性能瓶颈的时候,才应进行 优化。除非用专门的工具分析瓶颈,否则很有可能是在浪费自己的时间。性能 提升的隐含代价是自己的代码变得难于理解,而且难于维护。

but know early and design better at first is always necesary, or else
you die

(28) 请记住,阅读代码的时间比写代码的时间多得多。思路清晰的设计可获得 易于理解的程序,但注释、细致的解释以及一些示例往往具有不可估量的价 值。无论对你自己,还是对后来的人,它们都是相当重要的。如对此仍有怀 疑,那么请试想自己试图从联机Java文档里找出有用信息时碰到的挫折,这样 或许能将你说服。

(29) 如认为自己已进行了良好的分析、设计或者实施,那么请稍微更换一下思 维角度。试试邀请一些外来人士--并不一定是专家,但可以是来自本公司其他 部门的人。请他们用完全新鲜的眼光考察你的工作,看看是否能找出你一度熟 视无睹的问题。采取这种方式,往往能在最适合修改的阶段找出一些关键性的 问题,避免产品发行后再解决问题而造成的金钱及精力方面的损失。

(30) 良好的设计能带来最大的回报。简言之,对于一个特定的问题,通常会花 较长的时间才能找到一种最恰当的解决方案。但一旦找到了正确的方法,以后 的工作就轻松多了,再也不用经历数小时、数天或者数月的痛苦挣扎。我们的 努力工作会带来最大的回报(甚至无可估量)。而且由于自己倾注了大量心 血,最终获得一个出色的设计方案,成功的快感也是令人心动的。坚持抵制草 草完工的诱惑--那样做往往得不偿失


 
平涛 @ 2009-01-17 16:50

互联网上有很多专门的工具可以提高您的Blog质量,下面就是50个有助于Blogging的在线工具列表,它们将帮助你更有效的进行创建和发布Blog。4`"B%k%X(c)x%O4w7X
tech.techweb.com.cn'n)|9m%i&u/R8I4@,I

主机, DNS 和域名1. Domainscour: 这是一个用来查找域名是否有效的网站,非常的Web2.0化,支持.com .net .org .biz 及 .info域名。TechWeb-技术社区;G!o-Q-p1A&w6I*z
2. MyIPneighbours: 根据IP或域名查找同一虚拟主机上的其他站点。
3. WhoIshostingthis: 是一个挺有意思服务,通过输入域名,就可查询出当前站点位于哪个主机空间商或托管商。这个功能对于那些想寻找一款好主机的朋友来说应该是相当实用的,当你看到人家的Blog运行如飞的时候,你就可以利用此工具来看看他用的是什么主机了,也不必麻烦到别人。:l%o*S"D$|*]:Y+u*E
4. You Get Signal: 一个网络工具集合服务,它提供了一系列的网络、主机及IP信息查询工具。
设计和色彩.5. GenFavIcon: 在线Favicons图标创建工具。
6. Color Palette generator: 这个工具适合被利用在以一张图片作为网站主题的时候,选择与这张图片搭配的网页用色。/c7w9T;y"o%b
7. Color Scheme Generator 2: 在线多功能调色盘. 当你在设计网页、电脑应用程式或室内设计时,往往需要寻找适合的颜色配置,这个工个就可帮助你。
8. Font Tester: 字体在线测试,免费在线排版工具,都是网络安全字体。. @3P"X-U'p'H/w4`4l-a
9. Screen Size Tester: 屏幕尺寸测试。检查您的网站在不同屏幕尺寸先的显示效果。
程序和代码10. Grid: 网格工具。.e!u I8j3Q V&|1S
11. CSS Superdouche: CSS清理工具,此工具可显着降低你的CSS编程不需要的内容,降低复杂程度!tech.techweb.com.cn/K3](?-Y4h
12. Centricle: CSS兼容一览图。
网站表单13. WuFoo:一个在线表单创建服务,你可以用它来创建联系信息表、网络调查试卷等表单。
14. Web Form Factory: 一个开源的网络表单生成工具,可支持各种 HTML 文件中提取数据库表单,并且导入到 PHP 环境中。整个过程只需三个步骤,无需专业知识即可完成。。程序开发,操作系统,服务器,源码下载,Linux,Unix,BSD,PHP,Apach,asp,下载,源码,黑客,安全,技术社区,技术论坛"O1X$L0~$`6L&v,^
15. PHP form: 同样是一个在线表单创建服务。
Logo及其他21. Logo generator: web2.0样式的Logo生成器。
22. Buttonator: 在线制作各类按钮。
23. MyCoolButton: Web2.0样式的按钮生成器。.
24. StripeDesigner: 在线制作条纹背景。
25. Spiffy corners: 在线制作纯CSS 圆角边框。9|%Y)u%U%q(i,N3~"W
26. Tartan Maker:可以在线生成类似衣物等格子图案的工具。
SEO及推广27. URL trends: 会显示网站的访客是如何通过搜索引擎来到你的网站,还有各个流量是多少。这些数据是包括 Google, Yahoo, MSN, Alexa, AlltheWeb, AltaVista 和其他一些网站。.
28. Word-tracker: 侧重于提供某一个关键词的搜索频度。它还能估算出其它使用相同的关键词的网站个数。 ~9_+o j3T*g
29. Crawl test: 用测试爬虫来索引你的网站,测试搜索引擎是否能在你的网站上正常工作。.tech.techweb.com.cn'Q)w8B%U*i)t-x
30. SiteUptime: 可监测你的网站是否当机,一旦当机就会通过mail或sms来提醒你。
31. HostTracker: 免费服务提供每30分钟一次的监测,特色功能是他还提供IM通知,包括ICQ和GTalk。TechWeb-技术社区4R,w8|5s"x6@)G
32. OnlineMetatag: Meta标签生成器。
排名33. Blog Juice: Text Link Ads推出的一款博客影响力检测工具,只要输入你的博客地址,就可以知道自己的博客影响力值。跟PageRank有点相似,Blog Juice的值的范围也是0~10,不过它还可以精确到小数点后1位。
34. DNScoop: 是一个网站相关信息,网站价值查询工具,能够查询的内容包括:域名年限,Google Pagerank,所有指向此域名的网页等。tech.techweb.com.cn f8i-S!E7\%j3V:]
35. Xinu: 一个功能简单但比较实用的网站综合信息快速查询工具,通过它你可以在一个页面上快速查询出PageRank、书签网站收录情况、搜索引擎收录情况、Alexa排名等一系列信息。现在已开源,你可以自已架设一个类似的网站。
36. Website grader:免费的线上网站评级服务,这项服务透过许多外部数据来检核网站的好坏,所以说评鉴的是网站外在数据,而非本身的内容好坏 。TechWeb-技术社区(x*S;G'b!i&g
37. Page Strength: 网页强度测试工具.而评鉴的数据包括在Yahoo、Google的连结数、 Alexa Rank..等,包括Wikipedia-维基百科也是参考项目之一。
38. PR checker: 一个不错的Gogole PR监测工具。$l%R8g;Y.?2V
39. Test Everything: 一个功能超级强大的在线站长工具箱,将100多种(准确的说是128种) 在线检验服务整合到了一起!
40. Popuri.us: 一个用于检测网站流行度的简易工具,它会帮助用户查询出网站的 RANK值 (比如Google PageRank, Alexa Rank, Technorati 等), 在社会性书签网站中的被收藏连接数 (比如del.icio.us等)及RSS阅读器中的订阅数s (比如Bloglines等),根据这些数据信息,可以综合得出某一网站是否受人欢迎?
状态和反馈41. Google analytics: Google出品的网站访问统计系统,能够帮助您更方便地改善在线营销效果, 还可帮助您撰写更好的广告、改善您的营销计划并创建转换率更高的网站。.1N'g%}#q5a)|)x7]
42. WebAGogo: 一个站点在线分析评估服务,它可以对你的网站进行全面分析检测,会测试多个域名下的页面,分析HTML和CSS校验,并且会根据网页易用性(WCAG),可用性(链接检查,ICRA),速度,SEO,安全性,隐密性,兼容性等等方面进行全面测试。同时还分析出站点地图,链接结构等等信息。
注:目前正在改版中,新的2.0版将于2009年上线。
43. Piwik: 一个开源的网站访问统计系统,你可以在自已的主机上架设一个类似于Goolge analytics的服务。
44. PHPmyvisites: 同样是一个开源的网站访问统计系统。
杂项45. TagCloud generator: 这是一个在线的网络服务应用,它可以提供把你网页的关键字密度以一个可视化、漂亮的标签云显示出来。(使用了C SS和H TML)。 支持输入文本,提交网页地址,上传文本文件,它就会自动抓取页面里面的关键词,并根据关键词的使用频率生成一个标签云和相应的代码。TechWeb-技术社区)J.m3R2Z6f
46. GickR: 在线创建GIF动画图片的免费工具。.TechWeb-技术社区#l#z3]*M+v'J;I
47. Searchamabob: 是一个挺酷的小工具!它让访客反白你的博文后,快速地从搜索引擎里搜索相关资料。.
48. XML sitemaps: XML sitemaps在线生成工具。.
49. ShrinkTheWeb: 一款在线的网站缩略图生成器,输入指定的网站或者网页地址,即可生成需要的缩略图和截图,并供基于PHP 环境的源码下载。TechWeb-技术社区:F/f P&N;I0O-I.y
50. Website ribbon: 网页缎带制作工具。


 
平涛 @ 2008-12-26 21:40

   最近打开浏览器后出现很叉叉,主要是一些小图片无法打开,在网上找了方法后解决了。
   具体说明如下:
   发现ie浏览器看一些网站的图片和验证码无法显示,,但是opera却是正常,,,研究了一下,,这些都是png图片.
解决方法:
注册文件dll 运行

regsvr32 pngfilt.dll(如果找不到这个dll文件,,就下载附件里面的拷贝到windows\system32下面)

pngfilt.zip (20.33 KB)

然后运行:regedit
选择:HKEY_LOCAL_MACHINE/SOFTWARE/MICROSOFT/INTERNET EXPLORER/EMBEDEXTNTOCLSIDMAPPINGS/

看看这个项目下面有没有.png
如果没有新建项目.png
然后把项目.png下面的"默认"键的键值修改为

02BF25D5-8C17-4B23-BC80-D3488ABDDC6B

如果有.png项,,看看"默认"键的键值是否同上,,不同就修改一下
保存后关闭regedit,,重启浏览器,,这时候png图片就应该能显示了


 
平涛 @ 2008-12-05 20:37

Google推出的Chrome让大家热议纷纷,只有专业用户才会注意到用Chrome访问网页时发出的“Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US) AppleWebKit/525.13 (KHTML, like Gecko) Chrome/0.2.149.27 Safari/525.13”UserAgent字符串,貌似天书,它到底是怎么回事儿代表什么呢?我们来看看吧.

最早的时候有一个浏览器NCSA Mosaic,把自己标称为NCSA_Mosaic/2.0 (Windows 3.1),它支持文字显示的同时还支持图片,于是Web开始好玩起来。

然后出现了一个新的网页浏览器“Mozilla”,其实就是“Mosaic终结者”的意思,这搞的Mosaic很不爽,(毕竟Mosaic出道早,江湖老),新浏览器最后正式公布的名称是Netscape,它把自己标称为Mozilla/1.0 (Win3.1),更好玩了。Netscape支持框架显示,后来框架在大家中间流行起来了,但Mosaic不支持框架啊,于是伟大的“用户代理人探测”技术出现了,如果是“Mozilla”,那就发给支持框架的页面,至于其他的浏览器,则发给不含框架的页面。

Netscape想逗Microsoft玩儿,把Windows叫做“几乎不曾做过调试的设备驱动器”,后者很恼火。Microsoft于是推出了自己的 网页浏览器,叫做Internet Explorer,希望它能成为“Netscape终结者”。Internet Explorer也支持框架,但它不是Mozilla啊,所以没人给它发送带有框架的页面。Microsoft慢慢烦躁起来,不再寄希望于网站管理员逐渐 认识IE并给它发框架,而是宣称自己是“兼容Mozilla”的,开始模仿Netscape,把自己标称为Mozilla/1.22 (compatible; MSIE 2.0; Windows 95),这样Internet Explorer也能收到框架了,整个Microsoft狂喜,但网站管理员开始有点被搞糊涂了。 

Microsoft把IE和Windows一起卖,并且把产品也弄得比Netscape更好了,拉开了第一场浏览器之战。结果和大家知道的一样,Netscape被干掉了,Microsoft大胜、大喜。但是后来Netscape以Mozilla的新名称重生了,构造了Gecko,标称其为Mozilla/5.0 (Windows; U; Windows NT 5.0; en-US; rv:1.1) Gecko/20020826,Gecko属于渲染引擎,表现优异。Mozilla开发了Firefox,标称为Mozilla/5.0 (Windows; U; Windows NT 5.1; sv-SE; rv:1.7.5) Gecko/20041108 Firefox/1.0,并且Firefox表现也非常优秀。Gecko扩张迅速,一些浏览器使用了它的代码并标称为Mozilla/5.0 (Macintosh; U; PPC Mac OS X Mach-O; en-US; rv:1.7.2) Gecko/20040825 Camino/0.8.1 ,这是一个,还有Mozilla/5.0 (Windows; U; Windows NT 5.1; de; rv:1.8.1.8) Gecko/20071008 SeaMonkey/1.0,另一个,它们都伪装成Mozilla,同时也都是基于Gecko支持的。

Gecko表现优秀,IE则很差劲,于是身份甄别再次发生,输送给Gecko的是设计良好的网页代码,其他浏览器就没有这个待遇了。Linux的跟随者很伤心,因为他们创建了基于KHTML引擎支持的Konqueror,但却不会被输送好代码,虽然他们自己认为KHTML和Gecko一样优秀,于是Konquerer开始伪装自己“像Gecko”那样以得到好的网页,并标称自己为Mozilla/5.0 (compatible; Konqueror/3.2; FreeBSD) (KHTML, like Gecko),这个世界更让人困惑了.

后来出现了Opera这样的主儿,宣称“允许用户自己决定让浏览器装成谁”,它的菜单中提供了Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1; en) Opera 9.51Mozilla/5.0 (Windows NT 6.0; U; en; rv:1.8.1) Gecko/20061208 Firefox/2.0.0 Opera 9.51Opera/9.51 (Windows NT 5.1; U; en) 供大家来选择,选谁是谁。

Apple开发了Safari,使用了KHTML,同时也增加了很多新特性,后来干脆一锅煮,另起炉灶叫了WebKit,但是它有希望能够得到那些为KHTML编写的网页,于是Safari标称自己为Mozilla/5.0 (Macintosh; U; PPC Mac OS X; de-de) AppleWebKit/85.7 (KHTML, like Gecko) Safari/85.5,这个世界更混乱了。

Microsoft越来越担心Firefox的发展,重新启动了Internet Explorer的开发,标称自己为Mozilla/4.0 (compatible; MSIE 8.0; Windows NT 6.0) ,可以很好的渲染代码,但那要看网站管理员是否指示它这么做。

Google也开发了自己的浏览器Chrome, 使用了Webkit,有点像Safari,希望能得到为Safari编写的网页,于是决定装成Safari。这样啊,Chrome使用了WebKit渲染 引擎,想装成Safari,而WebKit呢又伪装自己是KHTML,KHTML呢又是伪装成Gecko的,同时所有的浏览器又都宣称自己是 Mozilla,于是,Chrome宣称自己是Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US) AppleWebKit/525.13 (KHTML, like Gecko) Chrome/0.2.149.27 Safari/525.13,,UserAgent字符串彻底混乱了,也几乎不再发挥任何作用,每个人都宣称自己是别人,混乱充斥人间啊。



 
日历
网志分类
『所有网志』 (60)
更新日志 (2)
语言区 (11)
协议区 (3)
网络区 (23)
软件区 (14)
硬件区 (0)
问题区 (7)
最新留言
站内搜索
友情链接
我的歪酷 非非共享界
====个人blog====
我自己的主blog
my csdn
boblong的博客
三牛
一直漂
狼的天堂资料馆
网络家园
Tommax
另类对我好
潘健的blog
丞相IT
====编程语言网====
Delphi俱乐部
[Delphi]园地
PHP学习之家
中文MySQL.CN
编程中国
====专业技术网====
中国协议分析网
订阅 RSS
0016387
歪酷博客