DjangoRestAPI - 使用 ModelViewSet 执行数据库管理,同时 运行 您自己的函数(如事件处理程序)

DjangoRestAPI - Using ModelViewSet to perform database management while running your own function (like a event handler)

我习惯于将 Flask 用于 apis,将 Django 用于数据库,我正在尝试学习 DjangoRestAPI。我按照官方快速入门和 medium 的另一个教程进行了大量研究,但我仍然很难理解 如何实现我自己的功能(例如:进行一些计算或向 Twilio 发出请求 api 在 ModelViewSet 中收到 api 请求后发送消息)。 我读过 APIView 也可以是另一种选择,但它会使访问数据库变得非常困难?当我 运行 在 views.py 中的 ModelViewSet class 中的打印函数或 @action 函数时,它在服务器启动时仅在程序开始时打印一次。这是我在 Flask 中的代码版本以及我在 Django 中尝试过的版本。

我应该继承哪个 class(APIView 或 Viewset 或 ModelViewSet,我在哪里可以找到这方面的更多信息?

非常感谢您的提前帮助:- 请注意,flask 实现是一个 get 请求

@app.route('/api/upload/<uuid>/<major>/<minor>/<rssi>',methods=['GET'])
def beacon_info_upload(uuid,major,minor,rssi):
    if 'uuid' in request.args:
        uuid = str(request.args['uuid'])
    if 'major' in request.args:
        major = str(request.args['major'])
    if 'minor' in request.args:
        minor = str(request.args['minor'])
    if 'rssi' in request.args:
        rssi = str(request.args['rssi'])
    qualify = send_twilio_message(uuid,major,minor,rssi)
    return jsonify(uuid,major,minor,qualify)

在 Django 中尝试(views.py)

class beacon_occuranceViewSet(viewsets.ModelViewSet):
    queryset = beacon_occurance.objects.all().order_by('from_location')
    serializer_class = beacon_occuranceSerializer
    print("event occ beacon occ views.py L32 success experiment") #only prints once at the beginning

    @action(detail=True, methods=['post'])
    def register(self, request, pk=None):
        print("hello!!!!! L38") #only prints once at the beginning
        beacon = self.get_object()
        print(beacon)

class beacon_occuranceSerializer(serializers.HyperlinkedModelSerializer):
    print("hello") #also only prints once when booting the server
    class Meta:
        model = beacon_occurance
        fields = ('from_location','uuid','major','minor','rssi','time')

已解决 - 使用

def create(self, request):
     #do what you want - do access data- do request.data (its a dictionary)
     return super().create(request)

参考