junctioner

2006年7月17日

序:给自己找点事做

时间和日子在无知无觉中过去,问自己收获了什么?

每天无所事事。


列个标题,挖个坑,希望每天能来挑一点土。

《解读eclipse_3.50_galileo 源码》

从第一次使用eclipse(大概是03年的事,那时比较好用的是2.1版还是1.4版已记不清了)就想看看这么巧妙的一个玩意儿是怎么实现的,一直懒散无度,从未下手。

这段时间用SWT做个小工具,是边找边抄,为什么要那么写,不知道--真是有违一惯的作风。

每天下班后,都不是为什么奔忙着,网页?网游?都不知道自己看了些什么,玩了些什么。

eclipse 的jar很多,核心的是core.runtime和osgi(早些版本里,是没有osgi的),core.runtime比较小,就几个类,先攻击小的少的--毛主席真是伟大的军事家呀。

敬礼,睡觉去。

posted @ 2009-09-16 22:17 junctioner 阅读(226) | 评论 (0)编辑 收藏

一穷二白学习C语言(1)

前言
  一直想学习C,在刚知道有计算机的时候就想学习C,上学时,偷上计算机专业的课,学了半年Turbo C,学到指针时,晕了,也就没有下文。工作之后,时有心血来潮之时,但还是没怎么学习,Java还是比较简单,Java几乎占据了工作全部,更少有学习C了。用Java,研究到Java的核心,发觉还是得学C,学呀,学吧。
  今天也是一时的心血来潮了,趁着有股劲,开始动手,记录一下,以期待和方便下次来潮。

  写出的代码,得编译才可以运行,这个编译环境,得先搭起来。VC、Visual Studio,都微软的东西,有点抵触,也有些大,不安装了,手工配一套环境吧。
  网上搜了一下,Windows系统配C的编译环境,得要MinGW或者cygWin,以前都下载过,但一直不知道它们本身是个什么东西,再查,知道大概:二者均基于GCC(GNU Compiler Collection -格努编译套件),再加一些基本的类库。去各自的官网分别下载安装,感受:cygWin更象是一个linux的模拟器,把linux环境下的GCC给模拟出来,其它的就都一样需要基本的编译器、类库,其它的如make工具。使用的时候,个人取向选择minGW,在环境变量中指向{$minGW}\bin,gcc和make就可以在cmd中运行了。
  写个简单的hello world源程序,gcc一把,生产可执行文件,运行,结果出来,OK!

  注,下载minGW时,我选择了自动安装下载,一个个的下载,点来点去,累的慌。
单独下载minGW,要如下几个包,再分别解开放在同一目录中。
gcc-core
C语言编译器
gcc-c++
C++语言编译器
mingw-runtime
MinGW的运行时库(这个必须安装)

win32api

win32API函数头文件和连接库

binutils

MinGW的汇编器和连接器等基础工具

gdb

MinGW中的调试工具
mingw32-make
Make工具,用以更好的管理你的项目
make解后,没有通常的make.exe,只有一个mingw32-make.exe文件,其实,把这个文件改名为make.exe就行。

posted @ 2008-12-22 15:53 junctioner 阅读(1685) | 评论 (6)编辑 收藏

年迹

1978:第一个关键的年份
1988:虽然是第一个十年,但十岁的生日没多少印象了,更多的是开始注意的第一个年份。
1993:初中结束了,
1997:高中结束了,
2000/06/30:大学毕业了,世纪之交呀!
2000/08/03:子身跑到汕头的一个小镇开始第一份工作,真正的人生地不熟。到目的地时,身上只有20块钱了,还是年青的老板给我付的“摩的”费。
2001/11/03:混到一份跟自己所学专业,所做的工作一点也不相关的工作,毅然一个人跑到北京。首都呀!当时天很冷,比我想象的要冷,下车后把能穿的都穿上,不知象什么熊。打22块钱的车找到公司,竞然还没到上班时间。
2004/06/xx:一个伤感的月份,也注定要离开这个做了好几年有公司。
2004/08/04:换了一个比较远的公司,在朝阳,自己租住在西直门。
2005/02/28:一个没有29日的月份,还没开始工作,就没有选择的离开了。
2005/07/03:
2006/07/03:换了一份工作,不知什么感受。

