Thursday, December 20, 2012

Ant build with lib


Cấu trúc folder :








file Java :

 package oata;  
import org.apache.log4j.Logger;
import org.apache.log4j.BasicConfigurator;
public class HelloWorld {
static Logger logger = Logger.getLogger(HelloWorld.class);
public static void main(String[] args) {
BasicConfigurator.configure();
logger.info("Hello World"); // the old SysO-statement
}
}

File log4j.properties :

 log4j.rootLogger=DEBUG, stdout  
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%m%n


File build :


 <project name="HelloWorld" basedir="." default="main">  
<property name="src.dir" value="src" />
<property name="build.dir" value="build" />
<property name="classes.dir" value="${build.dir}/classes" />
<property name="jar.dir" value="${build.dir}/classes" />
<property name="main-class" value="oata.HelloWorld" />
<property name="lib.dir" value="lib"/>
<path id="classpath">
<fileset dir="${lib.dir}" includes="**/*.jar"/>
</path>
<target name="clean">
<delete dir="${build.dir}" />
</target>
<target name="compile">
<mkdir dir="${classes.dir}" />
<javac srcdir="${src.dir}" destdir="${classes.dir}" classpathref="classpath"/>
<copy todir="${classes.dir}">
<fileset dir="${src.dir}" excludes="**/*.java"/>
</copy>
</target>
<target name="jar" depends="compile">
<mkdir dir="${jar.dir}" />
<jar destfile="${jar.dir}/${ant.project.name}.jar" basedir="${classes.dir}" >
<manifest>
<attribute name="Main-Class" value="${main-class}" />
</manifest>
</jar>
</target>
<target name="run" depends="jar">
<java fork="true" classname="${main-class}" >
<classpath>
<path refid="classpath" />
<path id="application" location="${jar.dir}/${ant.project.name}.jar" />
</classpath>
</java>
</target>
<target name="clean-build" depends="clean,jar" />
<target name="main" depends="clean,run" />
</project>

Wednesday, December 19, 2012

How to change the ‘root’ password for MySQL in XAMPP?

By default, when you install XAMPP in your windows machine, the ‘root’ password for the MySQL is set to empty. But this is not recommended, as the MySQL database without a password will be accessible to everyone. To avoid this, a proper/secure password must be set to the user ‘root‘. To do it in XAMPP, there are two ways.


Method 1: 

Reset XAMPP MySQL root password through web interface: After you started your XAMPP server, go to the browser and type the URL http://localhost/security/ (incase you’ve modified XAMPP server port, you need to include that port number also in previous URL). The security page will be shown where you can change the ‘root’ password for MySQL. This will update the phpMyAdmin config also.


Method 2: reset XAMPP MySQL root password through SQL update

  1. Start the Apache Server and MySQL instances from the XAMPP control panel.
  2. After the server started, open any web browser and givehttp://localhost:8090/phpmyadmin/ (if you are running XAMPP on 8090 port). This will open the phpMyAdmin interface. Using this interface we can manager the MySQL server from the web browser.
  3. In the phpMyAdmin window, select SQL tab from the right panel. This will open the SQL tab where we can run the SQL queries.
  4. Now type the following query in the textarea and click Go
    UPDATE mysql.user SET Password=PASSWORD('password') WHERE User='root';
    FLUSH PRIVILEGES;
  5. Now you will see a message saying that the query has been executed successfully.
  6. If you refresh the page, you will be getting a error message. This is because the phpMyAdmin configuration file is not aware of our newly set root passoword. To do this we have to modify the phpMyAdmin config file.
  7. Open the file [XAMPP Installation Path] / phpmyadmin / config.inc.php in your favorite text editor.
  8. Search for the string $cfg['Servers'][$i]['password'] = ”; and change it to like this, $cfg['Servers'][$i]['password'] = ‘password’; Here the ‘password’ is what we set to the ‘root’ user using the SQL query.
  9. Now all set to go. Save the config.inc.php file and restart the XAMPP server.

references : http://veerasundar.com/blog/2009/01/how-to-change-the-root-password-for-mysql-in-xampp/



PS : Some initializing information when run :/opt/lampp/lampp security

