Answered step by step
Verified Expert Solution
Link Copied!

Question

1 Approved Answer

Plz code in java with comments so it esay to follow Assignment guidelines: Traditional password entry schemes are susceptible to shoulder surfing in which an

Plz code in java with comments so it esay to follow

Assignment guidelines:

Traditional password entry schemes are susceptible to shoulder surfing in which an attacker watches an unsuspecting user enter their password or PIN number and uses it later to gain access to the account. One way to combat this problem is with a randomized challenge-response system. In these systems the user enters different information every time based on a secret in response to a randomly generated challenge. Consider the following scheme in which the password consists of a five-digit PIN number (00000 to 99999). Each digit is assigned a random number that is 1, 2, or 3. The user enters the random numbers that correspond to their PIN instead of their actual PIN numbers.

For example, consider an actual PIN number of 12345. To authenticate the user would be presented with a screen such as:

PIN: 0 1 2 3 4 5 6 7 8 9

NUM: 3 2 3 1 1 3 2 2 1 3

The user would enter 23113 instead of 12345. This does not divulge the password even if an attacker intercepts the entry because 23113 could correspond to other PIN numbers, such as 69440 or 70439. The next time the user logs in, a different sequence of random numbers would be generated, such as:

PIN: 0 1 2 3 4 5 6 7 8 9

NUM: 1 1 2 3 1 2 2 3 3 3

Write a class AuthenticateDemo to use the Authenticate class, to simulate the authentication process.

Note:

1. Store an actual PIN number in your program.

2. The program should use an array to assign random numbers to the digits from 0 to 9.

3. Output the random digits to the screen, input the response from the user, and output whether or not the users response correctly matches the PIN number.

Sample Run for Actual password 99508:

A. correct input:

----jGRASP exec: java AuthenticateDemo

Welcome! To log in, enter the random digits from 1-3 that correspond to your PIN number. PIN digit: 0 1 2 3 4 5 6 7 8 9 Random #: 2 1 1 2 2 3 3 2 1 2 Enter code. 22321 Correct! You may now proceed.

----jGRASP: operation complete.

B. Non correct input:

----jGRASP exec: java AuthenticateDemo

Welcome! To log in, enter the random digits from 1-3 that correspond to your PIN number. PIN digit: 0 1 2 3 4 5 6 7 8 9 Random #: 2 3 3 3 3 3 1 3 1 2 Enter code. 22623 Error, invalid password entered.

----jGRASP: operation complete.

Note:

Assignment must have the following files:

1. class Authenticate, in file Authenticate.java

2. class AuthenticateDemo, in a file AuthenticateDemo.java

Step by Step Solution

There are 3 Steps involved in it

Step: 1

blur-text-image

Get Instant Access to Expert-Tailored Solutions

See step-by-step solutions with expert insights and AI powered tools for academic success

Step: 2

blur-text-image

Step: 3

blur-text-image

Ace Your Homework with AI

Get the answers you need in no time with our AI-driven, step-by-step assistance

Get Started

Recommended Textbook for

Database Concepts

Authors: David Kroenke, David Auer, Scott Vandenberg, Robert Yoder

8th Edition

013460153X, 978-0134601533

More Books

Students also viewed these Databases questions

Question

Define and discuss affirmative action.

Answered: 1 week ago

Question

Define the term Working Capital Gap.

Answered: 1 week ago

Question

18. If you have power, then people will dislike and fear you.

Answered: 1 week ago