Django之全局使用request.user.username的實(shí)例詳解
我就廢話不多說了,大家還是直接看代碼吧!
def pro_mgr(): ''' 獲取當(dāng)前登陸用戶的項(xiàng)目 :return: ''' if DEVELOP_USER_NAME == ’admin’: return Project.objects.all() return Project.objects.filter(prj_mgr=DEVELOP_USER_NAME)class DeployApplyForm(ModelForm): # project = forms.ModelChoiceField(queryset=pro_mgr()) bgn_time = forms.DateTimeField(initial=datetime.datetime.now().strftime('%Y-%m-%dT%H:%M:%S'), label=u’開始’, input_formats=[’%Y-%m-%dT%H:%M:%S’], widget=forms.DateTimeInput( attrs={’type’: ’datetime-local’, ’emptyTips’: u’請(qǐng)選擇時(shí)間’, ’step’: ’1’})) end_time = forms.DateTimeField(initial=datetime.datetime.now().strftime('%Y-%m-%dT%H:%M:%S'), label=u’結(jié)束’, input_formats=[’%Y-%m-%dT%H:%M:%S’], widget=forms.DateTimeInput( attrs={’type’: ’datetime-local’, ’emptyTips’: u’請(qǐng)選擇時(shí)間’, ’step’: ’1’})) class Meta: model = DeployApply fields = ’__all__’ def __init__(self, *args, **kwargs): prj_mgr = kwargs.pop(’prj_mgr’, ’’) super(DeployApplyForm, self).__init__(*args, **kwargs) if prj_mgr == ’admin’: self.fields[’project’] = forms.ModelChoiceField(queryset=Project.objects.all()) else: self.fields[’project’] = forms.ModelChoiceField(queryset=Project.objects.filter(prj_mgr=prj_mgr))
//views.pydeployApplyForm = DeployApplyForm(initial=wfContent[0], prefix=’deployApply’,prj_mgr=request.user.username)
//settings.py# DEVELOP模式下登陸用戶DEVELOP_USER_NAME = ’admin’
補(bǔ)充知識(shí):Django 中 request.user 調(diào)用用戶名時(shí)出現(xiàn) AnonymousUser(匿名對(duì)象)的錯(cuò)誤
說明
已經(jīng)添加了額外的屬性,現(xiàn)在想通過request.user的方式獲取,打印request.user是一個(gè)AnonymousUser對(duì)象,無法獲取 user 值!
原因
1. 沒有登錄賬號(hào)或者無法登錄成功。
2. 登錄成功但是在登錄代碼中沒有注冊(cè) cookie,導(dǎo)致無法驗(yàn)證身份!
3. 其它原因。
解決方法
1. 登錄賬號(hào),你也可以試著使用 admin 賬戶登錄后,看看能否解決。
2. 參考以下代碼,在 login 中注冊(cè)cookis(大多數(shù)是這種情況):
auth_obj = auth.authenticate(request, username=username, password=password)if auth_obj: # 需要auth驗(yàn)證cookie auth.login(request, auth_obj) ....
3. 換另一種方式重寫 login 。
以上這篇Django之全局使用request.user.username的實(shí)例詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 用css截取字符的幾種方法詳解(css排版隱藏溢出文本)2. ASP.NET MVC遍歷驗(yàn)證ModelState的錯(cuò)誤信息3. jsp網(wǎng)頁實(shí)現(xiàn)貪吃蛇小游戲4. ASP 信息提示函數(shù)并作返回或者轉(zhuǎn)向5. CSS hack用法案例詳解6. asp中response.write("中文")或者js中文亂碼問題7. 將properties文件的配置設(shè)置為整個(gè)Web應(yīng)用的全局變量實(shí)現(xiàn)方法8. PHP設(shè)計(jì)模式中工廠模式深入詳解9. asp(vbs)Rs.Open和Conn.Execute的詳解和區(qū)別及&H0001的說明10. ASP實(shí)現(xiàn)加法驗(yàn)證碼
