Source favicon18:33 条形码,二维码,龙贝码(LP Code),QR Code,3G » Andy's blog

看电影出来拿了张十月上映的电影宣传单,居然看到这个:手机拍码。莫名其妙的词,不过也猜出来了,这东西应该类似日本的QR Code,不过干吗叫手机拍码啊?虽然形象(表示能用带照相机的手机拍的“编码”),但这样只局限在手机上了,还不如叫本来的名字龙贝码(LP Code)呢。

LPCode

不是详见www.pic-tic.com吗?到家后我就上那个网站看了看,网站做得很烂,不过基本上明白啥意思了:

就是你在网上订票后,网站通过彩信或电子邮件发送手机电子票(包含了电影名称、场地、时间场次以及座位的加密二维码)到你的手机上,然后你可以到电影院检票口通过二维码扫描设备扫描你手机上收到的二维码,然后直接入场。

这个是龙贝公司网站(国内中小技术公司的网站怎么都这么烂啊?)的图片,很形象(这例子可不好,怎么是日本的NTT DoCoMo的手机啊,也太不小心了,也该避避嫌啊,让人怀疑LP Code和QR Code的关系,不是自主知识产权吗?不会又像是哪个教授啊、院士啊,组织开发的“自主知识产权的国产操作系统”吧?(先不说是不是基于Linux、BSD的,骗国家大把大把的钱可太可恶了!)

LPCodeA LPCodeB

不过,逛遍整个网站,我也很失望,很封闭!居然找不到一点儿编码技术的规范和资料,甚至连生成LP Code的软件都没有提供,我还想试试生成我Blog信息的LP Code呢。难道他们只打算卖他们的硬件产品吗?没考虑开放编码技术资料,以便各个厂商能方便的生成、识别LP Code?以便让这项技术应用更广泛?

如果只是靠卖硬件活着,那我觉得LP Code基本没什么前途,当然,“和ZF紧密合作”还是有发展的。记得有人说过,国内新兴富豪中除了IT行业的,都有原罪。要我说IT行业也不见得好哪去,哪个大的国内软件公司敢说发展中百分之百没有靠“关系”拉到项目的?

不管LP Code怎么先进、怎么比QR Code好,但我觉得如果不开放,那它绝对不会像QR Code那样成功!既然QR Code也可以支持中国汉字字符(GB 2312对应的汉字和非汉字字符),又是开放的技术,那就别追求所谓的“自主知识产权”了,直接用就好了(好像台湾地区QR Code用得也挺多的,看这里:手機讀條碼 生活情報手到擒來),真替这个“自主知识产权的”、“屡获国家大奖的”LP Code担心。

下面我说一下我了解的日本QR Code相关的信息:

QR Code码是由日本Denso公司于1994年9月研制的一种矩阵二维码符号,它除具有一维条码及其它二维条码所具有的信息容量大、可靠性高、可表示汉字及图象多种文字信息、保密防伪性强等优点,QR Code的编码技术是公开的、免费的。所以,QR Code在日本应用很广泛,很多产品都有QR Code,用来描述产品名称、产地、生产日期、价格等信息。日本很多网站都有QR Code,甚至日本最大的blog服务商livedoor.jp支持每个用户注册在自己建立的Blog或个人主页生成QR Code,这样,浏览者不必记下冗长的网址,只需要拍下来,就可把网站信息和网址等存到手机上!

想想那个短信网址MobileNIC也蛮搞笑的:),信息产业部居然联合移动、联通,想在手机上建立个新的“英文或中文网址”揽钱(注册短信网址最低为600元/年,好吓人啊),以为缩短用户输入网址的长度就行了,那还不是要用户记网址?还不是要输入?哪有拍照方便?真不知道他们怎么想的:D,当然,要是强制所有的手机厂家不准内置QR Code识别器,内置他们的软件那就两说了,反正手机入网证也掐在他们手上。。。