posted @ 2007-06-19 16:35 junctioner 阅读(266) | 评论 (0)编辑 收藏

Velocity之首次研究

    与Velocity的第一次见面,是03年,有个新同事推荐使用,因当时我在做别的项目,也没怎么仔细了解,简单的知晓类似如模板一类的东西。之后有过几次接触,但,都没花时间仔细看,前段时间,帮朋友做一个小东西,觉得用个模板做,会省很多事,想到Velocity。东西很小,做完了都没时间看Velocity,今天正好有时间,研究研究。
    Velocity是apache下的一个开源项目,其网址:http://velocity.apache.org/;下载地址:http://velocity.apache.org/download.cgi,可直接下载源码,也可通过SVN获取源码。
    在eclipse中创建一个web应用工程,把Velocity的源码拷到java资源目录下,自动编译后,报几个错,拷贝下载的Velocity源码lib目录下的commons-collections-3.1.jar、oro-2.0.8.jar、commons-lang-2.1.jar这个三类包到web应用工程的lib目录下即可。
    准备就绪,就写个例子跑跑试试。写一个hello.vm的模板文件,创建一个对应的Servlet,就可以运行了。两文件源码贴出如下:
    hello.vm
<html>
    
<body>
    #set($greet = "你好哇!")
        Hello!$name, $greet
    
</body>
</html>
    HelloServlet.java
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Hashtable;
import java.util.Properties;

import javax.servlet.ServletConfig;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.velocity.Template;
import org.apache.velocity.app.Velocity;
import org.apache.velocity.context.Context;
import org.apache.velocity.servlet.VelocityServlet;

public class HelloServlet extends VelocityServlet {

    
protected Properties loadConfiguration(ServletConfig config)
            
throws IOException, FileNotFoundException {

        Properties p 
= new Properties();

        String path 
= config.getServletContext().getRealPath("/");

        
if (path == null) {
            path 
= "/";
        }

        p.setProperty(Velocity.FILE_RESOURCE_LOADER_PATH, path);
        p.setProperty(
"runtime.log", path + "velocity.log");
        p.setProperty(Velocity.INPUT_ENCODING, 
"GBK");
        p.setProperty(Velocity.OUTPUT_ENCODING, 
"GBK");
        
return p;
    }

    
public Template handleRequest(HttpServletRequest request,
            HttpServletResponse response, Context ctx) {
        Template template 
= null;
        
try {
            ctx.put(
"name","Velocity");
            template 
= Velocity.getTemplate("/hello.vm");
        } 
catch (Exception e) {
            e.printStackTrace();
        }
        
return template;
    }
}
    创建servelt要注意的几个地方。
    1、新建的Servlet要扩展Velocity的VelocityServlet
    2、在servlet中要实现 public Template handleRequest(HttpServletRequest request,HttpServletResponse response, Context ctx)
       A)把要返回到页面上的数据放到context中对应到指定键值(键值名为对应模板中定义的变量名)
       B)引入指定模板文件
    3、导入配置文件的方法protected Properties loadConfiguration(ServletConfig config),是否实现,是可选的 ,其作用在后面说明。

发布运行后,访问http://localhost:8080/vt/HelloServelt,就可看到结果了。

