- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在为 Django channel 编写自定义身份验证中间件
class TokenAuthMiddleware:
def __init__(self, inner):
# Store the ASGI application we were passed
self.inner = inner
def __call__(self, scope):
return TokenAuthMiddlewareInstance(scope, self)
class TokenAuthMiddlewareInstance:
def __init__(self, scope, middleware):
self.middleware = middleware
self.scope = dict(scope)
self.inner = self.middleware.inner
async def __call__(self, receive, send):
## my logic to get validate user and store the user in user data
...
...
...
self.scope['user'] = user_data
inner = self.inner(self.scope)
return await inner(receive, send)
但是在尝试从前端连接到 Web 套接字时,我收到以下错误
TypeError: __call__() missing 2 required positional arguments: 'receive' and 'send'
最佳答案
供您引用:https://channels.readthedocs.io/en/stable/releases/3.0.0.html
从routing.py改变
websocket_urlpatterns = [
re_path(r'ws/chat/(?P<room_name>\w+)/$', consumers.ChatConsumer),
]
至
websocket_urlpatterns = [
re_path(r'ws/chat/(?P<room_name>\w+)/$', consumers.ChatConsumer.as_asgi()),
]
然后
from channels.auth import AuthMiddlewareStack
from channels.db import database_sync_to_async
from django.contrib.auth import get_user_model
User = get_user_model()
@database_sync_to_async
def get_user(user_id):
try:
return User.objects.get(id=user_id)
except User.DoesNotExist:
return AnonymousUser()
class QueryAuthMiddleware:
"""
Custom middleware (insecure) that takes user IDs from the query string.
"""
def __init__(self, app):
# Store the ASGI application we were passed
self.app = app
async def __call__(self, scope, receive, send):
# Look up user from query string (you should also do things like
# checking if it is a valid user ID, or if scope["user"] is already
# populated).
scope['user'] = await get_user(int(scope["query_string"]))
return await self.app(scope, receive, send)
TokenAuthMiddlewareStack = lambda inner: QueryAuthMiddleware(AuthMiddlewareStack(inner))
use requirements.txt as following list, and also download package in this order
Django==3.0.8
djangorestframework==3.11.0
websocket-client==0.57.0
redis==3.5.3
asgiref==3.2.10
channels-redis==2.4.2
channels==3.0.1
关于Django channel 自定义身份验证中间件 __call__() 缺少 2 个必需的位置参数 : 'receive' and 'send' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64625473/
class Meta(type): def __call__(cls, *args, **kwargs): print 'Meta.__call__ called.'
一个非常简单的类不是可调用类型: >>> class myc: ... pass ... >>> c=myc() >>> callable(c) False 如何判断一个类是否有方法__cal
我想在 python 中实现单例模式,我喜欢 http://www.python-course.eu/python3_metaclasses.php 中描述的模式. class Singleton(t
根据我对 Python 面向对象编程的所有了解,如果一个类定义了 __call__ 方法,如果我们像函数调用一样使用该类的实例,该方法将被调用。例如: class Employee: def
Python 的神奇方法 __call__ 会在您尝试调用对象时被调用。 Cls()() 因此等于 Cls.__call__(Cls())。 函数是 Python 中的第一类对象,这意味着它们只是可调
在 python 中,您可以通过实现 __call__ 方法使实例可调用。例如 class Blah: def __call__(self): print "hello" ob
我需要在测试中修补当前日期时间。我正在使用这个解决方案: def _utcnow(): return datetime.datetime.utcnow() def utcnow():
我知道类中的 __call__ 方法是在调用类的实例时触发的。但是,我不知道什么时候可以使用这种特殊方法,因为可以简单地创建一个新方法并执行在 __call__ 方法中完成的相同操作,而不是调用实例,
本节再介绍 Python 类中一个非常特殊的实例方法,即 __call__()。该方法的功能类似于在类中重载 () 运算符,使得类实例对象可以像调用普通函数那样,以“对象名()”的形式使用。 举个例子
这个问题在这里已经有了答案: Overriding special methods on an instance (5 个回答) 关闭2年前。 我需要更改给定对象的 __call__ 方法的行为。天真
class Method(object): def __call__(self): #how could I get the App instance here?
我试图理解下面的代码。 class Chain(object): def __init__(self, path=''): self._path = path def
我正在浏览 Daniel Nouri 的 tutorial关于使用 CNN 的面部识别,我遇到了一些我不理解的代码。 Daniel 正在定义一个在网络训练期间每次迭代结束时调用的类,它将决定训练是否应
Python 的可调用对象是具有 __call__ 方法的对象。它们大部分时间是函数,但也可能是类实例。 但是函数确实有一个 __call__ 方法。因此,一个 __call__ 方法也有一个 __c
我正在用 Python 编写单元测试,我想创建一个模拟函数,在调用时返回另一个模拟(由我指定)。 这是我尝试过的: my_mock = Mock() fn = Mock() fn.__call__ =
以此为例: class Foo(object): def __init__(self, msg): self._msg = msg def __call__(self):
考虑以下代码: class MyCustomDescriptor: def __init__(self,foo): self._foo = foo def __call
我正在测试 simpleTAL 模板库,它使用 callable 来测试传入模板的对象是否为函数。 callable 的定义是说如果一个对象包含魔法方法__call__,那么它就是可调用的。另见 Wh
我在 python2.7 中使用 tkinter。我想要做的就是在一个类中绘制一个 Canvas ,然后在另一个类中绘制一个 Canvas ,该类将在 Canvas 周围移动一个正方形。但出于某种原因
我试图在运行时定义 __call__ dunder 方法,但没有成功。代码如下: class Struct: pass result=Struct() dictionary={'a':5,'b
我是一名优秀的程序员,十分优秀!