3

なぜかマイページのDeviseで認証がうまくいかず、Unauthorized 401エラーになってしまいます。net/ldap の手順を実行すると、問題なくバインドされるようです。問題がどこにあるのかわかりません。

サーバーからの出力:

Processing by Devise::SessionsController#create as HTML
  Parameters: {"utf8"=>"â", "authenticity_token"=>"0uaLJJKobrDkn1mGDRP/RM6gIec+Wi7oykgWYuutsvk=", "user"=>{"login"=><login>, "password"=>"[FILTERED]", "remember_me"=>"0"}, "commit"=>"Sign in"}
Completed 401 Unauthorized in 14ms

ldap.yml から:

development:
  host: <hostname>
  port: 389
  attribute: sAMAccountName
  base: <base>
  admin_user: <admin user>
  admin_password: <admin pass>
  ssl: false
  # <<: *AUTHORIZATIONS

Devise.rb から:

config.ldap_use_admin_to_bind = true
config.authentication_keys = [ :login ]

irbでのテストから:

$ irb
irb(main):001:0> require 'rubygems'
=> true
irb(main):002:0> require 'net/ldap'
=> true
irb(main):003:0> ldap = Net::LDAP.new
=> #<Net::LDAP:0x141d19 @host="127.0.0.1", @auth={:method=>:anonymous}, @encryption=nil, @base="dc=com", @port=389, @verbose=false, @open_connection=nil>
irb(main):004:0> ldap.host = <hostname>
=> <hostname>
irb(main):005:0> ldap.port = 389
=> 389
irb(main):006:0> ldap.base = <base>
=> <base>
irb(main):007:0> ldap.auth <admin user>, <admin pass>
=> {:method=>:simple, :username=><admin user>, :password=><admin pass>}
irb(main):008:0> dn = ldap.search( :filter => Net::LDAP::Filter.eq('sAMAccountName', <login>)).first.dn
=> <login dn information>
irb(main):009:0> ldap.auth dn, <password>
=> {:method=>:simple, :username=><login dn information>, :password=><password>}
irb(main):010:0> ldap.bind
=> true

ご覧のとおり、バインドは通常の net/ldap テストでは正常に機能しますが、実際の Rails サイトを参照すると、Devise モジュールが行うべきことを複製しても、何らかの理由で機能しないようです。

4

2 に答える 2

0

他の誰かがこの問題を抱えている場合、この質問で必要な修正が得られました。

于 2013-06-01T02:25:58.210 に答える
0

認証キーは :login ではなく :username です。それはあなたの問題を解決するかもしれません

于 2013-01-28T21:13:49.513 に答える