运行起来,看到结果,是觉得很简单,其运行过程,就要跟踪看源码才能知道了。

    看源码,先看的,肯定是VelocityServlet.java。发现源码注释中,这个类已不推荐使用,推荐使用Velocity的一个子项目tool中的VelocityViewServlet.java,我没有当tool子项目,就先看这个“过时的”实现。
     VelocityServlet.java,扩展了HttpServlet,实现了doGet、doPost、init基本方法,前两个方法都直接调用新实现的doRequest方法,这些都是很常规的操作。
    doRequest方法做如下几件事:创建上下文、设置响应内容文件类型、获取模板(调用每个请求中的具体实现)、合并数据做出响应、出错处理及资源清理。看到这儿,整个请求和响应过程很清晰,并没什么特别的处理。
    接下来,看看它的初始化做了些什么事。就做了三件事,超类初始化、自己的初始化、缓存内容类型数据。自己的初始化,也就是(i)导入配置信息,(ii)根据配置信息做初始化设置。导入配置信息,是根据指定的几个地方,获取配置数据(在提供的样例中,重载了它的获取配置数据的方法,自己灵活的写入一些配置信息);根据配置信息做初始化的工作,应用单例设计模式,保证初始化工作的处理唯一。
    VelocityServlet自已的初始化,调用另一个类org.apache.velocity.app.Velocity的init( Properties p )方法,就看看Velocity里做了些什么。Velocity里全是静态方法。主要有如下几个方法:
    1、初始化;2、预演传入的数据(发现在应用中没有使用,只在单元测试代码中引用到);3、合并数据和模板;4、设置/获取属性;5、操作信息提示(不过,都不推荐使用了),整个的看下来,有两点:1、主要的还是初始化和数据合并了;2、这个类只是一个中转类,所有的方法,最终都是调另一个类org.apache.velocity.runtime.RuntimeSingleton的方法。
    打开RuntimeSingleton的代码,看一看,发现它同Velocity类差不多,类本身不做实际的处理操作。它与Velocity不同的是,它是申明一个静态的实例,再调用这个实例,个别地方(init())加了同步控制。如此处理体现它这个类的名字--单例,核心的还是这个静态实例org.apache.velocity.runtime.RuntimeInstance。
    到RuntimeInstance,就开始接触到Velocity的处理核心了。

    写到这儿,突然没有写下去的冲动了,暂切休息一下。
   
    抽时间看了一下Velocity子项目tool下的VelocityViewServlet的源码,比VelocityServlet要实现的好多了,与struct接合的比较好。
    Velocity,不仅仅适合于web应用,还可以作生成SQL、XML的模板,内容比较多,待一一挖掘。

posted @ 2007-05-30 15:49 junctioner 阅读(2898) | 评论 (3)编辑 收藏

开源需要一个良好的商业模式

在网上看到“盖茨北大演讲遭开源人士抗议”一事,对开源兄的行为,我选择不置可否,但对软件而言,我选择开源。
现在的局面是,商业化的软件比开源的软件,要活地滋润、舒展多了,所以也会发生这次事件。

为什么会出面这种局面?为什么需要开源?在这里我不阐述自己的观点--持有同感的人都有自己的想法。

开源如果想要活得不那么艰难,我想:需要一个良好的商业模式支持。
开源不是免费!
开源要生存发展,也需要营养供应,不能仅靠一部分怀开源激情的人或者组织无偿奉献能支撑起来的。
linux、jboss的生存模式算是比较成功的,但还不能够同商业化软件相比较,还需要更充足的营养源。
这二者的模式也是一定范围内有效,不能做到推而广之。

开源软件生存模式的探索之路还很广,还很远,需要有志之士共同努力。

posted @ 2007-04-24 10:03 junctioner 阅读(987) | 评论 (0)编辑 收藏

在eclipse 3.3m6发布之际的感慨

     摘要:   阅读全文

posted @ 2007-03-28 13:20 junctioner 阅读(2958) | 评论 (9)编辑 收藏

再次开始centric crm研究

上次看centric crm,是一年多前的事了,这一年中,忙忙碌碌的,都不知道做了些什么,但还是一直关注crm的相关信息。
年初,有个朋友需要一套CRM软件,我就给他推荐centric crm,但他不懂技术,希望我帮他搞搞,这就应了下来,又一次开始认真的看centric crm。
[温故而知新] 看以前贴的关于centric crm的blog,心有惭愧,希望产生误导的影响不会很大。

今天作一些更正,算是补偿。
1、获取centric crm源码,得先注册,注册地址:http://www.centriccrm.com/Register.do
   先输入你的邮箱地址(登录用这个);
   个人名称可随便填写;
   注册成功后,密码会发送到你邮箱中,

2、官方用SubVersion管理centic crm的源码,可以当一个subverion的客户端,指定到要下载版本的链接,   输入注册的邮箱和密码,就可以获取源码。
  现在有4.0和4.1两个版本,subverion链接分别如下,   
  4.1源码:https://svn.centricsuite.com/webapp/branches/branch-41   
  4.0源码:https://svn.centricsuite.com/webapp/tags/rel-200611151353-402   

  我使用eclipse,装了个SVN插件,配好后,直接check out成eclipse的项目。   
  SVN eclipse plugin是subclipse,插件获取网站:http://subclipse.tigris.org/update_1.2.x

3、源码获取下来目录如下图
centric crm源文件目录结构

