Skip to main content

Creating a dApp using Ethereum and Meteor (Setting up)

This blog posts contains the step to be followed when creating a simple dApp (Decentralized Application) using Ethereum and Meteor. 

This application will not use the actual ethereum blockchain. Instead it will connect to the Testnet. This application is developed for Demo purposes. Hence, Meta mask extention will be used. If you need to connect to the main network, geth client or any other client for Ethereum should be used.

Step 1: Create a meteor project

In order to create a new meteor application, run the following command inside the directory you want the app to be created in.

meteor create <app_name>

The application will be created as follows.



Step 2: Add Web3 to the project

Web3 library is what allows you to interact with the ethereum blockchain. Web3 library can be found at [1]. Inside the meteor application just created run the following command to add Web3.


meteor add ethereum:web3



Step 3: Download and install Metamask extension for Chrome

This will allow you to interact with the Ethereum blockchain without having to download the entire blockchain into your local machine like geth client does.





Make sure you are connected to the Test Network as shown below.


Step 4: Launch the Meteor Application

To run the meteor application give the following commands.

meteor npm install


 meteor 



Now if you browse localhost:3000 via the browser, your application will be available.


Step 5: Open the application in an IDE / Text Editor

Create a folder (lib) and a JS (lib.js) file inside that folder as below.



Step 6: Developing a sample dApp

1) Initialize web3 object


Now your application is connected to the Ethereum blockchain.



2) Checking the balance

Inside the main.js insert the following code inside the button click function.

web3.eth.getBalance("0x6DcFA49E1c61758AFd02789c6d2bacdfC4c9cEd9", function (error,result) {
  instance.counter.set(result);});

This address should be replaced with yours.

Your address can be found through the meta mask extention as below.

Your final main.js will look like below.




You can also change your HTML as below.



When you reload the application and click on the button, the balance will be shown.




Comments

Popular posts from this blog

Fixing 'java RMI - ConnectException: Operation timed out' in WSO2 Enterprise Integrator 6.4

If you ever come across the below exception when running WSO2 Enterprise Integrator 6.4, here is the fix. This error occurs when you have multiple IP addresses from different networks configured in your etc/hosts as below. 10.xxx.x.xxx localhost 192.xxx.x.xxx localhost So simply, removing the unnecessary one and leaving the one of the network that you are currently connected to should resolve this issue. 10.xxx.x.xxx localhost

Student Information System - Java (SLIIT - ST2 PROJECT)

Student Information System (Github Project) This system is developed in Java and mySQL as a group project by me and 3 other members during a period of 1 month. The system allows the administrator to,  enroll students to the system  update enroll information  add/update course and degree program details  generate reports  create exams and edit relevant information  calculate gpa of the relevant exam  assign lecturers to courses  add lecturers/update details Lecturers to,  assign course grades  view their feedback  generate reports  view student / course / degree program details Students to,  view their profile  view their grading information  give feedback to lecturers   view lecturer / course / degree program details and other features. Below are some interfaces of the project. (Splash Screen) (Login) (Admin View) (Student Re...

SIMPLE BLACKJACK GAME IN JAVA (CONSOLE)

import java.util.Scanner; class BlackJack{     public static void main(String[] args)      {         int player_random1 = 100;         int player_random2 = 100;         while(player_random1 >= 12 || player_random2 >= 12  || player_random1 < 3 || player_random2 <3)         {             player_random1 = (int)(Math.random()*100);             player_random2 = (int)(Math.random()*100);         }                  int player_total = player_random1 + player_random2;                  System.out.println("You get a "+player_random1+" and a "+player_random2);         System.out.println("Your total is "+player_total); if(player_total==21)  ...