XAMPP:  Quick security check...
XAMPP:  Your XAMPP pages are NOT secured by a password.
XAMPP: Do you want to set a password? [yes]
XAMPP: Password:
XAMPP: Password (again):
XAMPP:  Password protection active. Please use 'xampp' as user name!
XAMPP:  MySQL is accessable via network.
XAMPP: Normaly that's not recommended. Do you want me to turn it off? [yes]
XAMPP:  Turned off.
XAMPP:  MySQL has to run before I can check the security.
XAMPP:  MySQL has to run before I can check the security.
XAMPP:  MySQL has a root passwort set. Fine! :)
XAMPP:  The FTP password for user 'daemon' is still set to 'xampp'.
XAMPP: Do you want to change the password? [yes]
XAMPP: Password:
XAMPP: Password (again):
XAMPP: Reload ProFTPD...not running.
XAMPP:  Done.


Tuesday, December 18, 2012

Các thao tác cơ bản trên DB2

Phần 1 :

File code tạo table trong cơ sở dữ liệu DB2

File này có tên là testdb.sql

1:  CREATE TABLE EMPLOYEE(  
2: ID SMALLINT NOT NULL,
3: NAME VARCHAR(9),
4: DEPT SMALLINT CHECK (DEPT BETWEEN 10 AND 100),
5: JOB CHAR(5) CHECK (JOB IN ('Sales', 'Mgr', 'Clerk')),
6: SALARY DECIMAL(7,2),
7: COMM DECIMAL(7,2),
8: PRIMARY KEY (ID)
9: );


Phần 2 :

Các lệnh cơ bản trong DB2


1:  start database :  
2: DB2 START
3: create database :
4: DB2 CREATE DATABASE TESTDB3 AUTOMATIC STORAGE YES
5: list database :
6: DB2 LIST DB DIRECTORY
7: connect with database :
8: DB2 CONNECT TO TESTDB02
9: list of tables :
10: DB2 LIST TABLES
11: create tables from files:
12: db2 -tvf sql_file_name
13: insert value to table:
14: INSERT INTO EMPLOYEE VALUES ( 1, 'DucNguyen', 11, 'Mgr', 3200, 4500)
15: INSERT INTO EMPLOYEE VALUES ( 3, 'ThienPham', 13, 'Clerk', 3500, 4000)
16: INSERT INTO EMPLOYEE VALUES ( 5, 'TungPham', 13, 'Sales', 3600, 4530)
17: INSERT INTO EMPLOYEE(ID, NAME, DEPT, JOB, SALARY, COMM) VALUES (2,'VuTruong',11,'Sales',3500,4000)
18: select all rows from table:
19: SELECT * FROM EMPLOYEE

Phần 3 : Code Java kết nối DB2 File name : EzJava.java
1:  import java.sql.*;  
2: public class EzJava
3: {
4: public static void main(String[] args)
5: {
6: String urlPrefix = "jdbc:db2:";
7: String url= urlPrefix +"//127.0.0.1:50000/TESTDB02";
8: String user="db2inst1";
9: String password="123456";
10: String empNo = null;
11: String empName =null;
12: Connection con=null;
13: Statement stmt=null;
14: ResultSet rs=null;
15: System.out.println ("**** Enter class EzJava");
16: try
17: {
18: // Load the driver
19: Class.forName("com.ibm.db2.jcc.DB2Driver");
20: System.out.println("**** Loaded the JDBC driver");
21: // Create the connection using the IBM Data Server Driver for JDBC and SQLJ
22: con = DriverManager.getConnection (url, user, password);
23: // Commit changes manually
24: con.setAutoCommit(false);
25: System.out.println("**** Created a JDBC connection to the data source");
26: // Create the Statement
27: stmt = con.createStatement();
28: System.out.println("**** Created JDBC Statement object");
29: // Execute a query and generate a ResultSet instance
30: rs = stmt.executeQuery("SELECT ID FROM EMPLOYEE");
31: System.out.println("**** Created JDBC ResultSet object");
32: // Print all of the employee numbers to standard output device
33: while (rs.next()) {
34: empNo = rs.getString(1);
35: empName = rs.getString(2);
36: System.out.println("ID : " + empNo+" | Name : " + empName);
37: }
38: System.out.println("**** Fetched all rows from JDBC ResultSet");
39: // Close the ResultSet
40: rs.close();
41: System.out.println("**** Closed JDBC ResultSet");
42: // Close the Statement
43: stmt.close();
44: System.out.println("**** Closed JDBC Statement");
45: // Connection must be on a unit-of-work boundary to allow close
46: con.commit();
47: System.out.println ( "**** Transaction committed" );
48: // Close the connection
49: con.close();
50: System.out.println("**** Disconnected from data source");
51: System.out.println("**** JDBC Exit from class EzJava - no errors");
52: }
53: catch (ClassNotFoundException e)
54: {
55: System.err.println("Could not load JDBC driver");
56: System.out.println("Exception: " + e);
57: e.printStackTrace();
58: }
59: catch(SQLException ex)
60: {
61: System.err.println("SQLException information");
62: while(ex!=null) {
63: System.err.println ("Error msg: " + ex.getMessage());
64: System.err.println ("SQLSTATE: " + ex.getSQLState());
65: System.err.println ("Error code: " + ex.getErrorCode());
66: ex.printStackTrace();
67: ex = ex.getNextException(); // For drivers that support chained exceptions
68: }
69: }
70: } // End main
71: } // End EzJava