[源码check out到eclipse后,把整个项目编码方式改为UTF-8,因源文件注释中有些时间戳是中文简体字,不设成UTF-8,就显示为乱码,看起来没什么大碍,但若修改源文件再保存就会弹出编码格式不正确错误信息]
bin:暂没看这个目录中的内容
doc:基本文件目录
    Binary EULA.rtf:版权申明的文件;
    CRM Installation and Setup.pdf:安装配置文件,描述的比较简单;
    db-schema.html:库表设计说明文件,了解centric CRM表结构这个文件最佳参考资料
lib:项目需要的jar文件目录
pref:特定情况下需要的配置文件目录
src:源码基本目录
    src目录内有下面四个主要目录:
    java:java源文件目录
    web:web展示源文件目录
    sql:库表脚本文件目录
    testcases:单元测试文件目录

    src目录内有下面四个主要文件:
    build.xml:项目编译、发布的ant配置文件
    home.properties.example:build.xml的辅助文件样例,定义一些基本路径信息,如:服务发布目录
    master.properties:build.xml的辅助文件,定义系统的一些属性配置
    README.txt:比较详细的安装配置文件(我就是看这个文件进行安装配置的,有时间可以把安翻译成中文)
4、开始安装配置
    1)安装需求Java JDK,就不用说了,1.4以上都可以,1.4以下行不行,我也没试,有兴趣的朋友可试试,测试结果能告之当是感激了。我装的是JDK 5.0。
    2)应用服务用tomcat 5.0,5.5都可以(不过tomcat5.5得在JDK5.0上才能运行起来),Jboss、Weblogic、WebSphere、Resin也可以运行。我用Tomcat 5.5.3。
    3)数据库支持DB、MSSQL、MySQL、Oracle等,具体信息可看README.txt。我用的是MySQL 5.0.21。驱动jar是MySQL官网下载的 mysql-connector-java-5.0.4-bin.jar。
    4)还需要有ant工具,申明是要1.6的,我用eclipse自带的1.6.5。
    5)centric CRM中用到WebServices,可去下载一个,
    下载地址:http://apache.downlod.in/ws/axis/1_4/axis-src-1_4.zip。
    解开zip包,把webapp下面的axis目录拷贝到$tomcat/webapps/目录下。

    准备好上几步要求的,可以开始配置build.xml运行的两个属性文件。
    复制home.properties.example文件为 home.properties,相关属性做如下修改:
## The following properties can be set instead of using environment variables

## Declare the webapp server's directory to compile using web app server libraries
## based on the webapp type configured in build.properties
## 设置Tomcat安装路径
CATALINA_HOME=D:/java/tomcat5.5.3
#GERONIMO_HOME=/path/to/geronimo or websphere ce
#JBOSS_HOME=/path/to/jboss
#WEBLOGIC_HOME=/path/to/weblogic
#WEBSPHERE_HOME=/path/to/websphere

## CENTRIC_HOME can be used to compile directly to the webapp's deployment
## directory (for development), or to any directory for later generating a .war
## 设置centric CRM 发布到tomcat中的路径
CENTRIC_HOME=D:/java/tomcat5.5.3/webapps/centric
#CENTRIC_HOME=/path/to/weblogic/domain/autodeploy/directory

## At times, scripts will need to install or upgrade fileLibrary documents when
## deploying from source
## 设置项目中配置文件存放目录
CENTRIC_FILELIBRARY=D:/Project.java/Centric CRM 4.1/fileLibrary
## To skip web based GUI the fileLibrary must be in the WEB-INF folder, useful
## for development
## 设置配置文件发布目录
CENTRIC_FILELIBRARY=D:/java/tomcat5.5.3/webapps/centric/WEB-INF/fileLibrary

## If using Axis Web Services, then declare the webapp home so that the
## Centric CRM descriptors can be installed with "ant ws"
## 设置axis在tomcat中的发布目录
AXIS_HOME=D:/java/tomcat5.5.3/webapps/axis
    
    master.properties 相关属性做如下修改:

##
## NOTE: Do not edit "master.properties" -- edit a copy of it
## These settings are used by ant for the build and installation process
##




## PART 1: Are you reading the instructions? (required)

