Skip to main content

Guessing Game Implementation using JSF

 In a typical Java Server Faces application each page connect to a managed bean, that have properties and methods that are associated with the components. This Guessing Game application consists of one managed bean and two views. All views are using same bean.
 The following are requirements for this application.
1. User must enter a number from 0 to 10.
2. Maximum number of attempt is 5.
3. If user guess a correct number with in 5 attempts, the success message is displayed to the user otherwise the failure message is displayed.
 Ok let's create a managed bean for implementing above requirements.
package com.pointerunits;

import java.io.IOException;
import java.util.Random;
import javax.faces.bean.ManagedBean;
import javax.faces.bean.SessionScoped;
import javax.faces.context.FacesContext;

@ManagedBean
@SessionScoped

public class GuessingGame {
 private int randomNumber;
 private int userNumber;
 private int minimum;
 private int maximum;
 private int allowableAttempts;
 private int userAttempts;
 private String message;
 public GuessingGame() {
  this.minimum = 0;
  this.maximum =10;
  this.allowableAttempts = 5; 
  this.initializeGame();
 }
 private void initializeGame() {
  Random randomGR = new Random();
  this.randomNumber = new Integer(randomGR.nextInt(this.maximum));
  System.out.println("Random number : " + this.randomNumber);
  this.userAttempts = 0;
  this.userNumber = 0;
  this.message = "";
 }
 public int getRandomNumber() {
  return randomNumber;
 }
 public void setRandomNumber(int randomNumber) {
  this.randomNumber = randomNumber;
 }
 public int getUserNumber() {
  return userNumber;
 }
 public void setUserNumber(int userNumber) {
  this.userNumber = userNumber;
 }
 public int getMinimum() {
  return minimum;
 }
 public void setMinimum(int minimum) {
  this.minimum = minimum;
 }
 public int getMaximum() {
  return maximum;
 }
 public void setMaximum(int maximum) {
  this.maximum = maximum;
 }
 public int getAllowableAttempts() {
  return allowableAttempts;
 }
 public void setAllowableAttempts(int allowableAttempts) {
  this.allowableAttempts = allowableAttempts;
 }
 public int getUserAttempts() {
  return userAttempts;
 }
 public void setUserAttempts(int userAttempts) {
  this.userAttempts = userAttempts;
 }
 public String getMessage() {
  return message;
 }
 public void setMessage(String message) {
  this.message = message;
 }
 public void playGame() throws IOException {
  this.userAttempts++;
  boolean isRedirect = false;
  if(this.userNumber == this.randomNumber) {
   this.message = "Hey..you got it. Total attempt is " + this.userAttempts ;
   isRedirect = true;
  }
  else if(this.userNumber > this.randomNumber){
   this.message = "Hey I am lesser than your guess";
  }
  else if(this.userNumber < this.randomNumber) {
   this.message = "Hey I am greater than your guess";
  }
  if(this.userAttempts == this.allowableAttempts) {
   this.message = "Hey..you have failed to guess.";
   isRedirect = true;
  }
  if(isRedirect) {
   FacesContext.getCurrentInstance().getExternalContext().redirect("guessingGameResponse.xhtml");
  }
 }
 
 public void resetGame() throws IOException {
  initializeGame();
  FacesContext.getCurrentInstance().getExternalContext().redirect("guessingGame.xhtml");
 }
}
 Here the redirect() method is used for redirecting to result page. Instead of you can use JSF navigation rule for redirection. The following facelet page is used for getting user input.

 Guessing Game


 
  

Hi, I am thinking of a number from #{guessingGame.minimum} to #{guessingGame.maximum}. Can you guess it?

 The following facelet page is used for displaying result.

 Guessing Game


 
  
  

  

Do you want to play a game once again?

 You can download an entire application from GitHub.

Comments

for ict 99 said…
Interesting Article

JSF online training JSF online training Java Online Training Java Online Training

JSF training in Chennai JSF training in Chennai Java Training in CHennai

Popular posts from this blog

Getting key/value pair from JSON object and getting variable name and value from JavaScript object.

 Hi, I had faced one issue like this. I have an JSON object but I don't know any key name but I need to get the all the key and corresponding value from JSON object using client side JavaScript. Suddenly I wondered whether it's possible or not, after that I had done lot of workaround and finally got this solution. See the below example.    function getKeyValueFromJSON() {     var jsonObj =  {a:10,b:20,c:30,d:50} ;     for ( var key in jsonObj) {       alert( "Key: " + key + " value: " + jsonObj[key]);     }  }  In this example I have created the one json array as string, and converted this string into JSON object using eval() function. Using for-each loop I got all the key value from jsonObj, and finally using that key I got the corresponding value.  Finally I got the alert like this,    Key: a value:10    Key: b value:20    Key...

Meteor tutorial - Part II - Building mobile applications

In my previous blog post , I have explained basics of meteor. In this tutorial I am going to add mobile support to the existing meteor application. Installing mobile SDKs Before going to start we need to install IOS and android SDKs (Software development kit). Here I am installing SDKs for iOS. Please keep in mind this is one time process. For installing iOS SDKs, we need to invoke “meteor install-sdk ios”. The same way you can install android SKDs by invoking “meteor install-sdk android” command. Adding mobile platform support I am using already created application called “myapp” and going to add iOS platform support by invoking a command “ meteor add-platform ios ”. We can add android platform by invoking a command  “ meteor add-platform android ”. Running application on mobile emulator Once we add mobile platform then we can run our application by using real mobile device or emulator. I have added IOS platform to myapp already. Now I am going to ru...

Meteor tutorial - Part I

What is Meteor? Meteor is a complete open source platform for building web and mobile application by using JavaScript. It is a combination of NodeJs, MongoDB and client side JavaScript. Installing meteor Meteor supports windows, linux and Mac operating systems. Invoke below command in terminal for installing meteor in mac operating system. Check below link for installing meteor on other operating systems. http://docs.meteor.com/#/basic/quickstart Creating an application The command “meteor create <<app_name>>” is used for creating new meteor application. I have created an app called “myapp” and will see how we can run the application. Running an application “meteor run” command is used for running meteor application. Internally it start a node js server and by default that will listen 3000 port number. Just make sure you are in project directory (myapp) before invoking run command. ' Other useful meteor commands Meteor provides lot of usefu...