SOLVED: Web Development Assignment

CO4752 Web Development Assignment (2020 C)

Date issued:   9th, March, 2020                                            Date due: 11:59PM, 18st, May, 2020

 

This assignment is worth 100% of the assessment for this module.

 

Learning Outcomes assessed

1.  Understanding of multi-tier web application architecture and corresponded infrastructure setup.

2.  Use of Servlets as a middle layer technology for web application development

3.  Use of JavaScript and AJAX for web front development.

4.  Use of JSON/XML as for exchanging messages between web portal and server application

5.  Use of HTML/HTML 5 and CSS for web portal rendering.

6.  Use of JDBC to interact with database (MySQL).

 

Introduction

In this assignment, you are required to complete an online student-accommodation management system, which is composed of three tiers (web portal, middle layer and database). The functional requirement of the system is as the followings:

1.      Admin users who are able to browse/add/remove/update/search/ accommodation records through a web portal. Records are stored in a back-end database. Each record should contain:

 

a.       Room id

b.      Room type

c.       Room location

d.      Monthly Charge

e.       Room Status (allocated/available)

f.       Payment status

2.      Student users are able to select their accommodation that are added by the admin user. Each of them can choose one type of room.

3.      Both type of users will need to log into the system. Therefore, your system should provide basic user registration/login/logout functions.

 

 

Task Details

Note: for guidelines what to hand in and what the marker will be looking for, see the marking scheme. Working INDIVIDUALLY:

1.      Web portal: Your web portal should contain at least the following pages:

1.      Login/Registration page for both admin and student users.

 

2.      Admin user’s room management page: where admin user can perform the required operations. The page should show a list of rooms (and their information) and admin users are able to add new room; update information about existing rooms.

3.      Student user’s accommodation management page: where a student can view information about each different types of room and select/update his or her own accommodation

The architecture of the assignment needs to be strictly three tiers based. This means web portal is only used for rendering contents, taking inputs from users and feeding back results. The portal is not supposed to handle any business logics (JSP, PHP, Ruby on Rails style portal and things similar will NOT be accepted and marked). You will need to use Javascript+HTML 5+CSS for your web portal development. Necessary third-party libraries are allowed in the implementation.

2.      Middle Layer: A middle layer that talks to both database and web portal through message exchange. It should handle all business logics. The middle layer needs to be implemented

 

conforming to Java Servlet standard. It needs to be done in JAVA rather than any other programming languages.

3.      Database: MySQL database will be used to store data. You will need to define your database schema that support your application. For this assignment, you do not need to worry too much about the DB normalisation rules and etc. You can use fewer tables as long as they satisfy your needs.

4.      Message Exchange: The messages that are exchanged between the portal and middle layer need to be JSON. This makes the whole system a completely decoupled manner. No portal will be relying on any specific middle layer’s implementation and vice versa. Both of them are only dependent on the contents of the messages exchanged and interpretations of those messages.

 

What You Should Submit:

You should submit a zip package and a source code text file via the links on Blackboard and Turnitin (code source file needs to be submitted via the Turnitin link). Both files should follow the name convention: YourRegistrationNumber_(FirstName LastName).zip/txt.

·         The zip file should contain the following contents:

a.

b.        Your web portal folder. This folder needs to be directly deployable and runnable on tomcat 7+ servers. Folder that fails to be deployed or run will be regarded as a failure, and you will lose half marks for web portal section.

c.        A war file which can be directly deployed on tomcat 7+ servers. Failure on the deployment will lose you half marks for middle layer sections. You will need to be very careful with the all the libraries that you choose to use. Make sure you pack them up in the war file so when the war is deployed, the tomcat server will not complain about missing libraries.

d.      A db.sql file that contains all the data you’ve created or used or tested for your project. It can be restored to MySQL database.

e.       A report that explains your design, implementation details and any potential problems that you are aware of your development and potential improvement that can be done. Full lists of messages (json syntax) that are exchanged between your Servlet service and portal. Explain how the http protocol is used in your implementation if any.

·        The source code text file must contain all the source codes you implemented. The content of the file is copied and pasted from all your own *.java source files.

 

Failure to provide either of the above files will be considered as an incomplete submission and your work will NOT be marked until both files are submitted. (It will be treated as a late submission). In addition, the work implemented using other frameworks/languages such as JSP, ASP, PHP will NOT be marked and you will receive no mark for your submission.

Assessment Criteria:

When I am marking this assignment, I will deploy your submission to my own environment. Please

don’t assume that I will be in any of the computing labs or place similar. So please make sure your submission is going to work on any PC. Also, please make sure you web portal will work on google chrome browser (it has better support to 3rd party libs for javascript).

 

1.Web Portal Development                                                                                                    40%

Characteristics

Mark Range

Has basic functions as specified in the requirements. User can do very basic operations through the portal. Pages are rendered using HTML only. CSS is not applied appropriately. Key interactions and communication with back end is handled by HTML form only. Implementation contains errors but doesn’t affect

browsing rendering. Deployable on Tomcat server 7+

0-15

 

Proper JavaScript is used and applied to all key operations/components in the portal. CSS is applied appropriately. Message exchange and handling is performed without major errors. Layout of portal is properly designed. HTML can pass W3C validator.

Exceptions returned from backend are handled properly using warning messages.

16-30

Excellent portal design with easy to use navigations. Authorisation and authentication are handled properly on the portal side. Have used local caching for data that need to be processed by users for better usability. Major PC browsers are supported (Chrome, Firefox, IE, for Internet Explorer, IE8+ is fine), as well as

mobile devices browser with no issues.

31-40

2. Middle Layer                                                                                                                     40%

Basic operations are handled properly using Java Servlet framework. Servlet concept is applied correctly (state and data driven, HTTP verbs are used are used correctly) from the implementation. Deployable on Tomcat server 6+. Can talk to DB and return results to the portal, but with major fault or exceptions. Some

libraries required are missing.

0-15

No major exceptions or errors or they are handled properly. Transactions are handled correctly with database. Connections to DB are handled properly as well. (open/close). Sessions are implemented well. Use of web server context to exchange information if needed. Can handle all the messages that are passed in from the

portal. Authorisation and authentication are implemented on service side.

16-30

Service lifecycle is handled well (activities when service is loaded, started, destroyed etc.) if needed. Necessary configures, such as DB connection information, are not hardcoded but are specified in configure file and is loaded into the application context. Concurrent control is implemented and implemented caching

mechanism for better service performance.

31-40

3. Report                                                                                                                                 20%

Servlet APIs are specified. Problems, experiences while doing the assignment are

summarised very briefly. Focused only on what you have done.

0-10

Deep analysis of your own implementation including the pros and cons. Possible improvement for the current implementation. Complete list of messages that are exchanged between server and portal as well as detailed comments (think it as a

communication document between the service developer and portal developer).

11-20

 

Late work

Except where an extension of the hand-in deadline date has been approved (using extenuating circumstances forms), work that is handed in up to 5 days late will be capped to 50%. After this, it will receive a mark of 0%:

LEAVE A COMMENT

Comment Box is loading comments...