## The following is a control, uncomment the following line after modifying
## these properties... we just want to make sure you're paying attention and
## the build process doesn't do something it shouldn't!
## 确认修改过此配置文件标识
PROPERTIES=configured




## PART 2: Deployment settings (required for compiling)

## Default language setting: even though any locale can be specified, the
## following have Centric CRM translations and supporting database data
## args="de_DE,en_US,es_VE,fr_FR,it_IT,ja_JP,nl_NL,pt_BR,ro_RO,ru_RU,sl_SI"/>
SYSTEM.LANGUAGE=en_US

## Web server debug level:
## Extended debug information can be displayed in the web server's log file
## Comment out for no debugging, especially production server
DEBUGLEVEL=2
#DEBUG=true
#DEBUGLEVEL=lines,vars,source

## Specify the web server to build/deploy against (required):
## Use catalina for Tomcat
## Use geronimo for WAS-CE or Apache Geronimo
## All others untested but planned for
## 指定Web Server 应用服务类型
WEBSERVER.TYPE=catalina
#WEBSERVER.TYPE=geronimo
#WEBSERVER.TYPE=jboss
#WEBSERVER.TYPE=weblogic
#WEBSERVER.TYPE=websphere

## A self-signed SSL Certificate will be generated with the following parameters,
## which can then be added to Tomcat's SSL configuration and/or
## signed by an authority
## Common name should be a domain name
## Ex. *.yourcompany.com or www.yourcompany.com
KEYSTORE.COMMONNAME=127.0.0.1
KEYSTORE.ORGANIZATION=Company
KEYSTORE.ORGANIZATIONALUNIT=Unit
KEYSTORE.CITY=City
KEYSTORE.STATE=State
KEYSTORE.COUNTRY=US
KEYSTORE.VALIDITY=1000

## Force users to use SSL in Centric CRM
## The web server must be configured for SSL if this option is set to true as
## Centric CRM will redirect non-secure URLs to the secure URL
FORCESSL=false




## PART 3: Database installation settings (required for database installation)

## Uncomment and set the connection information for your specific database
## NOTE: The gatekeeper URL includes your database name, the site URL does not;
## The ant script will insert the database name after the specified url


## DB2
## CREATE DATABASE centric USING CODESET UTF-8 TERRITORY US pagesize 32 k
#GATEKEEPER.DBTYPE=db2
#GATEKEEPER.DRIVER=com.ibm.db2.jcc.DB2Driver
#GATEKEEPER.URL=jdbc:db2://127.0.0.1:50000/centric
#GATEKEEPER.USER=db2admin
#GATEKEEPER.PASSWORD=
#SITE.DBTYPE=db2
#SITE.DRIVER=com.ibm.db2.jcc.DB2Driver
#SITE.URL=jdbc:db2://127.0.0.1:50000/
#SITE.USER=db2admin
#SITE.PASSWORD=

## POSTGRESQL
## createdb -E UNICODE centric_crm
#GATEKEEPER.DBTYPE=postgresql
#GATEKEEPER.DRIVER=org.postgresql.Driver
#GATEKEEPER.URL=jdbc:postgresql://127.0.0.1:5432/centric_crm
#GATEKEEPER.USER=postgres
#GATEKEEPER.PASSWORD=
#SITE.DBTYPE=postgresql
#SITE.DRIVER=org.postgresql.Driver
#SITE.URL=jdbc:postgresql://127.0.0.1:5432/
#SITE.USER=postgres
#SITE.PASSWORD=

## MySQL
## CREATE DATABASE centric_crm CHARACTER SET utf8 COLLATE utf8_general_ci
## 指定数据库类型及连接配置
GATEKEEPER.DBTYPE=mysql
GATEKEEPER.DRIVER=com.mysql.jdbc.Driver
GATEKEEPER.URL=jdbc:mysql://127.0.0.1:3306/my_centric_crm
GATEKEEPER.USER=my_centric_crm
GATEKEEPER.PASSWORD=crm
SITE.DBTYPE=mysql
SITE.DRIVER=com.mysql.jdbc.Driver
SITE.URL=jdbc:mysql://127.0.0.1:3306/
SITE.USER=my_centric_crm
SITE.PASSWORD=crm


