如何解决DjangoRestAPI-在运行自己的函数如事件处理程序的同时使用ModelViewSet执行数据库管理
我习惯将flask用于api,将Django用于数据库,并且正在尝试学习DjangoRestAPI。我遵循了官方的Quickstart和中级的另一篇教程,并做了很多研究,但是我仍然很难理解如何实现自己的功能(例如:进行一些计算或向Twilio api发出请求以在之后发送消息) 我已经读过APIView也可以是另一个选择,但这会使访问数据库变得非常困难吗?当我在views.py的ModelViewSet类中运行打印功能或@action函数时,在服务器启动时,它仅在程序启动时打印一次。这是我在Flask中编写的代码版本,也是我在Django中尝试过的代码。
我应该继承哪个类(APIView或Viewset或ModelViewSet,我可以在哪里查找有关此的更多信息?
非常感谢您提前提供的帮助:-请注意,flask实现是一个获取请求
@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,RSSi)
return jsonify(uuid,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)
参阅Custom function which performs create and update on DRF modelViewSet
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。