当使用Daphne服务器在Django应用程序中运行ASGI时,可能会遇到AttributeError的问题。此问题通常会显示以下错误消息:
AttributeError: ‘NoneType’ object has no attribute ‘sendall’
此问题通常是由于Daphne服务器的TLS设置不正确造成的。在ASGI中,TLS使用协商(negotiation)来设置加密。由于Daphne默认设置为‘None’,需要手动设置为‘auto’或’openssl’来实现协商。
以下是在Daphne服务器和ASGI应用程序中解决此问题的示例代码:
# daphne.run
from daphne.server import Server, HTTPProtocol
from daphne.tcp import TLSInterface, SecretKey
class MyHTTPProtocol(HTTPProtocol):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.tls_interface = TLSInterface(
self.application, self.recv, self.send, secret_key=SecretKey(b"my-secret-key"),
tls_backend="openssl", tls_version="1.2", verify_mode="none", tls_cert="/path/to/cert.pem",
tls_key="/path/to/key.pem"
)
server = Server(
MyHTTPProtocol, ..., certfile="/path/to/cert.pem", keyfile="/path/to/key.pem"
)
# asgi.py
from django.http import HttpResponse
async def application(scope, receive, send):
await send({
b"type": b"http.response.start",
b"status": 200,
b"headers": [
(b"content-type", b"text/html"),
(b"custom-header", b"my-value"),
]
})
await send({
b"type": b"http.response.body",
b"body": b"Hello world!",
b"more_body": False,
})
在上面的代码示例中,代码先定义了一个MyHTTPProtocol类并使用它来传递TLSInterface以及相关的TLS设置。在send中使用了一个字典,而不是 http. HttpResponse对象,以防止出现错误。 最后,在Daphne服务器中传递了TLS证书和密钥的路径。
这个例子演示了正确设置Django ASGI应用程序和Daphne服务器的TLS设置,以解决AttributeError问题。
上一篇:asg和waf的区别