## MS SQL SERVER
#GATEKEEPER.DBTYPE=mssql
#GATEKEEPER.DRIVER=net.sourceforge.jtds.jdbc.Driver
#GATEKEEPER.URL=jdbc:jtds:sqlserver://127.0.0.1:1433/centric_crm
#GATEKEEPER.USER=centric_crm
#GATEKEEPER.PASSWORD=
#SITE.DBTYPE=mssql
#SITE.DRIVER=net.sourceforge.jtds.jdbc.Driver
#SITE.URL=jdbc:jtds:sqlserver://127.0.0.1:1433/
#SITE.USER=centric_crm
#SITE.PASSWORD=

## CodeGear's InterBase (formally owned by Borland) www.codegear.com
## Do NOT put the database in the centric file library, or at least the root,
## as the build.xml copies its prefs into there using the same name as your database file!
## "e:/centriccrm_db" is only an example
#GATEKEEPER.DBTYPE=interbase
#GATEKEEPER.DRIVER=interbase.interclient.Driver
#GATEKEEPER.URL=jdbc:interbase://127.0.0.1:3050/e:/centriccrm_db/centric_crm.ib
#GATEKEEPER.USER=sysdba
#GATEKEEPER.PASSWORD=masterkey
#SITE.DBTYPE=interbase
#SITE.DRIVER=interbase.interclient.Driver
#SITE.URL=jdbc:interbase://127.0.0.1:3050/e:/centriccrm_db/
#SITE.USER=sysdba
#SITE.PASSWORD=masterkey

## FIREBIRD SQL
#GATEKEEPER.DBTYPE=firebird
#GATEKEEPER.DRIVER=org.firebirdsql.jdbc.FBDriver
#GATEKEEPER.URL=jdbc:firebirdsql:127.0.0.1/3050:${CENTRIC_FILELIBRARY}/centric_crm.fdb
#GATEKEEPER.USER=sysdba
#GATEKEEPER.PASSWORD=masterkey
#SITE.DBTYPE=firebird
#SITE.DRIVER=org.firebirdsql.jdbc.FBDriver
#SITE.URL=jdbc:firebirdsql:127.0.0.1/3050:${CENTRIC_FILELIBRARY}/
#SITE.USER=sysdba
#SITE.PASSWORD=masterkey

## DAFFODIL DB EMBEDDED
#GATEKEEPER.DBTYPE=daffodildb
#GATEKEEPER.DRIVER=in.co.daffodil.db.jdbc.DaffodilDBDriver
## YOU MUST EDIT THE path in the following line to where you want the database
## created.
## The user and password must be set to daffodil
#GATEKEEPER.URL=jdbc:daffodilDB_embedded:centric_crm;create=true;path=/home/fileLibrary/centric_crm/daffodildb
#GATEKEEPER.USER=daffodil
#GATEKEEPER.PASSWORD=daffodil
#SITE.DBTYPE=daffodildb
#SITE.DRIVER=in.co.daffodil.db.jdbc.DaffodilDBDriver
#SITE.URL=jdbc:daffodilDB_embedded:
## YOU MUST EDIT THE path in the following line to where you want the database
## created.
## Ex. Use the same path as Centric CRM's deployed file library, then the name of
## the database, then end in daffodildb
## The user and password must be set to daffodil
#SITE.APPEND=;create=true;path=/home/fileLibrary/centric_crm/daffodildb
#SITE.USER=daffodil
#SITE.PASSWORD=daffodil

## ORACLE
## During installdb, use XE (or whatever you add under gatekeeper) for the
## database name since the install has not been adjusted for Oracle yet
#GATEKEEPER.DBTYPE=oracle
#GATEKEEPER.DRIVER=oracle.jdbc.driver.OracleDriver
#GATEKEEPER.URL=jdbc:oracle:thin:@//127.0.0.1:1521/XE
#GATEKEEPER.USER=
#GATEKEEPER.PASSWORD=
#SITE.DBTYPE=oracle
#SITE.DRIVER=oracle.jdbc.driver.OracleDriver
#SITE.URL=jdbc:oracle:thin:@//127.0.0.1:1521/
#SITE.USER=
#SITE.PASSWORD=

