Full Stack Programming Further Web Programming COSC2758

1. Overview (you must read thisfirst)
In this assignment, you will develop a Full Stack Web Application to complete the front‐end prototype built from assignment 1. You are required to use the following stacks:
Frontend:
ReactJS or ReactTS
Middle layer :
Node.js & Express.js with Sequelize ORM or TypeORM
Backend database :
Cloud MySQL
You are not allowed to change technology stacks to suit your convenience and/or knowledge.
Using stacks other than the ones mentioned above will FETCH A ZERO for the whole assignment.
Use of Object‐Oriented React will FETCH A ZERO for the whole assignment.
The tasks are divided into four parts: PA (Pass), CR (Credit), DI (Distinction) & HD (High Distinction).
The HD section tasks will require self‐research, you will not getstraight answersin the course material.
While we are happy to assist you on those tasks, most of the work and research must be done by you.
This is done on purpose to prepare you for future work and rigours of the IT industry.
If you find a specification open to interpretation, post a query identifying the specification in the corresponding discussion board for assignment 2. Software development in real life does not come with a definitive roadmap and flowcharts complete with instructions. More often than so, it is the job of the developer to clarify requirements from the client. For this assignment and course, the lecturer is considered as the client.
It is your responsibility to regularly attend lectorial, practical and consultation session(s).
bring your questionsto online discussion board, consultation sessions
watch the online lectorial recordings on a regular basis if you cannot attend the face‐to‐face session.
do NOT start the work on assignment at the last minute.
do NOT ask for last minute extensions, these are often rejected. Extensions can only be granted for personal and medical reasons, provided you can supply some evidence.
2. Learning Outcomes
This assessment relates to the following learning outcomes of the course which are:
CLO2: Demonstrate proficiency with a web application development framework CLO3: Implement a range of techniques and procedures for developing a small to medium‐scale web application CLO4: Demonstrate knowledge of and utilise software engineering patterns in development
CLO5: Design and manage the development life cycle of a complete application.
3. Assessment details
The senior executive committee has accepted the SOIL front‐end prototype and now recommends that full stack version of website be developed. The committee recommends inclusion of extra features and constraints for the
website‐ a summary is presented here; you will find more details in Section 4: Tasks . The extra features and constraints include‐
3.1. The committee wants the developer to use a Cloud MySQL database (hosted at rmit.australiaeast.cloudapp.azure.com ) for the backend purposes.
3.2. Two users cannot have the same email/username.
3.3. Password must be stored in a hashed format in the database. Please do not use MD5 as it is no longer considered secure by industry professionals.
3.4. The full stack version of SOIL must be a multi‐user website where users can follow and unfollow one or more other users.
3.5. SOIL website will have a separate admin portal .
3.6. Admin dashboard part must be implemented via GraphQL and not REST API.
3.7. The codebase must be thoroughly commented.
3.8. GitHub should be used throughout the development lifecycle. The repository must be a part of rmit fsd 2024 s1 organisation account. You have been emailed an invite to join this organisation at the start of the semester.
3.9. The website must be fully styled and look professional. The content must make sense i.e., use of lorem ipsum is not allowed.
3.10. The digital assets (images, icons, audio & video) must be outsourced from free websites. You should not steal someone else’s assets to enhance the look and feel of your website. High‐quality & free assets can be obtained
from:
https://unsplash.com/    (Images)
https://uifaces.co/          (Avatars)
https://fonts.google.com/icons?selected=Material+Icons:home     (Icons)
https://www.flaticon.com/     (Icons)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/23872.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

iOS开发中copy on write

Copy-On-Write(写时复制)是一种内存管理技术,在iOS开发中被广泛使用。下面是一些常见的使用场景: 不可变对象的复制:当对一个不可变对象执行复制操作时,实际上只会创建该对象的引用计数副本,而不…

沉淀:心灵的宁静之道

在这个信息爆炸的时代,我们常常被繁杂的事务淹没。每日忙碌的工作、应接不暇的社交活动、纷至沓来的琐事,让人难以静下心来。最近,我也深感疲惫和迷茫,仿佛被生活的巨浪推着前行,却无暇思考方向。 沉淀,是一…

【C++】初识C++

【C】初识C 文章概括关键字(C98)命名空间命名空间的定义命名空间的特性 输入与输出C中的输入输出输入输出的命名空间 缺省参数函数重载引用引用的概念引用的特性引用地使用场景引用做参数引用做返回值 常引用常引用的俩个例子 引用与指针的区别 内联函数…

web端中使用vue3 实现 移动端的上拉滚动加载功能

需要再web端实现上拉加载 纯属web端的东西 类似这样的功能效果 能够在web端实现滚动分页 overflow-y: scroll;首先给这个大盒子 一个 css 样式 支持滚动 再给固定高度 这个盒子里的内容就能立马滚动起来 给这个盒子一个ref 的属性 以及 有原生滚动事件 scroll const handle…

c++ 左右值与引用折叠