Cài đặt XAMMP trên LINUX với NOMAL USER

Bước 1 : Sau khi cài đặt chúng ta chuyển đến folder chứa LAMMP :

#cd /opt/lampp/

Liệt kê danh sách file trong thư mục gốc của LAMMP :


Nhiệm vụ được đặt ra là đổi nobody thành tên username của chúng ta :

Bước 2 : Cần phải xác định được username mà chúng ta đang sử dụng là gì :

#whoami

Xác định user-name đang sử dụng thuộc group nào :

#goups



như hình trên ta có user-name : vanduc1102 thuộc về 2 group là rootdb2iadm1

Bước 3: Cấp quyền sử dụng cho thư mục  htdocs


Bước 4 :

mở file httpd.conf trong /opt/lammp/etc/


# gedit /opt/lampp/etc/httpd.conf 



xem đoạn

User nobody

Group nogroup

</IfModule>

</IfModule>


Và đổi thành

User vanduc1102

Group nogroup

</IfModule>

</IfModule>




Khởi động lại lammp là ok .
#/opt/lammp/lammp start

Liệt kê các port đang được mở và mở port

Chúng ta sử dụng lệnh sau :

netstat -tunap | grep LISTEN

Ví dụ :


Hoặc :


Scan all port Openning in centos using :

nmap 127.0.0.1





If you want to open a single port:

open iptables file : vi /etc/sysconfig/iptables

Add below line to open port.

-A INPUT -m state --state NEW -m tcp -p tcp --dport 143 -j ACCEPT

For multiple, you can use the following instead (or repeat the above line multiple times):

-A INPUT -m state --state NEW -m tcp -p tcp -m multiport --dports 22,80,143 -j ACCEPT

The reason your line doesn't work is likely because you don't have a chain named 'RH-Firewall-1-INPUT'.

CentOS 6 simply uses 'INPUT' as the chain name.

You'll note something like the following at the top of the default config, naming the chains that exist:

:INPUT ACCEPT [0:0]
:FORWARD ACCEPT [0:0]
:OUTPUT ACCEPT [0:0]

Just to explain a bit further, the line -A INPUT -m state --state NEW -m tcp -p tcp --dport 143 -j ACCEPT means:

-A: append a rule
INPUT: to the INPUT chain
-m state: use the 'state' module
--state NEW: only look for NEW connections (i.e. not those that are previously established/related)
-m tcp: use the tcp module
-p tcp: look for packets using the TCP protocol
--dport 143: look for packets with a destination port of 143


To save  :
#/sbin/service iptables save
#/etc/init.d/iptables restart

Thursday, November 29, 2012

Connect with Database Postgres using MAVEN

Step 1: Set up MAVEN in enviroment variable

Test command



Step 2 : Creating a mavent project using quick start template of maven

#mvn archetype:generate -DgroupId=com.mycompany.app / -DartifactId=my-app  -DarchetypeArtifactId=maven-archetype-quickstart -DinteractiveMode=false

-DartifactId : name of project
 -DgroupId  : name of package

After run command we have result:


Step 3 : Main code in App.java

 package com.mycompany.app;  