这个算不算3G时代的Killer application?天天嚷嚷3G啊,3G啊,真不知道中国靠什么、什么时候赶上日本韩国,技术上我们能赶上他们,可意识上呢?意识啊,意识啊,有时比技术更重要!

我Blog的QR Code(我的Nokia 6100,上次被豆浆泡了,居然还能修好,真想换个带相机的Nokia 6681!):

内容:

Andy's blog
http://blog.xintiantang.com/andy

对应的QR Code:

Wikipedia上关于QR Code的介绍:http://en.wikipedia.org/wiki/QR_Code
在线生成QR Code的网站:http://nfg.2y.net/system/qrcodegen.php
Open source QR Code Decode/Encode Java Library: http://sourceforge.jp/projects/qrcode/

Source favicon18:24 用Java进行基于浏览器的桌面应用程序开发(Browser-based desktop application development with java) » Andy's blog

作者:Andy(http://blog.xintiantang.com/andy),版权所有,转载请先联系我

这篇文章于2005/08/30 20:00开始,计划在一个月内完成,所以将会人工置顶。内容有点儿乱,先把想的和做的记下来,然后再慢慢整理。同时欢迎提出你的看法。更新记录:2005/08/30 20:00,2005/08/31 14:45,2005/08/31 21:21,2005/09/01 16:24,2005/09/01 21:53,2005/09/02 22:13,2005/09/14 13:10,2005/09/15 09:35,2005/10/01 18:24

对于普通用户来说,使用传统的桌面应用程序(可能采用不同语言和工具开发的)可能存在这样那样的限制,比如界面风格千变万化、操作习惯不统一、学习难度大、无法或很难和外部应用通信等。而传统的服务器端应用程序或网站也存在许多限制,比如网络连通可能出现问题、响应速度慢、不能保证服务器端始终可用、担心数据安全和个人隐私问题、不够灵活、使用不方便等。

 而基于浏览器的桌面应用程序正是综合桌面应用程序和服务器端应用程序的功能产生的。它包含以下优点:

基于浏览器的桌面应用程序(Browser-based desktop application)的定义:一个包含嵌入式网站服务器(Embedded web server)的能够在浏览器内的客户端的独立运行(Stand alone)的应用程序。

我把基于浏览器的桌面应用程序(Browser-based desktop application)简称为BBDA。其实BBDA和AJAX技术一样,也是一个buzzword,而不是什么新技术,只不过把几种通用的软件或技术组合在一起而已。和传统的重量级的Portal系统不同的是,BBDA是轻量级网络应用(Light weight web application),XML(Feed / RSS / XML-RPC / SOAP)是联系各个服务或应用的纽带。

其实,BBDA很符合目前热炒的WebOS(基于网络浏览器的操作系统)的特性,这方面Google做了个最好的Demo:Google Desktop, 在GD中,一切内容的表现都是网页(虽然隐藏了浏览器),并且很容易和Google网站进行通信(比如同时搜索本地和搜索Web,利用Feed(RSS)或XML-PRC或SOAP之类的协议读新闻、邮件、天气预报、股票行情等,微软该称RSS为Feed好像很有道理吧?)。现在GDS(Google Desktop Search)只是GD的一个模块而已,百度的桌面搜索只是单纯地模仿了GDS,却没有猜到原来Google是要做GD,好傻的百度。Google这几年的收购和挖人活动(Google Net, Google Browser等),看来一切都是为了WebOS而努力。这里顺便说一下Yahoo刚收购的Konfabulator,Konfabulator和GD有很大不同,我觉得它只是包含许多小软件或和网站交互的工具,只是个玩具箱而已,要做WebOS靠这个可以吗?看来Yahoo的眼光似乎始终不如Google。找到这篇文章:GoogleOS? YahooOS? MozillaOS? WebOS? 居然和我的想法如此相似(写这个之前我绝对没看过这篇文章)!

由于我主要做Java开发,所以只列出可能涉及的Java软件包:Browser(IE/FireFox), JDK, Tomcat/Jetty, HSQLDB/Apache Derby, Hibernate, Spring, Groovy, DOM4J,Apache Http Client, Lucene, Struts/WebWork/JSF/Tapestry/Wicket, DWR(AJAX), Apache Web Services(SOAP/XML-RPC), Apache POI(Word/Excel/ PDF), MP3 ID TAG 3 lib ,JPEG EXIF lib...

我的目的是组合几种通用的JAVA软件,用来进行快速的BBDA开发。对于开发者而言,只要选好合适的软件,并合理组合起来,完全可以达到或超过Ruby on rails的功能和开发效率。同时,对于普通用户而言,只要打开浏览器输入http://localhost就会进入Dashboard(ProtoPage是个很好的Prototype^_^,Start也不错),然后就可以管理日记(blog)、日历、通讯录、照片(flickr?)、音乐(itunes?)、文件、网摘(delicious?)、阅读订阅的RSS(bloglines?)、查看邮件(web mail)、新闻之类等,并可以进行搜索、共享、发布、与外部应用或网站同步等,构成一个完整的个人门户系统(Personal portal),XML(Feed / RSS / XML-RPC / SOAP)是联系各个服务或应用的纽带。

画了个草图(持续完善中):

Zoom in

关于嵌入式网站服务器(Embedded web server):

我这几天试用了Jetty和Tomcat。总以为Jetty很小呢,最适合做BBDA呢,结果发现软件包也很大了,另外很多功能不如Tomcat,Tomcat Embed 5.5由于使用Ecipse JDT,现在已经很小了(3M左右),而且标准,所以选了Tomcat Embed(这里下载)。下面的代码是Tomcat Embed的启动程序。

Start.java:

package com.terac.tomcat;
import java.net.InetAddress;
import java.net.UnknownHostException;
import org.apache.catalina.Context;
import org.apache.catalina.Engine;
import org.apache.catalina.Host;
import org.apache.catalina.LifecycleException;
import org.apache.catalina.connector.Connector;
import org.apache.catalina.startup.Embedded;

public class Start {
 public static void main(String[] args) {
  try {
   String path = System.getProperty("SERVER_HOME");
   if(path!=null&&!"".equals(path)){    
    int port = Integer.parseInt(System.getProperty("SERVER_PORT","8080"));
    startTomcat(path,port);
   }   
  } catch (Exception e) {
   e.printStackTrace();
  }
 }
 private static void startTomcat(String path,int port) throws UnknownHostException,
   LifecycleException {
  System.setProperty("catalina.home", path);
  Embedded embedded = new Embedded();
  Engine engine = embedded.createEngine();
  engine.setName("Engine");
  Host host = embedded.createHost("localhost", "web");
  Context rootContext = embedded.createContext("", "");
  rootContext.setPrivileged(true);
  host.addChild(rootContext);
  engine.addChild(host);
  engine.setDefaultHost("localhost");
  embedded.addEngine(engine);
  Connector connector = embedded.createConnector((InetAddress) null,port, false);
  embedded.addConnector(connector);
  embedded.start();
 }
}

start.bat:

@set classpath=./lib/所有的jar文件
@java -DSERVER_HOME=%cd% -DSERVER_PORT=80 -classpath %classpath% com.terac.tomcat.Start

关于嵌入式数据库(Embeded database):

Apache Derby虽然比HSQLDB强大,但还是太大了,尤其是当用到IBM的JDBC Driver时。所以只好选HSQLDB。下面的代码是利用ServerContextListener在Web应用程序启动时启动HSQLDB服务器。

HSQLDBServletContextListener.java:

package com.terac.hsqldb;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import javax.servlet.ServletContext;
import javax.servlet.ServletContextEvent;
import javax.servlet.ServletContextListener;

public class HSQLDBServletContextListener implements ServletContextListener {
 public void contextInitialized(ServletContextEvent evt) {
        try {
            ServletContext context = evt.getServletContext();
            String params = "port=9001;silent=true;trace=false;database.0=" +
                context.getRealPath("/") + "/WEB-INF/hsqldb/terac";
            org.hsqldb.Server server = new org.hsqldb.Server();
            server.putPropertiesFromString(params);
            server.setLogWriter(null);
            server.setErrWriter(null);
            server.start();
        } catch (Exception e) {
            System.err.println(e);
        }
    }
    public void contextDestroyed(ServletContextEvent evt) {
        Connection conn = null;
        try {
            Class.forName("org.hsqldb.jdbcDriver");
            conn = DriverManager.getConnection("jdbc:hsqldb:hsql://localhost:9001",
                    "sa", "123456");
            Statement stmt = conn.createStatement();
            stmt.executeUpdate("SHUTDOWN;");
        } catch (Exception e) {
            //
        }
    }
}

web.xml中需要加入listener:

com.terac.hsqldb.HSQLDBServletContextListener

关于全文检索引擎(Full text search engine):

Apache Lucene应用广泛,也足够强大,高亮显示(Highlighting)需要自己实现,自动摘要(autosummarize)需要Classifier4j 。下面是常用类的封装代码:

Indexer.java:

还未整理好

Searcher.java:

还未整理好

关于Shell:

有些时候,用户不满足已经有的服务,需要更灵活的、或者定制的功能,一个简单的、易学的、解释性的、交互式的Shell就显得很必要,比如Windows提供的cmd或Linux里的bash。研究了一下,发现Groovy正好能满足需要,“for (ch in "Hello world!") {println ch}”,这个稍微复杂点儿的Hello world很好懂吧?

关于时间服务(Time Service):

Windows里有计划任务(Schedule task),Linux里有Cron job,这个对于WebOS也是必须的,比如定时检查邮件,定时抓新闻等等都需要定时器(Timer),Spring framework封装了好几种Time service,足够了。

关于对象关系映射工具(OR mapping tools):

Hibernate是最常用最强大的工具。下面是Hibernate Session的封装代码(也可以利用Spring framework来管理):

HibernateUtil.java:

import net.sf.hibernate.HibernateException;
import net.sf.hibernate.SessionFactory;
import net.sf.hibernate.Session;
import net.sf.hibernate.cfg.Configuration;
import org.apache.log4j.Logger;

public class HibernateUtil {
 private static Log log = LogFactory.getLog(HibernateUtil.class); 
 public static final ThreadLocal threadSession = new ThreadLocal();
 private static final SessionFactory sessionFactory;
 static {
  try {
   sessionFactory = new Configuration().configure().buildSessionFactory();
  } catch (Throwable ex) {
   // We have to catch Throwable, otherwise we will miss
   // NoClassDefFoundError and other subclasses of Error
   log.error("Building SessionFactory failed.", ex);
   throw new ExceptionInInitializerError(ex);
  }
 }
    public static Session currentSession() throws HibernateException {       
        Session s = (Session) threadSession.get();
        if (s == null) {
            s = sessionFactory.openSession();
            threadSession.set(s);
        }
        return s;
    }
    public static void closeSession() throws HibernateException {
        Session s = (Session) session.get();
        session.set(null);
        if (s != null)
            s.close();
    }
}

关于模型-视图-控制框架(MVC framework):

现在的MVC framework太多了,传统的有Struts/WebWork,新的有JSF/Tapestry/Wicket/Flex&Laszlo(Flash RIA) ,Wicket网站列出了55种之多!我试过JSF,始终不能另我满意,正在研究WicketRIFE(这两个都支持AJAX),新加一个Stripes(采用Java 5 Annotations,所以不需要XML配置文件,非常简单)。

关于文件系统(File system):

Apache Commons Virtual File System - Commons VFS provides a single API for accessing various different file systems. It presents a uniform view of the files from various different sources, such as the files on local disk, on an HTTP server, or inside a Zip archive. 越来越好玩了:)

