ClickIDE is an Eclipse/WTP plug-in for web application development using Click. This release has not new features however it supports Click 1.5 and Eclipse 3.4/WTP 3.0.
Please download ClickIDE 2.1.0 and enjoy Click!!
ClickIDE is an Eclipse/WTP plug-in for web application development using Click. This release has not new features however it supports Click 1.5 and Eclipse 3.4/WTP 3.0.
Please download ClickIDE 2.1.0 and enjoy Click!!
Url Rewrite Filter has a configuretion file WEB-INF/urlrewrite.xml. This is a very simple example of clean URL with a Click application.
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE urlrewrite PUBLIC "-//tuckey.org//DTD UrlRewrite 2.6//EN" "http://tuckey.org/res/dtds/urlrewrite2.6.dtd"> <urlrewrite> <rule> <from>^/contents/([0-9]+).htm$</from> <to type="forward">/content.html?contentId=$1</to> </rule> </urlrewrite>For example, Url Rewrite Filter will forward /contents/001.htm to /content.htm?contentId=001.
If content.htm has possibility to receive any other query parameters, we can define following rules.
<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE urlrewrite PUBLIC "-//tuckey.org//DTD UrlRewrite 2.6//EN" "http://tuckey.org/res/dtds/urlrewrite2.6.dtd"> <urlrewrite> <!-- No Query String --> <rule> <from>^/contents/([0-9]+).htm$</from> <to type="forward">/content.html?contentId=$1</to> </rule> <!-- With Query String --> <rule> <from>^/contents/([0-9]+).htm?(.+)$</from> <to type="forward">/content.html?contentId=$1&$2</to> </rule> </urlrewrite>Of course, we can use Url Write Filter with other frameworks such as Struts. I think Url Write Filter is a simple solution to make clean URL in the Java web applications.
For example, see the below page class. If you clicks AjaxRequestButton, Click invokes getAllBooks()
using XMLHttpRequest. And getAllBooks()
renders a Java object as JSON. AjaxRequestButton
generates a HTML button that invokes Ajax.Request
of prototype.js.
public class AjaxPage extends AjaxPage { public AjaxRequestButton button = new AjaxRequestButton("search", this, "getAllBooks"); public AjaxPage(){ button.addAjaxHandler( AjaxRequestButton.ON_COMPLETE, "displayResult"); } public boolean getAllBooks(){ List<Book> books = bookService.getAllBooks(); renderJSON(books); return false; } }Next example. AjaxSubmit control send Form using
Ajax.Request
.
public class AjaxPage extends AjaxPage { public Form form = new Form("form"); private TextField keyword = new TextFiled("keyword"); private AjaxSubmit search = new AjaxSubmit("search", this, "onSearch"); public AjaxPage(){ form.add(keyword); form.add(search); } public boolean onSearch(){ List<Book> bookList = bookService.search(keyword.getValue()); renderJSON(books); return false; } }Of course, these controls need more improvement. However I think this concept matches to Click Framework well.
However I will introduce S2Click detailed features in this blog. And also I will feedback these features to Click Framework from S2Click in the feature.
This is the first step of introducing Click Framework to many Java developers. I'll make effort to incubate Click Framework in the Apache Incubator.
AIR GEAR is an open source IDE for Adobe AIR development. It works as an Eclipse plug-in so you can use it with many other Eclipse plug-ins and powerful features of Eclipse.
AIR GEAR has following features:
See this page about detailed use.
Enjoy your development!
In the future version, many other JavaScript libraries will be supported!
However Click maps page classes to request-path from HTML templates. So page classes which do not have corresponded HTML template is not mapped automatically.
For example:
@Path("/file-download.htm")
public class FileDonwloadPage extends Page {
/**
* Writes response for file downloading in this method.
*/
@Override public void onRender() {
HttpServletResponse res = getContext().getResponse();
OutputStream out = res.getOutputStream();
...
}
/**
* This method returns null
to not render template,
* because this class writes response contents for file download.
*/
public String getPath(){
return null;
}
}
This is one idea of using annotation in Click Framework.
EclipseHTMLEditor (a part of Amateras) provides the JavaScript editor. I added JavaScript source code formatter to the JavaScript editor. We can format JavaScript source code from the context menu.
Please wait for the next release of EclipseHTMLEditor!
JJUG Cross Community Conference 2008 Spring will be held at Japan 30 Apr.
JJUG is an abbreviation of Japan Java User Group. In this conference, top Java engineers in Japan talk about hot topics in Java such as Web frameworks, EclipseLink, JAM, Scala and New Swing APIs.
I'll talk about Click Framework in this conference and join panel discussion with speakers of Grails, JRuby on Rails and Wicket.
I wish to make efforts to spread Click Framework in Japan.
Click Framework provides FileField to upload file, however Click does not provide any support for file downloading. I made AbstractDownloadPage to download file.
Usage:
public class SampleDownloadPage extends AbstractDownloadPage { public SampleDownloadPage(){ setFileName("sample.txt"); setContents(SampleDownloadPage.class.getResourceAsStream("sample.txt")); } }
This page class does not have a template because response is written by this class. So auto-mapping does not work for file download pages. The extended page class have to be registered to click.xml.
Click controls provide JavaScript validation, but they are not easy to customize. Now I'm writing JavaScript validation framework for Click using LiveValidation.
In the page class, ready the LivaValiator
control like below:
Form form = new Form("form"); form.add(new TextField("name", true)); form.add(new PasswordField("password", true)); form.add(new Submit("login")); addControl(new LivaValidator("validator", form));
In the page template, generates LiveValidation JavaScript code by the LiveValidator
control:
<body> $form <script type="text/javascript"> $validator </script> </body>
We can also add customized validation rules by use of Validate.Custom
.
OVal is the simple validation framework for Java. You can specify validation rules using annotations.
public class Person { @NotNull public String name; }
Usage:
Validator v = new Validator(); Person p = new Person(); for(ConstraintViolation error: v.validate(p)){ System.out.println(error.getMessage()); }OVal can switch validation rules by profiles.
public class Person { @NotNull(profiles={"profile1"}) public String name; @NotNull(profiles={"profile1", "profile2"}) public String email; }
Switch profiles like following:
// Enable all profiles v.enableAllProfiles(); // Enable a specified profile v.enableProfile("profile1"); // Disable all profiles v.disableAllProfiles(); // Disable a specified profile v.disableProfile("profile1");
JSONIC is a simple JSON encoder / decoder for Java made in Japan. We can get JSONIC from http://sourceforge.jp/projects/jsonic/files/. The use of JSONIC is very easy.
import net.arnx.jsonic.JSON; // POJO to JSON String text = JSON.encode(new Hoge()); // JSON to POJO Hoge hoge = JSON.decode(text, Hoge.class);
JSONIC can handle POJO's public fields as property well and it also encode / decode java.util.Map
and java.util.List
.
I recommend JSONIC if you have to handle JSON in Java. It would be a best choice.
At first, I show the very simple example to use S2Container. I created following 3 files into "jp.sf.amateras.seasar.example" package.
example.dicon
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE components PUBLIC "-//SEASAR2.1//DTD S2Container//EN" "http://www.seasar.org/dtd/components24.dtd"> <components> <component class="java.util.ArrayList" name="list"> <initMethod name="add"><arg>"Naoki Takezoe"</arg></initMethod> </component> </components> <components> <component class="jp.sf.amateras.seasar.example.Hello" name="hello"> <property name="target">list</property> </component> </components>
Hello.java
package jp.sf.amateras.seasar.example; import java.util.List; public class Hello { private List target; public void setTarget(List target){ this.target = target; } public void sayHello(){ for(int i=0;i<target.size();i++){ System.out.println("Hello, " + target.get(i)); } } }
Main.java
package jp.sf.amateras.seasar.example; import org.seasar.framework.container.S2Container; import org.seasar.framework.container.factory.S2ContainerFactory; public class Main { public static void main(String[] args){ S2Container container = S2ContainerFactory.create( "jp/sf/amateras/seasar/example/example.dicon"); Hello hello = (Hello)container.getComponent("hello"); hello.sayHello(); } }
Run the "Main" class as a Java application, it displays "Hello, Naoki Takezoe".
S2Dao can assemble dynamic query using SQL comment. For example:
@Sql("SELECT * FROM emp WHERE empno = /*empno*/7788") @Arguments("empno") public Emp selectEmpByEmpNo(int empNo);
/*empno*/ replaces the given argument and 7788 is removed by S2Dao at runtime. We can execute this SQL without no modification with the database client software such as psql. This solutuion is called "2-Way SQL" in S2Dao.
We can also use IF..ELSE statement as SQL comment.
/*IF hoge != null*/hoge = /*hoge*/'abc'/*END*/
And see the following example. If all conditions are false, S2Dao ignores /*BEGIN*/ ... /*END*/ block. So WHERE phrase is removed when it's not needed.
/*BEGIN*/WHERE /*IF job != null*/job = /*job*/'CLERK'/*END*/ /*IF deptno != null*/AND deptno = /*deptno*/20/*END*/ /*END*/
Again, these SQL can be executed with database client software with no modifications. 2-Way SQL makes possible to test SQL easily.
S2Dao is a database access framework based on the Seasar2 and AOP solution. Today, I introduce this great framework to you.
S2Dao makes DAO from Java interface using AOP at runtime. We have to write only Java interface such as:
@S2Dao(bean=UserInfo.class) public interface UserInfoDao { public List<UserInfo> selectAllUserInfos(); public void insertUserInfo(UserInfo userInfo); public void updateUserInfo(UserInfo userInfo); public void deleteUserInfo(UserInfo userInfo); }
SQLs are generated automatically by the entity definition (which is specified by @S2Dao) and DAO method names. So we don't have to write SQL in simple cases such as CRUD to the single table.
Of course, we can use complex SQL instead of auto generated SQL. We can specify WHERE and ORDER BY using @Query:
@Query("DEPTID=? ORDER BY EMPNO") public List<UserInfo> selectUserInfoByDeptId(int deptId);
And using @Sql, we can specify all parts of SQL:
@Sql("SELECT COUNT(*) FROM USERINFO") public int getCount();
These are parts of S2Dao great features. If we have to use complex and large SQL, we can write it as an external SQL file named "classname_methodname.sql" and S2Dao also support dynamic query using SQL comment. I will talk about them as another entries.
This is the first entry in Blogger!!
I'm making a lot of Eclipse plug-ins at the Project Amateras. Eclipse is the major open source Java Integrated Development Environment. And I'm also commiter of the Click Framework. Click is powerful and simple web application framework for Java.
Now I'm interested in the small web development project using Java. Which frameworks should we use...? My one answer is here:
Seasar2 is a poweful DI/AOP container made in Japan. I think Seasar2 is more easy than Spring in many cases. However Seasar2 does not have enough English docuements to use it. So I will try to tell about Seasar2 in this blog.