2017-02-02 1 views
1

이 문제에 도움을 요청하고 싶습니다. 나는 그것이 같은 문제에 관한 다른 질문과 유사하다고 생각하지만, 나는 주변을 둘러 보았고 실제로 내 문제를 해결할 수있는 것이 아무것도 없었다. Btw, 여기는 내 두 번째 질문이므로이 메시지가 너무 길면 알려주세요. 감사! 내가 장고 1.8 파이썬 3.5키워드 'username'을 (를) 필드로 확인할 수 없습니다. 선택 사항 : 도시, 신분증, 전화 번호 등

와 AllAuth 사용하고

나는 AllAuth에서 제공되는 사용자 이름을 기반으로 간단한 프로필 페이지를 구현하려는. 문제는 모델에서 사용자 이름이나 전자 메일 필드를 지정하지 않았기 때문에 일부 정보를 추가하기 위해 확장했지만 장고는 확장 된 필드 만 식별한다는 것입니다. AllAuth에서 해당 정보를 얻을 수있는 올바른 방법을 찾을 수 없습니다. 여기

내 코드 (사용자 정의 필드의 일부는 포르투갈어하지만 모든 핵심 재료가 영어로)입니다 :

정보/models.py

from django.conf import settings 
from django.db import models 
from django.db.models.signals import post_save 
from django.utils.encoding import smart_text 

UF_CHOICES = (
    ('SP', 'SP'), 
    ('RJ', 'RJ') 
) 

class Profile(models.Model): 
    user = models.OneToOneField(settings.AUTH_USER_MODEL) 

    uf = models.CharField(
         max_length = 2, 
         blank=False, 
         default = 'SP', 
         choices = UF_CHOICES, 
         verbose_name = 'UF', 
         ) 
    cidade = models.CharField(max_length=120, null=True, blank=True, default="Rio de Janeiro") 
    telefone = models.CharField(max_length = 20, blank=True, null=True, verbose_name = 'Telefone para Contato') 

    def __str__(self): 
     return smart_text(self.user) 



def post_save_user_model_receiver(sender, instance, created, *args, **kwargs): 
    if created: 
     try: 
      Profile.objects.create(user=instance) 
     except: 
      pass 

post_save.connect(post_save_user_model_receiver, sender=settings.AUTH_USER_MODEL) 

정보/forms.py

from django import forms 
from .models import Profile 

class ProfileForm(forms.ModelForm): 
    class Meta: 
     model = Profile 
     fields = [ 
      "uf", 
      "cidade", 
      "telefone", 
     ] 

    def profile(self, request, user): 
     user.uf = self.cleaned_data['uf'] 
     user.cidade = self.cleaned_data['cidade'] 
     user.telefone = self.cleaned_data['telefone'] 
     user.save() 

정보/admin.py

from django.contrib import admin 

# Register your models here. 

from .models import Profile 

admin.site.register(Profile) 
,691,363,210

정보/views.py

from django.contrib.auth.decorators import login_required 
from django.shortcuts import render, get_object_or_404 
from .models import Profile 

# Create your views here. 

@login_required 
def profile_detail(request, username=None): 
    obj = get_object_or_404(Profile, username=username) 
    context = { 
     "object": obj, 
    } 
    template = 'profile_detail.html' 
    return render(request, template, context) 