## Derby
#GATEKEEPER.DBTYPE=derby
#GATEKEEPER.DRIVER=org.apache.derby.jdbc.EmbeddedDriver
## YOU MUST EDIT THE path in the following line to where you want the database
## created.
#GATEKEEPER.URL=jdbc:derby:/home/fileLibrary/centric_crm/derbydb;create=true;upgrade=true
#GATEKEEPER.USER=centric_crm
#GATEKEEPER.PASSWORD=
#SITE.DBTYPE=derby
#SITE.DRIVER=org.apache.derby.jdbc.EmbeddedDriver
## YOU MUST EDIT THE path in the following line to where you want the database
## created.
#SITE.URL=jdbc:derby:/home/fileLibrary/centric_crm/
#SITE.APPEND=;create=true;upgrade=true
#SITE.USER=centric_crm
#SITE.PASSWORD=


## PART 4: Advanced configuration (optional)

## Web-based configuration is recommended and is the default setting
##
## If you uncomment the following CONTROL line then you must configure the
## remaining parameters yourself. You will also have to create a new Centric
## CRM user and password before using Centric CRM.
##
## If you DO NOT uncomment the CONTROL line, then the first time you use
## Centric CRM, you will be presented with a configuration wizard which will
## assist you in defining these parameters and creating a new Centric CRM
## user and password.
##
#CONTROL=BYPASS_WEB-BASED_APPLICATION_SETUP

## The following are methods for working with multiple development databases
## The APPCODE must be the same for the following Gatekeeper prefs and Site prefs
GATEKEEPER.APPCODE=centric
SITE.APPCODE=centric

## Define the web address used in communications when using a single development
## database
#WEBSERVER.URL=127.0.0.1:8080/centric

## Define the web address used in communications when using multiple development
## databases
#WEBSERVER.ASPMODE=true
#WEBSERVER.PORT=8080
#WEBSERVER.CONTEXT=/centric

## The server's default timezone for new users (using standard Java names)
SYSTEM.TIMEZONE=America/New_York
## Default currency for all users
SYSTEM.CURRENCY=USD
## Default country for all users
SYSTEM.COUNTRY=UNITED STATES

## External Servers used by the system
MAILSERVER=127.0.0.1
FAXSERVER=127.0.0.1
FAXENABLED=false
PROXYSERVER=false
PROXYSERVER.HOST=
PROXYSERVER.PORT=

## Apache Axis Web Services
## 指定WebService 服务路径
AXIS.WEBAPP=/axis
AXIS.HOST=127.0.0.1
AXIS.PORT=8080


## Asterisk integration
ASTERISK.OUTBOUND.ENABLED=false
ASTERISK.INBOUND.ENABLED=false
ASTERISK.URL=
ASTERISK.USERNAME=
ASTERISK.PASSWORD=
ASTERISK.CONTEXT=from-internal

## XMPP/Jabber integration
XMPP.ENABLED=false
XMPP.CONNECTION.SSL=false
XMPP.CONNECTION.URL=
XMPP.CONNECTION.PORT=5222
XMPP.MANAGER.USERNAME=
XMPP.MANAGER.PASSWORD=

## LDAP integration
LDAP.ENABLED=false
# Validate username OR email against LDAP: username|email
LDAP.CENTRIC_CRM.FIELD=username
LDAP.FACTORY=com.sun.jndi.ldap.LdapCtxFactory
LDAP.SERVER=ldap://127.0.0.1:389
# Search by attribute, otherwise composite DN: true|false
LDAP.SEARCH.BY_ATTRIBUTE=true
LDAP.SEARCH.USERNAME=cn=admin,ou=IT,o=COMPANY
LDAP.SEARCH.PASSWORD=
LDAP.SEARCH.CONTAINER=o=COMPANY
LDAP.SEARCH.ORGPERSON=inetOrgPerson
LDAP.SEARCH.SUBTREE=true
LDAP.SEARCH.ATTRIBUTE=mail
#LDAP.SEARCH.BY_ATTRIBUTE=false
#LDAP.SEARCH.PREFIX=cn=
#LDAP.SEARCH.POSTFIX=,o=COMPANY

## Define the system's email address
EMAILADDRESS=Centric CRM <noreply@127.0.0.1>

## Timed events, definitely turn on for a production server
CRON.ENABLED=true

## Connection Pool Settings
CONNECTION_POOL.DEBUG=false
CONNECTION_POOL.TEST_CONNECTIONS=false
CONNECTION_POOL.ALLOW_SHRINKING=true
CONNECTION_POOL.MAX_CONNECTIONS=10
CONNECTION_POOL.MAX_IDLE_TIME.SECONDS=60
CONNECTION_POOL.MAX_DEAD_TIME.SECONDS=300

