Tuesday, September 28, 2010
Liferay 6- Scheduler Engine design change
Posted by Parth Barot at 11:56 AM 3 comments
Labels: Articles, Design, Development, Liferay, Programming, Quartz
Tuesday, September 7, 2010
Liferay Struts Portlet: Usage of SessionErrors class...
if (!SessionErrors.isEmpty(req)) {
return mapping.findForward("portlet.portlet_name.error");
}
Tuesday, August 17, 2010
Liferay: Make Custom "Add Application" portlet ...
<portlet>
<portlet-name>87</portlet-name>
<icon>/html/icons/default.png</icon>
<struts-path>layout_configuration</struts-path>
<use-default-template>false</use-default-template>
<show-portlet-access-denied>false</show-portlet-access-denied>
<show-portlet-inactive>false</show-portlet-inactive>
<restore-current-view>false</restore-current-view>
<private-request-attributes>false</private-request-attributes>
<private-session-attributes>false</private-session-attributes>
<render-weight>50</render-weight>
<system>true</system>
</portlet>
<portlet>
<portlet-name>87</portlet-name>
<display-name>Layout Configuration</display-name>
<portlet-class>com.liferay.portlet.StrutsPortlet</portlet-class>
<init-param>
<name>view-action</name>
<value>/layout_configuration/view</value>
</init-param>
<expiration-cache>0</expiration-cache>
<supports>
<mime-type>text/html</mime-type>
</supports>
<resource-bundle>com.liferay.portlet.StrutsResourceBundle</resource-bundle>
</portlet>
<!-- Layout Configuration -->
<action path="/layout_configuration/templates" forward="portlet.layout_configuration.templates" />
<action path="/layout_configuration/view" forward="portlet.layout_configuration.view" />
<!-- Layout Configuration -->
<definition name="portlet.layout_configuration" extends="portlet">
<put name="portlet_decorate" value="false" />
</definition>
<definition name="portlet.layout_configuration.templates" path="/portlet/layout_configuration/templates.jsp" />
<definition name="portlet.layout_configuration.view" extends="portlet.layout_configuration">
<put name="portlet_content" value="/portlet/layout_configuration/view.jsp" />
</definition>
toggle: function(ppid) {
var instance = this;
var plid = themeDisplay.getPlid();
var doAsUserId = themeDisplay.getDoAsUserIdEncoded();
if (!instance.menu) {
var url = themeDisplay.getPathMain() + '/portal/render_portlet';
var popupWidth = 250;
var body = jQuery('body');
body.addClass('lfr-has-sidebar');
instance._dialog = Liferay.Popup(
{
width: popupWidth,
message: '<div class="loading-animation" />',
position: [5,5],
resizable: false,
title: Liferay.Language.get("add-application"),
onClose: function() {
instance.menu = null;
body.removeClass('lfr-has-sidebar');
}
}
);
jQuery.ajax(
{
url: url,
data: {
p_l_id: plid,
p_p_id: ppid,
p_p_state: 'exclusive',
doAsUserId: doAsUserId
},
success: function(message) {
instance._dialog.html(message);
instance._loadContent();
}
}
);
}
}
PortletCategory portletCategory = (PortletCategory)WebAppPool.get(String.valueOf(company.getCompanyId()), WebKeys.PORTLET_CATEGORY);
<init-param>
<name>includeCategories</name>
<value>myCategory,yours</value> <!-- Comma seperated category names, sub-categories will not be filtered...-->
</init-param>
Posted by Parth Barot at 5:16 PM 1 comments
Labels: Articles, Frameworks, hacks, Liferay, Portlet, Programming, Tutorials
Friday, July 30, 2010
Spring MVC portlet with annotations
<portlet>
<description xml:lang="en">Portlet Description</description>
<portlet-name>portlet-name</portlet-name>
<display-name xml:lang="en">Portlet Display Name</display-name>
<portlet-class>org.springframework.web.portlet.DispatcherPortlet</portlet-class>
<init-param>
<name>contextConfigLocation</name>
<value>/WEB-INF/appContext.xml</value>
</init-param>
<expiration-cache>0</expiration-cache>
<supports>
<mime-type>text/html</mime-type>
<portlet-mode>VIEW</portlet-mode>
</supports>
<portlet-info>
<title>Portlet Name</title>
<short-title>Portlet Name</short-title>
<keywords>Spring Portlet MVC</keywords>
</portlet-info>
</portlet>
@Controller
@RequestMapping
public class MyController {
private static final Logger _LOG = Logger.getLogger(MyController.class);
//Default render method will call this method...
@SuppressWarnings("unchecked")
@RequestMapping({"VIEW","/demoportlet/jsp2.do"})
public Object defaultRender(Model model, PortletRequest request,RenderResponse response) {
response.setContentType("text/html; charset=UTF-8");
String action = request.getParameter("action");
if("action1".equals(action)) {
...
return "demoportlet/jsp1";
} else {
...
return "demoportlet/jsp2";
}
}
// Direct request mapping based on action parameter value = 'someAction'
@RequestMapping(params = "action=someAction")
public Object actionOne(RenderRequest actionRequest, RenderResponse actionResponse) throws Exception {
actionResponse.setContentType("text/html; charset=UTF-8");
...
return "demoportlet/jsp2";
}
}
<servlet>
<servlet-name>view-servlet</servlet-name>
<servlet-class>org.springframework.web.servlet.ViewRendererServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet>
<servlet-name>normal</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>normal</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>view-servlet</servlet-name>
<url-pattern>/WEB-INF/servlet/view</url-pattern>
</servlet-mapping>
<context-param>
<description>Spring Context XML location</description>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:conf/spring/global.xml</param-value>
</context-param>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:util="http://www.springframework.org/schema/util"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util.xsd">
<context:annotation-config />
<bean id="localeResolver" class="org.springframework.web.servlet.i18n.CookieLocaleResolver">
<property name="cookieName" value="lang"/>
<!-- in seconds. If set to -1, the cookie is not persisted (deleted when browser shuts down) -->
<property name="cookieMaxAge" value="100000"/>
</bean>
<bean id="localeChangeInterceptor"
class="org.springframework.web.servlet.i18n.LocaleChangeInterceptor">
<property name="paramName" value="locale"/>
</bean>
<bean class="org.springframework.web.servlet.mvc.annotation.DefaultAnnotationHandlerMapping">
<property name="interceptors">
<list>
<ref bean="localeChangeInterceptor"/>
</list>
</property>
<property name="order" value="10" />
</bean>
<bean class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter"/>
<context:component-scan base-package="com.spring.controller" />
</beans>
Posted by Parth Barot at 6:06 PM 3 comments
Labels: Articles, Development, Frameworks, Portlet, Programming, Spring, Tutorials
Wednesday, July 28, 2010
Display tag - Opensource JSP paging library...
<%@ taglib uri="http://displaytag.sf.net" prefix="display" %>
<display:table name="lstObject" defaultsort="1" pagesize="20" sort="external" partialList="true"
size="totalCount" uid="lstObject" id="myObject"
export="false" requestURI="<%=someUrl%>" class="data">
<!-- For detailed understanding for each property, check the link http://displaytag.sourceforge.net/1.2/configuration.html -->
<display:setProperty name="paging.banner.placement" value="both" />
<display:setProperty name="paging.banner.group_size" value="10" />
<display:setProperty name="paging.banner.no_items_found">
<span class="lfloat">No {0} found.</span>
</display:setProperty>
<display:setProperty name="paging.banner.one_item_found">
<span class="lfloat">One {0} found.</span>
</display:setProperty>
<display:setProperty name="paging.banner.all_items_found">
<span class="lfloat">{0} {1} found, displaying all {2}.</span>
</display:setProperty>
<display:setProperty name="paging.banner.some_items_found">
<span class="lfloat">{0} {1} found, displaying {2} to {3}.</span>
</display:setProperty>
<display:setProperty name="paging.banner.full">
<div class="paging_footer">
<div class="rfloat">
<div class="lfloat" style="padding-top:6px;">[<a href="{1}">First</a> | <a href="{2}">Prev</a>]</div>
<div class="paging_wrap lfloat">
{0}
</div>
<div class="rfloat" style="padding-top:6px;">[<a href="{3}">Next</a> | <a href="{4}">Last</a>]</div>
</div>
</div><br>
</display:setProperty>
<display:setProperty name="paging.banner.first">
<div class="paging_footer">
<div class="rfloat">
<div class="lfloat" style="padding-top:6px;">[First | Prev]</div>
<div class="paging_wrap lfloat">
{0}
</div>
<div class="rfloat" style="padding-top:6px;">[<a href="{3}">Next</a> | <a href="{4}">Last</a>]</div>
</div>
</div><br>
</display:setProperty>
<display:setProperty name="paging.banner.last">
<div class="paging_footer">
<div class="rfloat">
<div class="lfloat" style="padding-top:6px;">[<a href="{1}">First</a> | <a href="{2}">Prev</a>]</div>
<div class="paging_wrap lfloat">
{0}
</div>
<div class="rfloat" style="padding-top:6px;">[Next | Last]</div>
</div>
</div><br>
</display:setProperty>
<display:setProperty name="paging.banner.onepage" value="" /> <!-- Because dont want to show any value if only one page...-->
<display:setProperty name="paging.banner.page.selected">
<div class="lfloat">
<a onclick="return false;" class="active" href="javascript:void(0);">{0}</a>
</div>
</display:setProperty>
<display:setProperty name="paging.banner.page.link">
<div class="lfloat">
<a href="{1}" title="Goto page {0}">{0}</a>
</div>
</display:setProperty>
<display:setProperty name="paging.banner.page.separator" value=" " /> <!-- Seperator between page numbers ,, i.e this will show "[First | Prev] 1 2 3 [Last | Next]"-->
<% MyObject myObject = (MyObject)pageContext.getAttribute("myObject"); %> <!-- Get the object from pageContext, which is writter in 'id' attribute -->
<display:column title="My title" class="first">
<!-- An y HTMl or jsp scriptlet can be used here... -->
</display:column>
<display:column property="name" title="2nd Column"/>
<display:column title="3rd Column"><%= myObject.getSomeValue() %></display:column>
...
</display:table> -
-
-
-
-
<display:table name="lstObject" defaultsort="1" pagesize="20" sort="external" partialList="true"
size="totalCount" uid="lstObject" id="myObject"
export="false" requestURI="<%=someUrl%>" class="data">
...
</display:table> <display:setProperty name="paging.banner.page.separator" value=" " />Posted by Parth Barot at 5:42 PM 2 comments
Labels: API, Articles, Development, Html, Open Source, paging, Programming, Tutorials
Wednesday, June 9, 2010
Liefray: Using JSONObject for Ajax in Plugin Portlet...
$.ajax({
type: 'POST',
url: getUrl(),
data: {},
success: function(returnData) {
$('#someElementId').html(returnData);
}
}); protected void getSomeDataAsJson(ResourceRequest request, ResourceResponse response)
throws PortletException, IOException {
String myParam = ParamUtil.getString(request, "myParam","");
// Some service call using params from request...
Obj obj = getDataFromSomeService(myParam);
JSONObject jsonObj = JSONFactoryUtil.createJSONObject();
// obj can be anything... Integer,Boolean,String or some custom POJO...
jsonObj.put("testData", obj);
OutputStream os = response.getPortletOutputStream();
try {
os.write(jsonObj.toString().getBytes());
}
finally {
os.close();
}
}
@Override
public void serveResource(ResourceRequest request, ResourceResponse response)
throws PortletException, IOException {
String cmd = ParamUtil.getString(request,Constants.CMD);
if ("getSomeDataAsJson".equals(cmd)) {
getSomeDataAsJson(request, response);
}
} $("input:button[@name='<portlet:namespace />SomeThing']").click (function() {
$('#<portlet:namespace />myDiv').text("");
//URL which goes to your portlet...
var url = "<portlet:resourceURL><portlet:param name='<%=Constants.CMD %>' value='getSomeDataAsJson' /></portlet:resourceURL>";
//Append your hidden input fields in the resourceURL...
url +="&"+$('input:hidden').serialize();
$.ajax({
url: url,
data: {},
dataType: 'json',
success: function(message) {
$('#<portlet:namespace />myDiv').text(message.testData);
}
}
);
}); Posted by Parth Barot at 3:32 PM 2 comments
Labels: API, Articles, Frameworks, Html, javascript, JQuery, Liferay, Open Source, Programming, struts, Tips, web
Wednesday, June 2, 2010
jQuery - usage of $.bind method...
<script type="text/javascript" src="html/js/jquery.js"></script>
<script type="text/javascript">
//on load, register events for checkboxes...
$(document).ready(
function() {
$('#chk_all').change(checkAll);
$('form[@name="fm"] input:checkbox[@name!="chk_all"]').each (function(index) {
$(this).change(selectForDelete);
});
}
);
function checkAll(){
var isCheck = this.checked;
$('form[@name="fm"] input:checkbox[@name!="chk_all"]').each(function(){
this.checked = isCheck;
$(this).trigger("change");
});
}
function selectForDelete(){
var alertIdsObj = $('form[@name="fm"] input[@name="deleteIds"]');
if (this.checked) {
if (alertIdsObj.val().indexOf(this.value)==-1) {
if(alertIdsObj.val()=='') {
alertIdsObj.val(''+this.value);
} else {
alertIdsObj.val(alertIdsObj.val()+","+this.value);
}
}
} else {
if (alertIdsObj.val().indexOf(this.value)>=0) {
alertIdsObj.val(alertIdsObj.val().replace(this.value+',',''));
alertIdsObj.val(alertIdsObj.val().replace(','+this.value,''));
alertIdsObj.val(alertIdsObj.val().replace(this.value,''));
}
}
}
//Function called for item details...
function viewAlertDetails(alertId) {
$.ajax({
type: 'POST',
url: getUrl()+"&alertId="+alertId+"&cmd=detailed-market-alerts",
data: {},
success: function(returnData) {
$('#-mainDiv').hide();
$('#-detailsDiv').html(returnData);
$('#-detailsDiv').show();
}
});
}
function getUrl() {
var url = new String(document.location);
var index = url.indexOf("?");
if (index!=-1) {
url = url.substring(0,index);
}
return url;
}
//function called from second page to go back to first page with latest data...
//Repalces the old content with new
function viewAlerts() {
$.ajax({
type: 'POST',
url: getUrl(),
data: {},
success: function(returnData) {
var myData = $(returnData).find('#-mainDiv').html();
$('#-mainDiv').html(myData);
$('#chk_all').bind('change', checkAll);
$('form[@name="fm"] input:checkbox[@name!="chk_all"]').each (function(index) {
$(this).bind('change',selectForDelete);
});
$('#-detailsDiv').html("");
$('#-detailsDiv').hide();
$('#-mainDiv').show();
return true;
}
});
return false;
}
</script> $('#chk_all').bind('change', checkAll);
$('form[@name="fm"] input:checkbox[@name!="chk_all"]').each (function(index) {
$(this).bind('change',selectForDelete);
}); Posted by Parth Barot at 2:50 PM 0 comments
Labels: API, Articles, Development, Frameworks, javascript, JQuery, Open Source, Programming, Tips, Tutorials
Tuesday, June 1, 2010
HibernateDaoSupport with HibernateTemplate - defaultAutoCommit set false...
I am working on a web application which needs hibernate for DB integration. So i decided to use hibernate with spring. As we all know that Spring is very lightweight and supports hibernate in an easy way. Also i am used to spring
While working this time i decided to use
Steps to make
- Extend
- Define your methods which provides different Database operations (CREATE, DELETE, FETCH, UPDATE, INSERT etc...)
- Define required beans as below,
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName">
<value>com.mysql.jdbc.Driver</value>
</property>
<property name="url">
<value>jdbc:mysql://localhost/testdb</value>
</property>
<property name="username" value="username" />
<property name="password" value="passwordforit" />
<property name="defaultAutoCommit" value="true" />
<property name="defaultTransactionIsolation" value="2" />
<property name="maxActive" value="100" />
<property name="maxIdle" value="50" />
<property name="minIdle" value="50" />
<property name="maxWait" value="100" />
<property name="initialSize" value="20" />
</bean>
<!-- Database Property -->
<bean id="hibernateProperties"
class="org.springframework.beans.factory.config.PropertiesFactoryBean">
<property name="properties">
<props>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.cache.provider_class">
net.sf.ehcache.hibernate.EhCacheProvider</prop>
</props>
</property>
</bean>
<!-- Hibernate SessionFactory -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref local="dataSource" />
</property>
<property name="hibernateProperties">
<ref bean="hibernateProperties" />
</property>
<!-- OR mapping files. -->
<property name="mappingResources">
<list>
<value>myMapping.hbm.xml</value>
</list>
</property>
</bean>
<bean id="MyDAOTarget" class="com.dao.MyDAO">
<property name="sessionFactory">
<ref bean="sessionFactory" />
</property>
</bean>
- Define transactionManager for transaction managment as below,
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource">
<ref bean="dataSource" />
</property>
</bean>
- Define
<bean id="MyDAO" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
<property name="transactionManager">
<ref bean="transactionManager"/>
</property>
<property name="target">
<ref bean="MyDAOTarget"/>
</property>
<property name="transactionAttributes">
<props>
<prop key="insert*">PROPAGATION_REQUIRED, ISOLATION_READ_COMMITTED</prop>
<prop key="update*">PROPAGATION_REQUIRED, ISOLATION_READ_COMMITTED</prop>
<prop key="delete*">PROPAGATION_REQUIRED, ISOLATION_READ_COMMITTED</prop>
<prop key="find*">PROPAGATION_REQUIRED, ISOLATION_READ_COMMITTED, readOnly</prop>
</props>
</property>
</bean>
- Use
- Use
- Use
- Use
It seems so easy right? But no, wait! All these works fine when you have
I have tried using
public void updateMyObj(MyObj myObj) {
Session session = getSession(true);// true means allow create new session if required.
Transaction trans = session.beginTransaction();
session.saveOrUpdate(myObj);
trans.commit();
}
Same thing works for any update operation. This is really strange, i tried for one whole day using
Posted by Parth Barot at 9:40 PM 0 comments
Labels: API, Development, Frameworks, Hibernate, Programming, Tips, Tutorials
Thursday, May 27, 2010
Java Wildcards Vs. Generics...
I have never used wildcards in java until i read this.
Let's say I have a super class
List<Vehicle> lstVehicles;Instead, some people are recommending something like:
List<? extends Vehicle> lstVehicles;Why should I use wildcards instead of simple generics?
Because Java generics are invariant.
Suppose we have B extends A:
* B is a subtype of A
* an
Since Java arrays are covariant:
*
* an
However, Java generics are invariant:
*
* a
Wildcards are used to make it more flexible while preserving type safety.
*
References:
Wildcards
Generics
Generics and subtyping
More fun with wildcards
Posted by Parth Barot at 10:18 PM 0 comments
Labels: Articles, Programming, Tips, Tutorials, Wildcards
Friday, May 21, 2010
Java String manipulation: Appending empty string to 'var.subString(x,y)' saves memory...
In java usually we do SubString operation as follows.
String strMainData = "Some long String..." ;
String strSub= strMainData.subString(i,j); // Where i and j are index values...This operation will keep the reference to same object strMainData,but only returns smaller string as per the indexes. So it uses same memory as the original String.
We should use it as follows.
String strSub = new String(strMainData.subString(i,j));OR String strSub = strMainData.subString(i,j) +"";
This will only keep the reference to new smaller String and removes reference to original String variable.Posted by Parth Barot at 3:50 PM 0 comments
Labels: Articles, Development, Programming, Tips, Tutorials
Singleton refactored:Initialization on demand holder idiom...
public class Something {
private Something() {
}
private static class LazyHolder {
private static final Something INSTANCE = new Something();
}
public static Something getInstance() {
return LazyHolder.INSTANCE;
}
}The static class LazyHolder is only executed when the static method getInstance is invoked on the class Something, and the first time this happens the JVM will load and initialize the LazyHolder class. The initialization of the LazyHolder class results in static variable INSTANCE being initialized by executing the (private) constructor for the outer class Something.
Posted by Parth Barot at 3:14 PM 0 comments
Labels: Articles, Development, Patterns, Programming, Tips
Hibernate : One-to-many Parent-Child relationships...
Hibernate is quite good ORM framework. When we need one-to-many relationship in hibernate, we need to take ArrayList or Set. If the structure is kind of tree, then hibernate can perform wired if not properly tweaked.
Basically if you are having some sort of many to one relationships structure from child to parent. In hibernate all depends on mapping. Tweak your mapping, Use One-to-many relationship from parent to child using java.util.Set.
Do not use ArrayList because List is ordered, so hibernate will add extra column for that ordering only.
Also check your lazy property. If you load parent and you have set lazy="false" on its child set property (variable which is of type Set), then all of its children will be loaded from DB which can affect the performance.
Also check 'inverse' property for children. If inverse is true in child table, that means you can manage the child entity separately. Otherwise you have to do that using the parent only.
Thursday, May 20, 2010
AXIS2 web service client - without sub/proxy ...
//common interface for response handlers...
//implement this for diff. web service/methods
public interface WSRespHandler{
public Object getMeResp(Object respData);
}
//pass particular handler to client when you call some WS
public class WebServiceClient {
public Object getResp(WSRespHandler respHandler) {
...
return repHandler.getMeResp(xmlData);
}
}Posted by Parth Barot at 5:00 PM 0 comments
Labels: API, Articles, Development, Frameworks, Networking, Programming, Tutorials, Web Service, XML
Sunday, March 15, 2009
Telnet Client part 2 - using Apache net implementation...
Its a very simple class.You can download its source and can figure out what they have done. Though i will show simple usage for it.
TelnetClient tc = new TelnetClient();
tc.connect("localhost", 23); Then you can register a listener thread to get response from the telnet connection shown above. For full examples, check out java2sIts nothing new, but a good implementation what we understood so far.
If you want totally command prompt like session for telnet, then you must wait for response from execution of the given command.Then only the next command will be sent over, as we do in DOS/Terminal.So for that we must have a logic which check the input stream and receives response.
Posted by Parth Barot at 12:27 AM 0 comments
Labels: API, Articles, Development, Open Source, Programming, Tutorials
Saturday, December 20, 2008
Telnet client with java...
Through java, if we want to make remote connection over some port then we have two different ways.
1. Use windows/linux telnet command line utility (which is same on both win and linux... :).)
OR
2. Use socket programming using java.net package.
In first way, we need to get hands on the process.We can achieve that using
Process p = Runtime.getRuntime().exec(<system command or exe path>)But i don't think this should be used for telnet like communication,because telnet requires continuous session running on remote server and executing you commands.Sometimes it can be so that after executing several commands,you need to rollback so you can cancle all the commands.so its a continuous and sequential process most of the times.The Process class used can be out of our hands anytime if the executable crashes or if anything bad happen(Mostly..the exe crash...).So, we have another,'Socket' way here, which connects to perticular host on given port number and try to open TCP connection with it.If the host is listening on port and connection accepted,then we can send our commands to the host.(I know, i know, that we all know sockets since our starting graduation days :) ,but let me tell guys... ).
There are two ways to make a telnet client using Sockets.
1.Make it CLI based,means which accepts every input from Command Line Interface entered by user.
2.Make it automated,which takes command list from some file or database,generates a script or list of commands and run it whole on host.
First one is quite easy,i think you all might have done that :).Just let me tell you little what to do...
1.CLI based Telnet...
Socket soc = new Socket(host,port);
DataInputStream din=new DataInputStream(soc.getInputStream());
PrintWriter dout = new PrintWriter(soc.getOutputStream(),true);
BufferedReader br=new BufferedReader(new InputStreamReader(System.in));See,we have taken InputStream of socket and made a PrintWriter on the OutputStreamof it to send commands.Also we have taken BufferedReader for user inputs from CL....
....
do
{
char[] buffer = new char[8192];
int mark = bReader.read(buffer);
StringBuffer sb = null;
for(int i=0;i<buffer.length;i++){
char c = buffer[i];
if(c!='\0'){ //To avoid null characters printed...
if(sb == null){
sb = new StringBuffer(buffer.length);
}
sb.append(c);
}
}
System.out.print((sb!=null)?sb.toString():"-- No Response --");
Command=br.readLine(); //takes commands from CL by user...
if(!Command.equals("quit"))
{
dout.println(Command);
}
}while(!Command.equals("quit")); //exit the loop if user sends 'quit'...
...
This gives you same telnet as you got in your OS, so i think its simple but good to know :)
2.Automated Telnet...
It will be almost same,except we will have a ArrayList/Array of commands in hand before we create Socket.And then change the loop onto the list to execute all the commands one after another...
So this will executes all commands in commands Array of String.int j=-1;
String[] commands = new String[5];
...
....
do
{
j++;
char[] buffer = new char[8192];
int mark = bReader.read(buffer);
StringBuffer sb = null;
for(int i=0;i<buffer.length;i++){
char c = buffer[i];
if(c!='\0'){//To avoid null characters printed...
if(sb == null){
sb = new StringBuffer(buffer.length);
}
sb.append(c);
}
}
System.out.print((sb!=null)?sb.toString():"-- No Response --");
Command = commands[j];
if(Command==null || Command.length()<0)
break;
dout.println(Command+"\n");
}while(j<commands.length);
...
So folks,this ends our telnet socket :).Same like this we can make client or scripts for FTP automation.It helps in real time situation when you need to make some jobs for backup,export/import files on remote host etc...Waiting for you responses...
Posted by Parth Barot at 1:20 PM 3 comments
Labels: Articles, Development, Networking, Programming, Tips, Tutorials
Wednesday, December 17, 2008
Snmp4J - Java library for SNMP Communication...
We can query any device (Switch,PC etc...) if it has a SNMP agent running,which will handle our SNMP request and respond with the proper data.This library made it so easy for us without looking into much details of SNMP.
In basic,SNMP is used for getting information (GET requests),but sometimes it can be used to set values in the device (SET requests).Assume that every device has a list of pre-defined variables in it,which are called OID(Object IDs).These OIDs will have a specific structure (which is called MIB file,which seems like a tree structured as in registry).
OID looks like 1.3.6.1.4.1.318.1.1.1.12.3.2.1.3.1, which has a special meaning.It has a description(name) and an associated value in it.When you query particular OID (i.e 1.3.6.1....),it will give its associated value.You can set its value also (if its allowed ;)).OIDs also have communities(Public,Private etc...) which shows permissions.Mostly public community is allowed to be viewed by SNMP requests.
See the example below how to make a SNMP request,
import org.snmp4j.*;So the last line, snmp.send(pdu, target), will return the SNMP4j Response having the value for OID we set in the PDU.This is just the example of how to get any data from OID.We can set the values using SET PDU.
...
...
OctetString communityName = new OctetString("public");
String ipAddressUrl = strIpAddress+"/"+161; //161 is used for SNMP Agent...
Address targetAddress = new UdpAddress(ipAddressUrl);
TransportMapping transport = new DefaultUdpTransportMapping();
Snmp snmp = new Snmp(transport);
snmp.listen();
CommunityTarget target = new CommunityTarget();
target.setAddress(targetAddress);
target.setRetries(3);
target.setTimeout(500);
PDU pdu = new PDU();
pdu.setType(PDU.GET);
OID oid = new OID("1.3.6.1.2.1.1.");
VariableBinding vb = new VariableBinding(oid);
pdu.add(vb);
...
...
snmp.send(pdu, target);
Posted by Parth Barot at 10:53 PM 0 comments
Labels: API, Articles, Development, Freeware, Networking, Programming, Tips, Tutorials
Tuesday, November 25, 2008
Batch insert/update DB - Use XML as you data...
This is not an excellent thing, but i think you should take care of this.Just think that if you are having 100 rows to be inserted in one table, and you make batch update call from you java code.How much time and resources it will take?We just can't answer this question.Yeah, we can't but we have different solution here.
Instead of making batch params data, you make and XML data using XSLT transformation or Castor mapping.We will see what these both things mean later. Today every Database server supports XML parameters as an input to Stored procedure/Function.You can pass your XML to the SP, and then handle the XML traversal logic inside the SP.You are done!
You just need to,
1.Create the XML data for Input param.
2.Pass the XML,execute the SP.
3.SP will handle the XML data and do the processing fetching the data from XML(Using Xpath traversal)
4.SP also can return resultset data as an XML content, which you can again transform map to Object.
XML Transformation: is done by javax.xml.Transform package, which takes one XML as input,Used XSLT file to transform input XML to XML format as defined by the XSLT.
Castor Mapping:is done by third party open source jar, which maps Object to XML and XML to object.So you can directly get XML/Object using this.
Posted by Parth Barot at 11:03 PM 0 comments
Labels: Development, Frameworks, Open Source, Programming, Tips, Tools, web, XML
Monday, July 14, 2008
Remote Method call - EJB/HTTPClient/Web Service?
This was a need in my project to call a method of another application which can be on same machine or another. First i thought i need to call a EJB and its all mess because of heavy loads for a simple method call. But when i saw the implementation, i got confused how i will cuse it! But my senior told me to check using HTTPClient from apache commons.
Its very simple to call a method on servlet using HTTPClient. Check the code below. We will just use PostMethod class for parameters to be passed and execute the request. So as per the parameters,the servlet will do its work.
PostMethod postMethod = new PostMethod("http://some.blah.com");Its so simple. But though its not a call which returns something. I mean you cna see i am just passign some information to some method to invoke some processing which is independent and i don't need its response.
postMethod.setParameter("some_id", "1");
postMethod.setParameter("param1", "any data");
postMethod.setParameter("param2", "any data");
...
int status = httpClient.executeMethod(postMethod); //status will be your response...
Posted by Parth Barot at 10:58 AM 0 comments
Labels: API, Articles, Development, Frameworks, Open Source, Programming, Tips, Tutorials, web
Tuesday, May 20, 2008
Controlling Module Dependencies in Eclipse
Let’s figure it out with Eclipse Web Tools Platform. I consider that you all have ability to create projects and modules in Eclipse; so skipping those steps. I have Eclipse 3.3 with WTP 2.0 M6.
I have created project with following details.
MyProject –
MyEJB_Module – Contains bean class
MyEJBClient_Module – Contains interfaces of EJB, VO, and BeanUtil.
MyWeb_Modules – Holds JSPs, servlets and all presentation tier stuffs.
MyJava_Module – Contains common classeslike constants, utilities.
Starting with MyProject, select properties from right click menu. In property dialog, select “J2EE Module Dependencies”. You will find all the modules. Select all as project is dependent on all modules.
Now you can configure dependency of individual module, let’s take an example of web module. In “J2EE Module Dependencies” window, you will find a radio button group which would has by default “Use EJB Client Jars” option selected. That radio button groups defines visibility of EJB jar.
As clients of any EJB should be isolated from bean classes, it is preferable not to select other options where you can define dependencies with EJB jar file. After all, EJB clients should not have any kind of dependencies with EJB jar.
Now here if I select MyEJB_ModuleClient.jar only, MyWeb_Module won’t able to access classes defined in MyJava_Module until you redefine module dependencies.
Similarity you can define dependencies with Utility project, specifically saying third party libraries. You want one module to access one jar and isolate others all you need to do is add library in main project (MyProject in my case) and then configure dependencies of other modules.
This feature takes care of dependencies on behalf of you and let you concentrate on other tasks.
Posted by Jay Rajani at 12:42 PM 0 comments
Labels: Articles, Configuration, Development, Eclipse, Open Source, Programming, Tips, Tools, Tutorials
Thursday, May 15, 2008
Servicemix PollingComponentSupport - stuck if lower period and higher threadPoolSize
We have two FilePoller components here and we kept the period to 10 minutes. Which means the instance of FilePoller will run at every 10 minutes. Now say if I have two instances, each run at 10 minutes, and 5 minutes gap between them. So it means after every five minutes, files will be picked by one of them. And the WorkManager, which is given to FilePoller as property, has threadPoolSize of 30.
All was working fine with this configuration.30 threads in pool, every five minutes any of two pullers will pick files. But now we have to change it. When we changed the period from 10 minutes to 1 minute, we got strange errors. Yes even you won't believe it. While testing concurrency we got, FileNotFound exception even though the file exists there, and many other concurrency issues. We looked into the logs and found that sometimes the load goes only on one server and the other is always idle doing nothing. Because when it comes, the first one is doing task.
Then we decided to decrease the thredPoolSize. Becasue if puller get 30 files for 30 threads from the pool, and when it comes to 31st file from the folder and if any of previous 30 threads is in the pool after it has completed its job, then it will take the file. It means, though we have pool size of 30, it may be possible that it can process more than 30 files per instance (say 32 to 38 files). So we decided to make pool size to 10.
Now after making 10 it seems to be working fine. Each one is picking almost equal numbers of files and sharing load as it should. Let’s see if more issues are coming or not.
So, key thing to be remembered is
"Keep you threadPoolSize and period on which instance will run in proportion to each other. If period is long then threads can be more but if you want to reduce the period, you must take care of pool size."
Posted by Parth Barot at 3:35 PM 0 comments
Labels: Articles, Development, Frameworks, Open Source, Programming, Spring, Tips, Tutorials
