Skip to content

Latest commit

 

History

History
172 lines (121 loc) · 10.8 KB

File metadata and controls

172 lines (121 loc) · 10.8 KB

Flight Booking System for Airlines (Java Web Application) ✈️

views Open Source Love svg1 GitHub Forks GitHub Issues contributions welcome

A fully responsive web-based Flight Booking System for Turkish Airlines based on the Model View Controller (MVC) Architecture made using Java Servlets, Java Server Pages (JSPs). Moreover authentication and authorization for users is implemented using Tomcat Roles. The web-application is also secured against SQL Injection and Cross-Site Scripting attacks.

Technologies Used

  • Frontend: HTML, CSS, JavaScript, Jquery, Bootstrap, Java Server Pages (JSPs), AJAX (for a Flight Search Widget)
  • Backend: Java Servlets, Java Models, Microsoft Access (Database)
  • Webservices: SOAP Web Services (to get price and number of seats)
  • Security Features: SQL Injection, Cross-Site Scripting (XSS), Tomcat Roles

Roles

Following roles are implemented:

  • Airline Admin
  • Airline Manager
  • Customer

Workflow (Functionalities)

This is for just one airline who wants to sell seats to their customers via internet.

Following are the steps of work flow:

  1. Airline Admin will set the prices of the seats. There should be three types of seats:
    • First Class
    • Business
    • Economy
  2. The Airline Admin should be able to create and update the features of each type of seat.
  3. The Airline Admin should be able to set the total number of seats for each flight.
  4. Airline Manager should see a list of seats which the Admin has added or edited when he/she logs in.
  5. Airline Manager then needs to approve the new price or updates.
  6. When the price and update is approved by the manager only then it should be available for the customer to buy.
  7. The Customer should be able to buy seats based on availability.
  8. When a customer buys a ticket the system should be able to calculate how many seats are left. If all seats are bought the application should not let the customers buy more seats.
  9. The Customer should be able to select the following, to select a seat:
    • origin and destination cities
    • dates of travel
    • number of people traveling
  10. When the customer selects the seat and confirms the booking flight Itinerary should be shown to the customer.
  11. When the customer approves the itinerary the customer should be taken to a payment page where the total price should be shown. When the customer presses the pay button consider the transaction done and mark the seat sold.
  12. Once the seat is sold, send out an email to the customer with the flight itinerary.

Interface

Home Pages

Login Page and Book Flight

Current Bookings and Itinerary

Seat Features and Approval

How to Run

1- Install these:

2- Open Netbeans IDE and go to Services > Servers > Apache Tomcat. Right click "Apache Tomcat" and select Properties. Copy the Catalina Base Path and open it. Open the "conf" folder and then the "tomcat-users.xml" file there. Copy the following lines and paste them in the tomcat-users.xml file before closing tag

<role rolename="Manager"/>
<role rolename="Admin"/>
<role rolename="Customer"/>

<user username="[email protected]" password="a" roles="Admin"/>
<user username="[email protected]" password="m" roles="Manager"/>
<user username="[email protected]" password="c" roles="Customer"/>

Morever, open and read the file. Only the users authenticated in this file are allowed to login and use the Booking System. Use above mentioned credentials to login through the Login Page.

3- Restart NetBeans IDE. Click on File -> Open Project and browse to the downloaded folder named "Project". There will be two projects there "Turkish Airlines" and "WSTester" (which is basically a project to test the Web Services). Select both and open them. Both projects will be loaded. Now first run the Turkish Airlines project, then to test the web services run WSTester project.

Author

You can get in touch with me on my LinkedIn Profile: LinkedIn Link

You can also follow my GitHub Profile to stay updated about my latest projects: GitHub Follow

If you liked the repo then kindly support it by giving it a star ⭐ and share in your circles so more people can benefit from the effort.

Contributions Welcome

GitHub Issues

If you find any bugs, have suggestions, or face issues:

  • Open an Issue in the Issues Tab to discuss them.
  • Submit a Pull Request to propose fixes or improvements.
  • Review Pull Requests from other contributors to help maintain the project's quality and progress.

This project thrives on community collaboration! Members are encouraged to take the initiative, support one another, and actively engage in all aspects of the project. Whether it’s debugging, fixing issues, or brainstorming new ideas, your contributions are what keep this project moving forward.

With modern AI tools like ChatGPT, solving challenges and contributing effectively is easier than ever. Let’s work together to make this project the best it can be! 🚀

License

MIT

Copyright (c) 2018-present, harismuneer


Waving hand Hey there, I'm Haris Muneer 👨🏻‍💻

Total Github Stars Total Github Followers


  • 🕸️ Founder of Cyfy Labs: At Cyfy Labs, we provide advanced social media scraping tools that enable businesses, researchers, and marketers to extract actionable insights from platforms like Facebook, Instagram, and X (formerly Twitter). Our tools are designed for use cases such as lead generation, market research, social listening, and more. Learn more at www.cyfylabs.com

  • 🌟 Open Source Advocate: Passionate about making technology accessible, I’ve developed and open-sourced several software projects for web, mobile, desktop, and AI on my GitHub profile. These projects have been used by thousands of learners worldwide to enhance their skills and knowledge.

  • 📫 How to Reach Me: To learn more about my skills and work, visit my LinkedIn profile. For collaboration or inquiries, feel free to reach out via email. For Cyfy Labs related queries, please contact us through our company website.


🤝 Follow my journey