另外,发现在Windows系统下PHP5也可以在Tomcat下运行(Running php 5.x on windows using tomcat 4.x or 5.x - Simple Thoughts - Java and Web Software)。BBDA with PHP:),不知道PHP的基于文本的数据库都有哪些?我试了一下,phpinfo和一个简单的基于文本的PHP留言本可以使用,phpMyAdmin和几个PHP的blog不能运行,Tomcat直接Crash。

我已经把BBDA框架和以前写的一个非常简单的Struts/Hibernate单用户相册程序打包了,这里下载,下载后解压缩就能用(需要安装好JDK,并设置好path)。login.do是管理界面登陆入口,秘密是:111111。

Source favicon14:59 国庆节,成龙的电影《神话》,1排2座 » Andy's blog
  1. 和同事十点到电影院时只剩3张票,他是1排1座,我是1排2座,第一次离银屏这么近:)
  2. 成龙这部电影不错,至少比什么《上海正午》、《环游地球八十天》好多了。
  3. 成龙老了,面部又僵硬,不适合和金MM演感情戏。
  4. 金MM确实有气质,不过我老觉得她不如别人说的那样漂亮。

theMyth

Source favicon11:59 Flickr Backup » Jan's Tech Blog
Flickr Backup,一看而知就是Download Flickr相片的工具。它讓我們在一個簡單(簡陋?)的Interface,剔選想下載的相片,然後幫我們下載。不過,若你像Jan一樣是使用免費Flickr Account的話,Flickr Backup就會只讓你下載頭200張相,之前的相就不能下載。What you see is what you can download! 它是一個Java程式,不用安裝,而且可用在不同的Platform上。 [ via Download Squad ]...
Source favicon01:36 Ants unearthed with Google Earth » Official Google Blog


