django使用ldap登录认证

1、重写认证过程

#coding:utf-8
from django.contrib.auth.models import User
import ldap
from django.contrib.auth import authenticate as authenticate_old
from xxxxxxxx.settings import ldapserver,mail_postfix ,se_dn,se_pw,base_dn,attrs,filter

#########################myclass
ldapserver='ldap://10.225.2.111:389'
#dn='CN=Users,DC=xxxx,DC=inc'
mail_postfix='@xxxx.com'
base_dn="OU=技术部,OU=xxxx,DC=xxxx,DC=inc"
se_dn='CN=xx,CN=Users,DC=xxxx,DC=inc'
se_pw='eds.ebj1'
attrs=['mailNickname','mobile']
filter = '(objectclass=person)'

class myldapBackend:
    def authenticate(self,username=None,password=None):
        if len(password) == 0:
            return None
        con = ldap.initialize(ldapserver)
        try:
            r1 = con.simple_bind_s( se_dn, se_pw )
            #print r1
            search_result = con.search_s( base_dn, ldap.SCOPE_SUBTREE, filter, attrs )
            for i in search_result:
                if i[1]['mailNickname'][0] == username:
                    x = i
                    dn=i[0]
                    result=con.simple_bind_s( dn, password )
                    break
                else:
                    pass
            if result:
                pass
            else:
                return authenticate_old(username=username,password=password)
        except:
            return authenticate_old(username=username,password=password)
        if result[0] == 97:
            return self.get_or_create_user(username,password,dn,x)
        else:
            return None

    def get_or_create_user(self, username, password, dn, i):
        try:
            user = User.objects.get(username=username)
        except User.DoesNotExist:
            mail = username + mail_postfix
            user = User(username=username,email=mail)
            user.is_staff = True
            user.is_superuser = False
            user.set_password('ldap a authenticated')
            user.save()
        return user

2、修改登录视图:

def login(req):
    if req.method == 'POST':
        uf = UserForm(req.POST)
        if uf.is_valid():
            username = uf.cleaned_data['username']
            password = uf.cleaned_data['password']
            a=myldapBackend()
            user = a.authenticate(username=username, password=password)
            print user
            if user:
                user.backend = 'django.contrib.auth.backends.ModelBackend'
                if user.is_active:
                    user_login(req,user)
                    response = HttpResponseRedirect("/home/")
                    req.session["uid"] = user.id
                    #response.set_cookie('user_id',user.id)
                    return  response
            else:
                return HttpResponseRedirect('/login/')
    else:
        uf = UserForm()
    return render_to_response('login.html',{'uf':uf})


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值