带有 JWT 授权标头的 Curl PUT 请求

chr*_*aka 7 curl jwt django-rest-framework curl-commandline json-web-token

我仍然掌握使用curl 来测试来自终端的API 请求的技巧。我在格式化方面遇到了特殊问题,因为我尝试的 API 请求需要在每次调用时传递 JWT 令牌。\n我尝试传递的请求是 PUT 请求,我的问题是在哪里放置 JWT 令牌授权的标头。\n我尝试了以下格式,但收到错误“无法解析主机:\xe2\x80\x94H”curl:(6) 无法解析主机:“授权:”

\n\n
curl -X PUT -H "Authorization: JWT <token here>" -d "field=value" "https://url/update_record/<id>/"\n
Run Code Online (Sandbox Code Playgroud)\n\n

有任何想法吗?

\n\n

正在访问的呼叫具有以下权限

\n\n
class Item_Update_APIView(UpdateAPIView):\n    authentication_classes = [SessionAuthentication, BasicAuthentication, JSONWebTokenAuthentication]\n    permission_classes = [IsAuthenticated]\n    serializer_class = ItemSerializer\n\n    def get_queryset(self):\n        id = self.kwargs[\'id\']\n        return Item.objects.filter(id__exact=id)\n
Run Code Online (Sandbox Code Playgroud)\n\n

序列化器:

\n\n
class ItemSerializer(ModelSerializer):\n\n    class Meta:\n        model = Item\n            fields = [\n            \'id\',\n            \'booleanField\',\n        ]\n
Run Code Online (Sandbox Code Playgroud)\n