At a time when the power of information technology doubles every 12 to 15 months and extends to capture every scrap we have, digitizing biodiversity information is a final frontier for IT. It's an essential step to ensure society maintains and hopefully increases bio-literacy. Toward this end, there's Antweb. It's a project from the California Academy of Sciences that has incorporated the Google Earth interface to provide location-based access to the diversity and wonder of ants: from your backyard to the Congo Basin.

As society advances, literacy increases and bio-literacy decreases. If you're illiterate, you may view a library as thinly sliced stacks of firewood; a Google search engine is meaningless. If you are bio-illiterate, a forest is at best a green blob to be consumed. If you are bio-literate, you see the diversity of the forest and understand that each animal, each plant, tells a story and has a place.

Google has helped us achieve free and democratic access to information, but now, with Google Earth, it's taken an important step to promote bio-literacy. Together with other institutions in the Bay Area, Google is uniquely poised to take on this enormous task.

There are two ways people need to access information on biodiversity: either have a name for which they want more information, or they are at a location and want to know what they will find there. On Antweb, you can access information about ants via location – and Google Earth allows for any scale of access via location. So you can be in Santa Clara County and see what ants you are likely to find. Soon you will be able to create a field guide for ants in any location defined in Google Earth.

We tried to get NASA’s help to develop such a system for years with their mapping expertise and data, but Google Earth answered the call first. I am so impressed with Google that I have named an ant I recently discovered in Madagascar Proceratium google. Its bizarrely-shaped abdomen is an adaptation for hunting down obscure prey: spider eggs. Here's what it looks like.

I hope that Google will continue applying its skills to serve biodiversity data to conservation planners and the general public. Google has given us a tool to connect the 6 billion people on earth with our remaining biodiversity. Antweb welcomes any form of collaboration to help achieve this goal – and may the ants be with you.

^==Back Home: www.chedong.com

<== 2005-09-30

==> 2005-10-02