- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 django restframework 并希望处理多个数据库。我正在使用 django 函数 using(alias) 和 switch_db(alias) 在我想要获取、发布或更新数据时在数据库之间手动切换。
我在发布和更新数据时遇到问题,即每当调用 serializer.is_valid() 时。
serializer.is_valid() 将首先检查 model.py 文件中的 db_alias。如果我没有在 meta 下指定 db_alias ,它将选择默认数据库进行验证。如果我在模型中指定 db_alias,它将选择该数据库进行验证。
但我不想在模型中指定 db_alias,因为我的用例是根据 View 文件中的某些逻辑将数据存储在不同的数据库中。所以动态地我想从 View 中选择数据库并想在其中存储数据。
我几乎已经实现了,但是当我的模型有引用字段时我遇到了问题。在这种情况下,serializer.is_valid 将使用默认数据库来验证该引用字段。
必需的详细信息:我正在使用 mongoengine(0.9.0)、文档、文档序列化程序。
我的文件如下:
模型.py:
class ngroup(Document):
groupname = StringField(max_length=100, required=True)
description = StringField(max_length=100, required=False)
parent = ReferenceField('ngroup',null=True)
created_ts = DateTimeField(default=datetime.now())
modified_ts = DateTimeField(default=datetime.now())
is_deleted = BooleanField(default=False)
序列化器.py:
from device_management.models import ngroup
from rest_framework_mongoengine.serializers import DocumentSerializer
from mongoengine import EmbeddedDocumentField, ReferenceField, StringField, ObjectIdField, IntField, BooleanField, FloatField, DateTimeField,ListField
class ngroupSerializer(DocumentSerializer):
class Meta:
model = ngroup
def setOrgId(self, orgid):
self.orgid = orgid
def create(self, validated_data):
ngroup_data = ngroup(**validated_data).switch_db(self.orgid)
ngroup_data.save()
return ngroup_data
def update(self, instance, validated_data):
ngroup_data = ngroup.objects.using(self.orgid).get(id = instance.id)
ngroup_data = ngroup_data.switch_db(self.orgid)
ngroup_data = ngroup_data.update(**validated_data)
return validated_data
def to_internal_value(self, data):
print "data:" , data
return super(DocumentSerializer, self).to_internal_value(data)
View .py:
def create(self, request, format=None):
orgid = str(request.user.orgid.id)
data=request.data
serializer = ngroupSerializer(data=data)
if serializer.is_valid():
try:
serializer.save()
except Exception as e:
log.error("create" , extra={'extra':{'error': str(e),'message' :strings.DATA_VALIDATION_ERROR }})
return response.errorResponse(message=strings.SERIALIZATION_ERROR_MSG,error=str(e),rstatus=status.HTTP_400_BAD_REQUEST)
return response.successResponse(res_data=serializer.data, message=strings.POST_SUCCESS_MSG, rstatus=status.HTTP_201_CREATED)
log.error("create" , extra={'extra':{'error': serializer.errors,'message' :strings.DATA_VALIDATION_ERROR }})
return response.errorResponse(message=strings.DATA_VALIDATION_ERROR,error=serializer.errors,rstatus=status.HTTP_400_BAD_REQUEST)
设置.py:
DATABASES = {
'default': {
'ENGINE': 'django_mongodb_engine',
'NAME': 'mydb',
'USER': 'admin',
'PASSWORD':'admin123',
'HOST': '127.0.0.1',
'PORT': 27017,
'DBTYPE' : "mongo",
},
'586e47c784413825f2b5bc49': {
'ENGINE': 'django_mongodb_engine',
'NAME': 'mydb1',
'USER': 'admin',
'PASSWORD':'admin123',
'HOST': '127.0.0.1',
'PORT': 27017,
'DBTYPE' : "mongo",
},
# Enter super_user organisation here. This DB will be same as default db only always
'58996fb28441384430dc8ae6': {
'ENGINE': 'django_mongodb_engine',
'NAME': 'mydb',
'USER': 'admin',
'PASSWORD':'admin123',
'HOST': '127.0.0.1',
'PORT': 27017,
'DBTYPE' : "mongo",
},
}
pip freeze(安装版):
Django==1.5.11
django-browserid==2.0.2
django-classy-tags==0.8.0
django-missing==0.1.18
django-mongo-auth==0.1.3
django-mongodb-engine==0.6.0
django-mongoengine==0.2.1
django-redis-sessions==0.5.6
django-rest-framework-mongoengine==3.3.0
django-sekizai==0.10.0
django-websocket-redis==0.4.7
djangorestframework==3.1.2
djangorestframework-jwt==1.9.0
djangotoolbox==1.8.0
gevent==1.1.2
greenlet==0.4.10
httplib2==0.9.2
mongoengine==0.9.0
oauthlib==2.0.1
pika==0.10.0
Pygments==2.1.3
PyJWT==1.4.2
pymongo==2.8
python-dateutil==2.6.0
python-openid==2.2.5
pytz==2016.10
redis==2.10.5
requests==2.12.3
requests-oauthlib==0.7.0
rest-condition==1.0.3
six==1.10.0
tweepy==3.5.0
twilio==5.7.0
我在调用 serializer.save() 时覆盖了在序列化器中创建以处理数据库,但如何处理 serializer.is_valid()。
我的项目一直卡在这个点上。任何帮助将不胜感激...
最佳答案
这不是上述问题的确切解决方案,但我们有 2 个选择。
1) 不要使用 serializer.is_valid() 或 serializer.save()。直接创建ngroup:
def my_create(self, validated_data):
gateway = Gateway(**validated_data).switch_db(self.orgid)
gateway.save()
return gateway
2) 另一种解决方案是使用 django-mogodb-engine 和 django 模型和模型序列化器,而不是文档和文档序列化器。
我已经尝试使用 Django-mongodb-engine 来执行此操作并且运行良好:
-> JWT authentication
-> custom user
-> foreign key
-> embedded model
-> list of embedded model
-> dict field
-> **Routers for switching between databases.(Manual switching DB is not required)**
我还可以使用 middleware_classes 在每个请求中指定运行时使用哪个数据库。引用链接:Django Authenticate Backend Multiple Databases
关于python - 在使用 django restframework 多数据库时,serializer.is_valid() 总是去默认数据库进行验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42412218/
一 前言 经过权限判断之后就是进行频率的判断了,而频率的判断和权限又不一样,认证、权限和频率的执行流程都差不多,使用配置里面的相关类来进行判断。而不和认证和权限一样,频率的配置没有,
前言 最近学习了 django 的一个 restframework 框架,对于里面的执行流程产生了兴趣,经过昨天一晚上初步搞清楚了执行流程(部分方法还不太清楚),于是想详细的总结一下当来一个请求时
系统:ubuntu18.04 x64 GitHub:https://github.com/xingjidemimi/DjangoAPI.git 安装 ?
我想为我的用户使用用户名或电子邮件和密码进行一些自定义身份验证。在第一次使用电子邮件和密码登录时,api 应该返回相应的用户 token 。对于 api 的所有其他操作,我需要使用 token ,这是
我有一个常规的 django 站点,djangorestframework (v2.3.14) 在“/api”下提供 restful api。在本地机器上一切正常(mac/mavericks),在远程
我正在使用Django Restframework 3.3.3,并且尝试使用通用 View ,但是我希望覆盖序列化程序验证错误消息。我得到以下代码,当没有给出名称字段时,出现“名称字段不能为空”的代码
我正在使用 python 2.7 和 django 1.7 构建 API,但我遇到了问题。我不是 Rest Framework 方面的专家,但我了解基 native 制。 我可以通过举个例子来继续我的
我的问题与 django-rest-framework 有关,是关于如何对元素进行分组的。 这是我的serializers.py from collaborativeAPP.models import
我正在使用Django restframework和 Elasticsearch 来开发移动应用程序的后端应用程序。我需要开发一个时间轴API,以加载该用户正在关注的其他用户的帖子时间轴。以及他们关注
我使用路由器创建 url,现在我想为我的 api 创建 url,但问题是,我收到错误 createuser() missing 1 required positional argument: 'req
我有两个模型,分别是问题和与该问题一致的选择集。我想结合这两个模型来创建一个 API,它显示问题列表及其选择。 这些是我的模型: class Question(models.Model): q
我目前正在使用线程标题中提到的技术进行一个项目。 我在浏览器上运行了这一切(该应用程序托管在 heroku 上),但是当我尝试从我的 Ionic 2 应用程序连接到 websockets 时,我总是在
我正在使用 Django rest framework-JWT 进行身份验证来处理 protected url,我正在尝试使用 IsAutchinted 保护 UserDetail View 。来自r
我只是将一个旧项目升级到 Python 3.6,并发现有这些很酷的新 async/await 关键字。 我的项目包含一个网络爬虫,目前性能不是很好,大约需要 7 分钟才能完成。 现在,由于我已经安装了
j查询: $.ajax({ url: '/notify/', type:'GET', dataType: 'json',
我正在使用 django restframework 并希望处理多个数据库。我正在使用 django 函数 using(alias) 和 switch_db(alias) 在我想要获取、发布或更新数据
在 django RestFramework 中,是否有任何“官方”方式来生成“Api Root”的文档? 在查看了 RestFramework 的源代码后,我通过继承 DefaultRouter 找
我是 Multi-Tenancy 架构的新手,正在使用 django-tenant-schema 开发 SaaS 产品 我的要求是客户注册产品。对于每个注册的客户,我都通过遵循单一数据库和隔离模式方法
我试图找出是否可以使用 Django Rest 框架中的通用 api 方法在同一 View 中发布和修补。我不认为有任何通用类允许完全创建和更新,任何人都可以告诉我下面的配置是否允许我在同一 View
您好,我尝试添加到我的项目 swagger 但它返回 401 错误,请帮助我解决这个问题 这是我的路由器 from . import router schema_view = get_sche
我是一名优秀的程序员,十分优秀!