December 21, 2006

How to use DWR in Liferay Portal (Part 2 - A simple Dictionary)

 

This post shows you how to build a very simple ajax dictionary. The dictionary does not have a database, it just add a string to keywords and send back to browsers. This application is a normal web application. In the third part, we will make a Ajax dictionary portlet in Liferay.

Step 1: Create a Web Project named AjaxDict

Image Hosted by ImageShack.us

Step 2: Copy DWR.jar to \WebRoot\WEB-INF\lib
Image Hosted by ImageShack.us

Step 3: Declare DWR Servlet in \WebRoot\WEB-INF\web.xml

<?xml version="1.0"?>

<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "http://java.sun.com/dtd/web-app_2_3.dtd">



<web-app>

<servlet>

<servlet-name>dwr-invoker</servlet-name>

<display-name>DWR Servlet</display-name>

<servlet-class>uk.ltd.getahead.dwr.DWRServlet</servlet-class>

<init-param>

<param-name>debug</param-name>

<param-value>true</param-value>

</init-param>

</servlet>

<servlet-mapping>

<servlet-name>dwr-invoker</servlet-name>

<url-pattern>/dwr/*</url-pattern>

</servlet-mapping>

</web-app>


Step 4.1: Create Dictionary Engine Class

package com.aq.jdict;

/**
* This is just a simple engine.
* In real application, this engine will search the keyword
* in database, then return the meaning and other information.
* @author naqalone
*
*/

public class JDEngine {

public static String search(String keyword)

{

String meaning="meaning of "+keyword;

return meaning;

}

}

Step 4.2 : Create \WebRoot\WEB-INF\index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="ISO-8859-1"%>

<%

String path = request.getContextPath();

String basePath = request.getScheme() + "://"

+ request.getServerName() + ":" + request.getServerPort()

+ path + "/";

%>

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">

<html>

<head>

<base href="<%=basePath%>">



<title>A Sample Dictionary</title>



<meta http-equiv="pragma" content="no-cache">

<meta http-equiv="cache-control" content="no-cache">

<meta http-equiv="expires" content="0">

<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">

<meta http-equiv="description" content="Ajax Dictionary">

<!--

<link rel="stylesheet" type="text/css" href="styles.css">

-->

<script type='text/javascript'

src='/AjaxDict/dwr/interface/JDEngine.js'></script>

<script type='text/javascript' src='/AjaxDict/dwr/engine.js'></script>

<script type='text/javascript' src='/AjaxDict/dwr/util.js'></script>

<script>
function search()
{
var keyword;

keyword = DWRUtil.getValue("txtKeyword");

JDEngine.search(updateMeaning,keyword);

}



function updateMeaning(rxData)

{

DWRUtil.setValue("result",rxData);

}

</script>

</head>



<body>

<font color="#004080"> <strong>A very simple Ajax

Dictionary - Powered by DWR</strong> </font>

<br>

<br>

Keyword :

<input type="text" name="txtKeyword">

<input type="button" value="Search" name="btSearch"

onClick="javascript:search();">

<br>

Meaning:

<div id="result" border="1">

</div>

</body>

</html>


Step 5: Declare Engine class in \WebRoot\WEB-INF\dwr.xml

<!DOCTYPE dwr PUBLIC

"-//GetAhead Limited//DTD Direct Web Remoting 1.0//EN"

"http://www.getahead.ltd.uk/dwr/dwr10.dtd">



<dwr>

<allow>

<create creator="none" javascript="JDEngine">

<param name="class" value="com.aq.jdict.JDEngine"/>

</create>

<convert converter="bean" match="com.aq.jdict.JDEntry"/>

</allow>

</dwr>

Step 6: Configure the JBoss (or Tomcat)server
If you already configured a server, you can skip this step.

Image Hosted by ImageShack.us

Step 7: Deploy
Image Hosted by ImageShack.us

Image Hosted by ImageShack.us

Step 8: Start jBoss
Image Hosted by ImageShack.us

Step 9: Test in IE or Firefox

GOTO: http://locaclhost:8080/AjaxDict
Image Hosted by ImageShack.us

That's all!

Part 1,
2



10 responses:

Quan said...

Test

Anonymous said...