C 增加了一个新的类型,右值引用,记作“&&” 左值:是指在内存中有明确的地址,我们可以找到这块地址的数据(可取地址) 右值:只提供数据,无法找到地址(不可取地址&…

分布式防止重复请求或者高并发防止重复提交

1:自定义注解JRepeat package com.huan.study.mybatis.config;import java.lang.annotation.*;/*** 防止重复提交的注解**/ Retention(RetentionPolicy.RUNTIME) Target({ElementType.METHOD}) Documented public interface JRepeat {/*** 超时时间** return*/int …

通过龙讯旷腾PWmat发《The Journal of Chemical Physics》 :基于第一性原理分子动力学热力学积分的离子溶剂化自由能计算

背景导读 离子溶解是电化学中一个重要的过程。电化学反应中许多重要的参数,例如电化学还原电位、无限稀释活度系数、亨利定律溶解常数和离子溶解度等,都与离子的溶剂化能有关。然而,由于测量技术和数据处理的困难,离子溶剂化能的…

vCenter7.0安装部署

vCenter7.0安装部署 一、准备环境二、创建新的虚拟机1.创建虚拟机2.第3-5步可直接默认安装并同意许可协议。3.其他设置4.第一阶段直接点完成即可 三、进入第二阶段安装(输入ip:5480进入安装界面) 一、准备环境 准备一台exsi,并登…

【定义动态组件】

利用动态组件可以动态切换页面中现实的组件&#xff0c;使用标签可以定义动态组件&#xff0c;语法格式如下。 <component is "要渲染的组件"></component>在上述语法中&#xff0c;标签必须配合is属性一起使用&#xff0c;is属性属性值表示要渲染组件&…

MySQL之查询性能优化(九)

查询性能优化 MySQL查询优化器的局限性 UNION的限制 有时&#xff0c;MySQL无法将限制条件从外层"下推"到内层&#xff0c;这使得原本能够限制部分返回结果的条件无法应用到内层查询的优化上。如果希望UNION的各个子句能够根据LIMIT只取部分结果集&#xff0c;或者…

项目沟通管理

目录 1.概述 2.项目沟通的重要性和必要性 2.1.项目沟通的重要性 2.2.项目沟通的必要性 2.3.具体措施 3.三个过程 3.1.规划沟通管理 3.2.管理沟通 3.3.监督沟通 3.4.对应过程组 4.应用场景 4.1.十个应用场景 4.2.新产品开发项目需要与多个部门协调沟通 5.总结 1.概…

调节效应多元统计回归

什么是调节效应&#xff0c;给个例子说明一下: 背景 假设我们有一个国家的经济数据&#xff0c;我们希望研究产业数字化是否调节了环境规制对产业结构调整的影响。 步骤 1. 假设检验 原假设 (H0)&#xff1a; 产业数字化对环境规制与产业结构调整之间的关系没有调节作用。…

C++ | 类对象初始化

文章目录 概述一、定义介绍二、操作教程1.直接初始化&#xff08;Direct Initialization&#xff09;2.复制初始化&#xff08;Copy Initialization&#xff09;3.列表初始化&#xff08;List Initialization&#xff09; 概述 本节介绍类对象初始化。 一、定义介绍 在C中通过…

银河麒麟V10_系统如何自定义添加桌面右键菜单选项

本篇博客取自《银河麒麟桌面操作系统软件适配常见问题指导手册》官网可以下载。 环境 系统版本 适用系统&#xff1a;V10&#xff08;SP1&#xff09;适用架构&#xff1a;X86、ARM、MIPS 其他版本和架构可做参考。 解决方案 使用下面的这个demo 编译就可以看到效果 peony…

每日一题——Python实现PAT甲级1063 Set Similarity(举一反三+思想解读+逐步优化)

一个认为一切根源都是“自己不够强”的INTJ 个人主页&#xff1a;用哲学编程-CSDN博客专栏&#xff1a;每日一题——举一反三Python编程学习Python内置函数 Python-3.12.0文档解读 目录 我的写法 优点 改进建议 时间复杂度分析 空间复杂度分析 总结 我要更强 优化方…

【C语言】指针(4)

一、回顾 在这之前&#xff0c;我们学习了很多关于指针的内容&#xff0c;我们先在这里简单的回顾一下。 1、一级指针 int* p; -- 整形指针-指向整形的指针 char* p; ... void* p;... ... 2、二级指针 int** p; char** p; ... 3、数组指针 -- 指向数组的指针 int (*p)[ ]…

3038. 相同分数的最大操作数目 I(Rust模拟击败100%Rust用户)

题目 给你一个整数数组 nums &#xff0c;如果 nums 至少 包含 2 个元素&#xff0c;你可以执行以下操作&#xff1a; 选择 nums 中的前两个元素并将它们删除。 一次操作的 分数 是被删除元素的和。 在确保 所有操作分数相同 的前提下&#xff0c;请你求出 最多 能进行多少次…

在 Vue 中实现算法可视化

算法是计算机科学的核心&#xff0c;而算法可视化有助于更好地理解算法的运行过程。本文将介绍如何在 Vue.js 中实现算法可视化&#xff0c;以排序算法为例&#xff0c;逐步展示数据变化过程。 环境搭建 首先&#xff0c;确保你已安装 Vue CLI&#xff0c;可以使用以下命令创…

Python | Leetcode Python题解之第136题只出现一次的数字

题目&#xff1a; 题解&#xff1a; class Solution:def singleNumber(self, nums: List[int]) -> int:return reduce(lambda x, y: x ^ y, nums)

Vue07-MVVM模型

一、MVVM模型的定义 M&#xff1a;模型&#xff08;model&#xff09;&#xff1a;对应data中的数据&#xff1b;V&#xff1a;视图&#xff08;view&#xff09;&#xff1a;模版&#xff1b;VM&#xff1a;视图模型&#xff08;ViewModel&#xff09;Vue的实例对象。 Vue.js…