Skip to content

HEC2018/Go-Cart

Repository files navigation

Go-Cart

Created by:

In this project, We designed a creative online shopping platform, with the functionality of purchasing products, putting up new products, duplicate product checking and a recommendation engine based on customers profile.

How we built it

Technology: we leveraged two useful platforms: Python Flask and Sqlite3, and used four different programming languages: Python, HTML5(with Bootstrap), CSS, and SQLite3. For this project, Flask is a framework that not only manage for a creative and user-friendly web interface but also handle the particular functionalities of the webiste, including purchasing and uploading products, eliminating duplicate products, and finding proper products for recommendation candidates. As a poweful framework, Flask is also used for hanlding form submission and template rendering. Sqlite3, as a mature database management tool, stores the product information, business transaction, also avoids adding duplicates.

For the backend design, in particular, we used the HTTP post action to trigger the upload process of products, and built-in functionality of HTML5 to check the data integrity. (i.e. whether the user's input is valid). Since the application requires uploading files, which shall be treated extremely seriously, we also put a very strict secure requirement on file's name and extension, using secure_filename from werkzeug.utils, which is a useful python package that basically determines if a file is safe to store. Pne cool feature we implemented is that we use some Sqlite3 code to check a if a certain product of the same price has appeared on the website or not. If it does, we will treat the new upload of products as adding stocks but not putting up new products for sell.

For the recommendataion engine, we choosed Auto-encoder from Neural Networks for define the proper dimensions for customers in this recommendation systems. The auto-encoder will collect some basic information from user's profile for training process. The system have been tested successfully for incrasing the usre-click for 30% in the last few weeks.

For the frontend, we mainly uses HTML5 with Bootstrap 5.0 for our clear and easy-understanding user interface. Using such technologies also provides a strong cross-browser and multi-platform compatibility. Flask's render_template function is used for updating data from past transactions. For the current stage, we automatically change every submitted image to 256x256 pixels because of the website's capacity. we also have built a file-upload page which make a good use of the form component of Bootstrap. Besides, a message website is included to remind the user if a purchase of product is successful or not. The message webisite uses an alert component which makes user have a better sense to the new transaction.

Features

Admin-Control
Duplicate-Check
Recommendation Engine(Auto-encoder)
Multiplatform Compatibility
Secure Upload

Usage

Requirements: Python3( Packages: Flask, sqlite3, werkzeug ) First,

$ git clone https://github.com/HEC2018/Go-Cart.git

To run this application, run python3 server.py from the command line, which will create the database tables and start the Flask server automatically.

Then, open a web browser at the address given by Flask (http://127.0.0.1:5000). Then there will be a login page. For current stage, input username = "admin" and password = "123" to authorize. The main website has a list of products with their related data, like their name, price, stock, and a sample. All of this data are pulled from Sqlite3 DB table and rendered through Flask. Initially some products are appeared on the page as a sample test to the website. The initial images are stored within the static/images folder locally. However, by clicking "Clear all" button on the website, user may reach to an empty site and starts to upload images that his favors. For developing and testing purposes, a button named "Reset" can resotre the page to the very beginning stage, with sampled pictures shown.

By clicking "Upload a picture for sell" button, the user will be directed to a uploading page where he can choose the file he wants to put up for sale, where the images come locally from his device, and makes up the price and number of images that he wants to put up. For security reasons, the uploading files must end with one of .jpg, .png, .jpeg, or .gif. (Also any uppercase form of these extensions). Strict requirement to these files are necessary since We need to ensure that nothing vulnerable will be saved. Besides, for protecting purposes of database, We also put a security check on the file's name, using werkzeug.utils. The step is necessary since the file's name will be stoed into the database and retrived later as the product's name showned on the top page.

The user can also try to purchase any images he want by clicking the "Purchase one" button next to the image on the main page (at the rightmost column). This step will check the inventory whether there are enough image stock remains, and recorded the transaction (time when transaction happens, image name, price of image) in the transactions table of database. The process will also update the product's inventory in Databse appropriately.

A small design for user is a navigation bar that shows how much the images that a customer has purchased on this website. The number is showed on the right side of the bar on top, counted in rounded dollars.

Test guides

For testing purposes, the "tests" directory contains some pictures that can be used to put up as test. Testers can try to upload these pictures one by one with different prices or multiple of them with same price. After uploading, testers can first verify the new rows that put up on the website, representing the new added images, ensuring them with correct price and quantity. For adding some past existed images, testers shall validate the new quantity/stock of them. After uploading, testers can try to purchase some of images (a combination of sample images from server or new added images) and see the total value of images.

Also, tester shall be aware of the exhibition of sample images of size 256x256 pixels. The resize function is strict and may cause partial of uploaded image does not show.

To start a blank test, tester shall click "Clear all" for initial environment setup. Remind that Reset will restore the sample images from the server.

What's next

We could add more features that requires login or access control. By allowing that, the website allows different users to surf the website at the same time, while reaching out to different contents. We can implement a personal wallet that represents that credit that a customer can use on the website. The wallet can also be used to collect the money from other customers, as well as users may purchase some products from other people and re-sell again. We could implement such feature by a login form of HTML5 that would give the browser an access token, allowing the application to serve some administrative tools to users, such as viewing earnings or managing stock. Customers purchase products would prefer using the money from wallet to filling a lot of transaction information when using some common checkout methods, like visa card or paypal. Users only need to put money in the wallet at the very begining, then purchasing and selling products will be extremely easy by just clicking buttons.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published