정보/adapter.py [사용자 이름이 나타나 여기에 참고 상기 문서화 등이 지정 http://django-allauth.readthedocs.io/en/latest/advanced.html

from django.conf import settings 
from allauth.account.adapter import DefaultAccountAdapter 

class MyAccountAdapter(DefaultAccountAdapter): 

    def get_login_redirect_url(self, request): 
     path = "/profiles/{username}/" 
     return path.format(username=request.user.username) 

정보/urls.py

from django.conf.urls import url 
from .views import profile_detail 

urlpatterns = [ 

    url(r'^(?P<username>[\[email protected]+-]+)/$', profile_detail, name='profile_detail'), 
] 

마지막으로 오류 메시지는

입니다.
Environment: 


Request Method: GET 
Request URL: http://localhost:8000/profiles/Sofia/ 

Django Version: 1.8.17 
Python Version: 3.5.2 
Installed Applications: 
('django.contrib.admin', 
'django.contrib.auth', 
'django.contrib.contenttypes', 
'django.contrib.sessions', 
'django.contrib.sites', 
'django.contrib.messages', 
'django.contrib.staticfiles', 
'allauth', 
'allauth.account', 
'allauth.socialaccount', 
'allauth.socialaccount.providers.facebook', 
'crispy_forms', 
'newsletter', 
'profiles', 
'properties') 
Installed Middleware: 
('django.contrib.sessions.middleware.SessionMiddleware', 
'django.middleware.common.CommonMiddleware', 
'django.middleware.csrf.CsrfViewMiddleware', 
'django.contrib.auth.middleware.AuthenticationMiddleware', 
'django.contrib.auth.middleware.SessionAuthenticationMiddleware', 
'django.contrib.messages.middleware.MessageMiddleware', 
'django.middleware.clickjacking.XFrameOptionsMiddleware', 
'django.middleware.security.SecurityMiddleware') 


Traceback: 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/core/handlers/base.py" in get_response 
    132.      response = wrapped_callback(request, *callback_args, **callback_kwargs) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/contrib/auth/decorators.py" in _wrapped_view 
    22.     return view_func(request, *args, **kwargs) 
File "/Users/Alex/Desktop/Hunters/src/profiles/views.py" in profile_detail 
    9.  obj = get_object_or_404(Profile, username=username) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/shortcuts.py" in get_object_or_404 
    155.   return queryset.get(*args, **kwargs) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/query.py" in get 
    325.   clone = self.filter(*args, **kwargs) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/query.py" in filter 
    679.   return self._filter_or_exclude(False, *args, **kwargs) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/query.py" in _filter_or_exclude 
    697.    clone.query.add_q(Q(*args, **kwargs)) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/sql/query.py" in add_q 
    1310.   clause, require_inner = self._add_q(where_part, self.used_aliases) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/sql/query.py" in _add_q 
    1338.      allow_joins=allow_joins, split_subq=split_subq, 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/sql/query.py" in build_filter 
    1150.   lookups, parts, reffed_expression = self.solve_lookup_type(arg) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/sql/query.py" in solve_lookup_type 
    1036.   _, field, _, lookup_parts = self.names_to_path(lookup_splitted, self.get_meta()) 
File "/Users/Alex/Desktop/Hunters/lib/python3.5/site-packages/django/db/models/sql/query.py" in names_to_path 
    1397.          "Choices are: %s" % (name, ", ".join(available))) 

Exception Type: FieldError at /profiles/Sofia/ 
Exception Value: Cannot resolve keyword 'username' into field. Choices are: cidade, id, telefone, uf, user, user_id 
+2

'get_object_or_404 (프로필, 사용자 이름 = 사용자 이름)'을'get_object_or_404 (프로필, user__username = 사용자 이름) '로 변경해보십시오. – anupsabraham

+1

맞습니다 ^^ –

+0

고마워, @anupsabraham! 정말로 문제였습니다! 불행히도 이제는 404 오류가 발생합니다. 데이터베이스에서 user__username을 찾을 수 없기 때문입니다. Facebook에 로그인 한 테스트 사용자를 사용 중이며이 사용자를 서명 할 때 사용자 이름 입력란을 명시 적으로 입력했습니다. 어떤 아이디어? –

답변

2

좋아요, 문제를 발견했습니다. 내가 옳은 길을보고 있지 않아서 아주 오래 걸렸어.

코드 자체에는 문제가 없었지만 실제로 필요한 모델을 실제로 저장 한 모델이 더있었습니다. 이 경우 필자는 두 개의 개별 모듈임을 인식하지 못한 채 데이터베이스에서 사용자 및 프로필 정보를 얻고 싶었습니다. 나는 사용자가 저장 한 프로필 정보를 얻으려고했다.

원래이었다 : (오래되고 잘못된)

profiles.views.py

from django.contrib.auth.decorators import login_required 
from django.shortcuts import render, get_object_or_404 
from .models import Profile 

# Create your views here. 

@login_required 
def profile_detail(request, username=None): 
    obj = get_object_or_404(Profile, username=username) 
    context = { 
     "object": obj, 
    } 
    template = 'profile_detail.html' 
    return render(request, template, context) 

profiles.views.py (새로운 작업) - 가져 오기가 프로필 변경 방법주의 사용자와 나는 모든 도움을

from django.contrib.auth.decorators import login_required from django.contrib.auth.models import User from django.shortcuts import render, get_object_or_404 # Create your views here. @login_required def profile_detail(request, username=None): obj = get_object_or_404(User, username=username) user = obj.profile context = { "object": obj, "user": user, } template = 'profile_detail.html' return render(request, template, context) 

obj.profile 많은 감사에서 새 사용자 OBJ를 생성하는 방법!

관련 문제