## Layout Settings
## Template replaces the following files which MUST exist:
## CSS:
## template1.css
## template1-8pt.css
## template1-10pt.css
## JSP:
## template1nav.jsp
## template1style.jsp
## template1styleNoSession.jsp
## template1styleContainer.jsp
LAYOUT.TEMPLATE=template1
LAYOUT.JSP.WELCOME=welcome.jsp
LAYOUT.JSP.LOGIN=login.jsp
#LAYOUT.JSP.LOGIN.LOGO=<img src="images/centric/logo-centric.gif" width="295" height="66" alt="" border="0" />
#LAYOUT.JSP.LOGIN.TEXT=Centric CRM

## Max Imports that can run concurrently
IMPORT_QUEUE_MAX=1

## Opportunity behavior
# OPPORTUNITY.DEFAULT_TERM=52
# OPPORTUNITY.DEFAULT_UNITS=W
# OPPORTUNITY.MULTIPLIER=52
# OPPORTUNITY.CLOSE_PROBABILITY=25,50,75

完成上述两文件的修改后,打开eclipse的ant视图,

    运行:ant deploy 完成项目的编译发布工作。

下一步是创建库表,可运行 ant installdb 创建库表。
    运行 ant installdb前,先在启动MySQL,创建一个表空间及用户,
    CREATE DATABASE my_centric_crm CHARACTER SET utf8 COLLATE utf8_general_ci;
    GRANT ALL PRIVILEGES ON my_centric_crm.* TO my_centric_crm@"%" IDENTIFIED BY "crm";


    创建库表时,若出现类似"Specified key was too long; max key length is 765bytes"的错误,是因为标识"UNIQUE NOT NULL"的字段长度>255(255=765/3)了。MySQL数据库的unique类字段长度限制比较短,视不同版本,有的限制为765个字节,有的限制为1000个字节,UTF是占用3个字节位的,所以在这个限制上还要除以3。centric CRM的mysql库脚本中,unique类字段的长度是设为300长字符的,出现上述问题一个可行的妥协办法是修改脚本unique类字段的长度。

建完表后,可以启动tomcat服务,运行 ant ws 激活WebService,应用服务配置安装完成!

通过 http://localhost:8080/centric,第一次进入centric crm系统。

    第一次进入系统时,是一个登录界面,用户是dhvadmin,密码是admin,登录进入,是一步步的系统参数设置操作,操页面提示,就可完成设置。最后是创建应用系统公司名称和管理员用户密码的界面,再次使用系统时,就以管理员名称和密码登录,对系统进行设置及添加管理其他用户。(至此,告一段落。)

posted @ 2007-03-02 14:53 junctioner 阅读(3738) | 评论 (1)编辑 收藏

男孩、年青的父亲、男人

 有一段时间没写blog了,个中的理由就是这段时间心情浮躁,沉不下来。

  毕业后参加工作已整整6个年头了。从一个只知道找父母要钱花,不知道社会是什么样的“弱冠”到现在刚开始意识到要靠自己养家糊口,照顾父母的准“而立”,要考虑的事情比以前复杂的多了,这段时间工作也是动荡的,没有一个稳定的基础考虑自己要考虑的问题,愈是浮萍一样的没有根。

  今,得空闲一会,浏览blog,看到一个blog,它的公告图片上是一个漂亮的小女孩,它的ICO是卡通的唐老鸭,抑郁的心情忽的开阔了。想那小女孩肯定是作者的女儿,唐老鸭肯定是作者女儿的所爱。如果年青的妈妈,她的blog上放这些,是很容易理解的,而作者是一个大老爷们,他的blog上放这些与“大老爷们”身份有巨大的反差,但正是这种反差,让我看到一位父亲对女儿的喜爱。

posted @ 2006-07-17 14:51 junctioner 阅读(310) | 评论 (0)编辑 收藏

<2006年7月>
2526272829301
2345678
9101112131415
16171819202122
23242526272829
303112345

导航

统计

常用链接

留言簿(8)

随笔分类

随笔档案

文章档案

搜索

最新评论

阅读排行榜

评论排行榜