[url=http://loveepicentre.com/taketour.php][img]http://loveepicentre.com/uploades/photos/12.jpg[/img][/url]
who is keisha cole dating now [url=http://loveepicentre.com]online dating in brazil[/url] speed dating in chciago il
frisco speed dating [url=http://loveepicentre.com/]korean dating customs[/url] speed dating in richmond
contract for teens before dating [url=http://loveepicentre.com/faq.php]handsome boy modelling school dating game[/url] dating colorado springs

Anonymous said...

make a free ebook http://audiobookscollection.co.uk/de/Vision-and-Voice-Refining-Your-Vision-in-Adobe-Photoshop-Lightroom/p180728/ core ebook [url=http://audiobookscollection.co.uk/it/El-libro-del-laser/p224222/]ebook e-book creation japanese french translation[/url] o'reilly ebook pda

Anonymous said...

ebook for ique 3600 http://audiobooksworld.co.uk/The-Lathe-of-Heaven/p15811/ model t ford ebook [url=http://audiobooksworld.co.uk/Classic-Brainteasers/p194648/]ebook shop[/url] stacked income ebook

Anonymous said...

[url=http://onlinemedistore.com/catalogue/q.htm][img]http://onlinemedistore.com/6.jpg[/img][/url]
sample essay and personal statement for entering pharmacy school http://onlinemedistore.com/products/atrovent.htm cialis forumcialis pharmacy [url=http://onlinemedistore.com/products/dramamine.htm]humana pharmacy[/url]
rite aide pharmacy owego ny http://onlinemedistore.com/products/ampicillin.htm budget pharmacy [url=http://onlinemedistore.com/products/pamelor.htm]pamelor[/url]
internet pharmacy sales in pa http://onlinemedistore.com/products/calan.htm pharmacy jean coutu [url=http://onlinemedistore.com/catalogue/m.htm]ferris pharmacy greece ny[/url]
applying for online job in online pharmacy http://onlinemedistore.com/categories/gastrointestinal.htm online pharmacy accepts paypal [url=http://onlinemedistore.com/products/aciclovir.htm]aciclovir[/url]

Anonymous said...

[url=http://englandpharmacy.co.uk/products/aceon.htm][img]http://onlinemedistore.com/6.jpg[/img][/url]
job pharmacy tech fairfield county http://englandpharmacy.co.uk/products/lynoral.htm crestwood pharmacy albany ny [url=http://englandpharmacy.co.uk/products/flonase.htm]annual salary for pharmacy technicians[/url]
lynn lafferty post haste pharmacy http://englandpharmacy.co.uk/catalogue/k.htm kronos pharmacy [url=http://englandpharmacy.co.uk/products/ceftin.htm]ceftin[/url]
best pharmacy practice http://englandpharmacy.co.uk/products/toprol-xl.htm online pharmacy xanax [url=http://englandpharmacy.co.uk/products/trimox.htm]florida medicaid pharmacy[/url]
imitrex online pharmacy http://englandpharmacy.co.uk/products/ed-discount-pack-2.htm theresa pharmacy 2 [url=http://englandpharmacy.co.uk/products/singulair.htm]singulair[/url]

Anonymous said...

the newest chat dating site meet and fuck spy atheist dating phoneix
power dating pa http://freeinternetdating.info/love/suggs-love-struck gone fishing dating
dating sites cedar rapids ia dating she makes occasional contact polygamy dating fort wayne indiana

Anonymous said...

high class dating website http://loveepicentre.com/faq/ theme song for dating game
adult profile dating site [url=http://loveepicentre.com/articles/]online dating cheats[/url] religion dating sites
0 free dating site [url=http://loveepicentre.com/faq/]joaquin phoenix and dating[/url] dating the right person [url=http://loveepicentre.com/user/Dnote112305/]Dnote112305[/url] fish dating personal

Anonymous said...

Paradisus Holiday resorts absolutely an all-inclusive expensive resorts manufacturer which is managed from Melia Accommodation options Money. Why don't you consider think about a few things i have written looking at. For being medium-duty receiver, how the Type 810 is actually for goods, store colleges, plus donut outlet stores.

Anonymous said...

Hello. And Bye.