import java.sql.DriverManager;
import java.sql.Connection;
import java.sql.SQLException;
public class App {
public static void main(String[] argv) {
System.out.println("-------- PostgreSQL "
+ "JDBC Connection Testing ------------");
try {
Class.forName("org.postgresql.Driver");
} catch (ClassNotFoundException e) {
System.out.println("Where is your PostgreSQL JDBC Driver? "
+ "Include in your library path!");
e.printStackTrace();
return;
}
System.out.println("PostgreSQL JDBC Driver Registered!");
Connection connection = null;
try {
connection = DriverManager.getConnection(
"jdbc:postgresql://10.190.201.79:5432/postgres", "postgres",
"admin");
} catch (SQLException e) {
System.out.println("Connection Failed! Check output console");
e.printStackTrace();
return;
}
if (connection != null) {
System.out.println("You made it, take control your database now!");
} else {
System.out.println("Failed to make connection!");
}
}
}
Step 4 : Contain in pom.xml


 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>PostgreSQL</groupId>
<artifactId>postgres</artifactId>
<packaging>jar</packaging>
<version>1.0-SNAPSHOT</version>
<name>postgres</name>
<url>http://maven.apache.org</url>
<dependencies>
<!-- Add Junit lib -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<!-- Add postgresql JDBC lib-->
<dependency>
<groupId>postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>9.1-901.jdbc4</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<archive>
<manifest>
<addClasspath>true</addClasspath>
<mainClass>com.mycompany.app.App</mainClass>
</manifest>
</archive>
</configuration>
</plugin>
<!--
to package this program with external jar files
-->
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<configuration>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
<archive>
<manifest>
<mainClass>com.mycompany.app.App</mainClass>
</manifest>
</archive>
</configuration>
<executions>
<execution>
<id>with-lib</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
</plugin>
<!--
To run program with command
#mvn exec:java
-->
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.1</version>
<configuration>
<mainClass>com.mycompany.app.App</mainClass>
</configuration>
</plugin>
</plugins>
</build>
</project>

Step 5 

$cd my-app
$mvn package
$mvn exec:java

Result :





Friday, October 5, 2012

All about “static” Keyword


1. Static variable

  • It is a variable which belongs to the class and not to object(instance)
  • Static variables are initialized only once , at the start of the execution . These variables will be initialized first, before the initialization of any instance variables
  • single copy to be shared by all instances of the class
  • A static variable can be accessed directly by the class name and doesn’t need any object
  • Syntax : <class-name>.<variable-name>


2. Static method

  • It is a method which belongs to the class and not to the object(instance)
  • A static method can access only static data. It can not access non-static data (instance variables)
  • A static method can call only other static methods and can not call a non-static method from it.
  • A static method can be accessed directly by the class name and doesn’t need any object
  • Syntax : <class-name>.<method-name>
  • A static method cannot refer to “this” or “super” keywords in anyway
Side Note:
  • main method is static , since it must be be accessible for an application to run , before any instantiation takes place.
Lets learn the nuances of the static keywords by doing some excercises!
Assignment: To Learn working of static variables & methods
Step 1) Copy the following code into a editor
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
class Student {
int a; //initialized to zero
static int b; //initialized to zero only when class is loaded not for each object created.
  Student(){
   //Constructor incrementing static variable b
   b++;
  }
   public void showData(){
      System.out.println("Value of a = "+a);
      System.out.println("Value of b = "+b);
   }
//public static void increment(){
//a++;
//}
}
class Demo{
   public static void main(String args[]){
     Student s1 = new Student();
     s1.showData();
     Student s2 = new Student();
     s2.showData();
     //Student.b++;
     //s1.showData();
  }
}
Step 2) Save & Compile the code. Run the code as, java Demo.
Step 3) Check output.
Step 4) It is possible to access a static variable from outside the class using the syntaxClassName.Variable_Name. Uncomment line # 27 & 28 . Save , Compile & Run . Observe the output.
Step 5) Uncomment line 15,16 & 17 . Save , Compile & Run.
Step 5) Error = ? This is because it is not possible to access instance variable “a” from static method “increment“.

3. static block

The static block, is a block of statement inside a Java class that will be executed when a class is first loaded in to the JVM
1
2
3
4
5
class Test{
 static {
 //Code goes here
 }
}
static block helps to initialize the static data members, just like constructors help to initialize instance members.

References