| Subcribe via RSS

Groovy WebSite Generator(Groovy 网站生成器)开源啦

11月 11th, 2007 | No Comments | Posted in 心得

用于生成bestunix 的程序发布在google code上,网址为 http://gwg.googlecode.com .

可以通过 svn checkout http://gwg.googlecode.com/svn/trunk/ gwg 取得最新代码。也可以在网站上下载打包好的代码。

经过两次比较大的重构(更新历史),目前gwg的主要功能有:

  1. 使用groovy根据rss生成网站首页,detail页面,分类页面,tag页面;
  2. 使用google ajax api实现了站内搜索功能;
  3. 页面内容中的tag链接替换为本地链接;
  4. 实现了本地rss输出;
  5. 实现了google sitemap;

gwg的价值在哪里:

  1. 可以快速的生成自己的独立网站;
  2. 只有一个配置文件需要修改;
  3. 网页风格可以通过dreamweaver的模板快速更改;
  4. gwg本身也是很好的groovy资料

快速启动:

  1. 首先需要配置好groovy运行环境;
  2. 进入gwg/src 目录,修改Config中的sourcePath和topFolder路径
  3. 在命令行运行 groovy start.groovy

相关文章:
Tags: , ,

Groovy学习之资料篇

10月 23rd, 2007 | No Comments | Posted in 资料

Groovy 官方网站,大部分问题看这里的文档都可以搞定了,从入门到精通在这里都可以完成。

PLEAC-Groovy 大量的代码示例,是Perl CookBook的一个Groovy版本 。

Groovy Tutorial 非常好的一个介绍Groovy的ppt,可以快速的对groovy有一个总体的了解,可以看作是Groovy In Action 的一个精华总结。

实战Groovy系列 比较老的资料,不过可以通过这些了解一下Groovy的实际用途。

Groovy in Action ,经典书籍,内容比较新,自己去eMule上去下载吧。

Groovy Programming ,看了一下目录,都是比较基础的东西,可以在eMule上下载到。现在中文版也出版了,叫《groovy 入门经典》。我感觉这本书也确实只适合入门,讲得不算深入。

中文资料:

朝花夕拾——Groovy & Grails 山风小子撰写或汇总的一些学习资料,大部分是中文的。山风小子为Groovy在中国的推广做了很多工作,致敬。

Groovy 学习笔记 ,中文pdf版,可以在百度上很容易搜到。

Groovy用户指南系列 非常不错的一套中文资料,可惜写成的时间太早,是2004年写的,现在groovy的语法有了一些变化。导致这个本来最适合初学者入门的资料却有些误导作用,因此已经不适合初学者。作者要是能更新一下就好了。

相关文章:
Tags: ,

使用Groovy自动生成网站

10月 21st, 2007 | No Comments | Posted in 心得

周末忽然心血来潮,决定重建一下bestunix,为了不再出安全问题,这次决定完全使用静态页面。

基本思路是这样的:

  1. 使用crontab定期从space上面下载feed.rss
  2. 使用groovy脚本解析feed.rss,生成静态页面
  3. 每次生成的页面覆盖以前的页面。

看起来很简单,但是因为以前没有用过groovy,而且groovy又没有好的ide工具,完全使用ultraEdit来做的,大概花了一天半时间。

基本上写程序半天,做页面半天,配置服务器半天(jdk,groovy,apache)。

通过这个小东西,基本上理解groovy的闭包了,另外对groovy的优点也有了进一步认识,进行io操作非常方便,语法习惯了以后写起来也很爽,虽然使用ultraEdit,但因为基本上没有重复的代码,ide生成代码的功能也显得不那么重要。缺点也很明显,没有好用的ide,调试程序非常麻烦,比js难调多了。另外就是性能太差,慢得要死,当工具来使还行,大项目上这东西还是不敢用。

做页面本身不是我的长项,花半天也是可以理解的。

配置服务器之所以要这么长时间,主要是因为编码的问题。通过iconv转换程序代码,设置apache默认编码等若干次尝试后,终于不再出乱码了。另外一个要注意的地方是groovy在linux下必须设置classpath,否则会找不到类。

现在设好以后,每次我在msn space上写了东西,bestunix上就会生成相应的静态页面了,呵呵,还是很有成就感的。

10月22日更新:

今天整理了一下程序,主要做了下面几点

  1. 程序功能分工更清晰,文件由原来的两个急剧增加到6个
  2. 增加了配置文件,适应性更好
  3. 程序和模板,生成的网站可以分离了
  4. 增加了RSS输出
  5. 增加了自动生成sitemap
  6. 修改了原来日期显示的问题

今天用了一下groovy的eclipse插件,还不错,有部分的代码自动完成功能和部分的语法检查,可以进行很简单的调试。另外一个感觉就是非常慢。

11月6日更新

  1. 重构了代码,使功能分工更清晰
  2. 增加了一个DataFactory,所有磁盘资源都只需要读取一次,减少了因为重复读取数据造成的性能问题
  3. 增加了tag的功能,使得导航更方便
  4. 解决了非utf-8环境下测试的问题
  5. 其他地方的性能也做了一些优化
  6. 网页模板改用绝对链接,这样模板文件更容易管理
  7. 程序与模板,生成的完全分离,可以在Config中指定。

11月8日更新

  1. 增加了taglist页

11月11日更新

  1. 增加了站内搜索,使用google ajax api,折腾了半天,还算好用
  2. 对上面的一级栏目做了调整,不再放分类了
  3. 修改了rss中一个链接错误

11月12日更新

  1. 终于实现分页了,确实有点麻烦,自己写了个分页类。
  2. 对网站的整体样式做了一些调整,使用大字体了,这样看着不会那么费劲。
  3. 把源代码放到 google code 上了。

TODO:

  1. 合并rss.因为网站上的rss只输出最近的几十条。内容多了就会丢失以前的数据。需要写个程序来增量合并更新的内容。
  2. 自动生成对应的繁体中文网站
  3. 根据tag自动生成专题
  4. 生成pdf

相关文章:
Tags: ,