后端开发文档

环境配置(WSL)

sudo apt update
sudo apt upgrade
sudo apt install python3-pip

MariaDB安装及配置

MariaDB和MySQL操作相同

sudo apt-get install software-properties-common
sudo add-apt-repository 'deb [arch=amd64] http://mirror.zol.co.zw/mariadb/repo/10.3/ubuntu bionic main'

输入上方最后一条之后系统应该会报错,类似于

The following signatures couldn't be verified because the public key is not available: NO_PUBKEY F1656F24C74CD1D8
Reading package lists... Done

复制此处的F1656F24C74CD1D8,用你的十六进制码代替下方的F1656F24C74CD1D8

curl -sL "http://keyserver.ubuntu.com/pks/lookup?op=get&search=0xF1656F24C74CD1D8" | sudo apt-key add
sudo apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xF1656F24C74CD1D8
sudo add-apt-repository 'deb [arch=amd64] http://mirror.zol.co.zw/mariadb/repo/10.3/ubuntu bionic main'
sudo apt update
sudo apt -y install mariadb-server mariadb-client
sudo apt install libmysqlclient-dev

设置数据库用户名和密码为root

mysql -uroot -p
# 输入密码
# 进入数据库
> create database oj default character set utf8 collate utf8_unicode_ci;

若报错ERROR 2002(HY000): Can't connnect to local MySQL server through socket '/var/run/mysqld/mysqld.sock (2)',尝试

sudo service mysql start

若失败,原因为WSL与宿主机共用端口,但宿主机3306端口被占用。

解决方法:关闭3306端口,重新尝试启动WSL下的MySQL。

参考1
参考2

Django安装及配置

server/目录下(注: pippython的使用根据所在操作系统环境的不同可能需要pip3python3)

pip install -r requirements.txt
python manage.py makemigrations
python manage.py migrate
python manage.py runserver 0.0.0.0:8000

若提示缺少依赖,安装即可。

开发

项目结构

项目入口为oj/settings.pyoj/dev_settings.pyoj/production_settings.py分别为开发环境和生产环境下的环境配置文件;oj/urls.py为整个项目url入口。项目已将各模块初始化为以下相应app

  • user
  • course
  • lecture
  • lab
  • exam
  • problem
  • submission

app文件目录如下:

  • urls
    • student.py
    • admin.py
    • statistics.py
  • views
    • student.py
    • admin.py
    • statistics.py
  • models.py
  • serializers.py
  • tests.py

其中,数据中心各功能在views/statistics.py中开发。

序列化

本项目利用rest_framework下的serializers类进行数据序列化,示例代码如下:

#demo/serializers.py

from rest_framework import serializers
from .models import Demo

class DemoSerializers1(serializers.Serializer):
    content = serializers.CharField()

class DemoSerializers2(serializers.ModelSerializer):

    class Meta:
        model = Demo
        fields = ('content', 'is_public')
        # or  fields = '__all__'

rest_framework参考文档

rest_framework.serializers参考文档

(不需要科学上网)

视图(view)开发

视图类APIView在Django的view类的基础上已经为大家进行封装,在开发相关视图时,只需导入并继承APIView,并调用:

  • self.success
  • self.error

返回相应结果。示例代码如下:

# demo/views/oj.py

from utils.api import APIView
from ..serializers import DemoSerializers1
from ..models import Demo

class DemoAPI(APIView):
    def get(self, request):
        demo_id = request.GET.get('demo_id')
        demo = Demo.objects.get(id=demo_id)
        return self.success(DemoSerializers1(demo).data)

URL添加

首先,在oj/urls.py中引入所在appurl的路径

#oj/urls.py

from django.conf.urls import include, url

urlpatterns = [
    url(r"^api/", include("demo.urls.oj")),
    #balabala
]

其次,在所在app中的路径文件中添加相应视图的url

#demo/urls/oj.py

from django.conf.urls import url

from ..views.oj import DemoAPI

urlpatterns = [
    url(r"^demo/?$", DemoAPI.as_view(), name="demo_content_api"),
]

Model开发

就在各app下的models.py啦~记得要python manage.py makemigrations和``

最后

所有demo代码都可以在项目根目录下的demo文件夹下找到嗷~

祝大家开发愉快ᕕ(ᐛ)ᕗ

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一日,安石邀我入梦。酒过三巡,安石执吾手侧身倾头对我说:“汪君,据高层透露,有...
    梦里不知身是客_Whm阅读 3,635评论 1 1
  • 清茶恋民宿 地址: 杭州市西湖区双灵村上堡组61号 主人: 小良 13588172833 (微信与手机号) 房间信...
    倪琴2019阅读 3,287评论 0 0
  • 在薄霜缠绵窗扉的夜里我翻来又覆去想你In the night of the frostaround the win...
    齐希阅读 1,579评论 0 4
  • 我没有什么特别的爱好,唯一可以说道的是读书,周末喜欢去秋林书城逛逛,再就是愿意与读书的人交朋友。 在我看来,书籍就...
    戎苑居士阅读 2,600评论 0 0
  • 【作业一】朗读 + 即兴(农民工追梦的故事) 《白杨礼赞》 那是力争上游的一种树,笔直的干,笔直的枝。它的干,通常...
    好听的暖阳阅读 1,521评论 0 1