0

ユーザーの認証に Sorcery gem を使用しようとしていますが、登録フォームに入力した後、エラーが発生して登録ページにリダイレクトされます。ただし、コンソールからユーザーを作成することはできます。

ログファイル:

Started POST "/users" for 127.0.0.1 at 2012-01-23 13:54:12 -0500
Processing by UsersController#create as HTML
Parameters: {"utf8"=>"✓",     "authenticity_token"=>"Rh6R5rwLu+XchOv3ki9iATgihU8hqr84y4AcQbyKFyI=", "user"=>  {"username"=>"testusername", "email"=>"testemail@email.com", "password"=>"[FILTERED]"}, "commit"=>"Register"}
[1m[35m (0.1ms)[0m  SELECT 1 FROM "users" WHERE "users"."username" = 'testusername' LIMIT 1
[1m[36m (0.1ms)[0m  [1mSELECT 1 FROM "users" WHERE "users"."email" = 'testemail@email.com' LIMIT 1[0m
Rendered users/new.html.erb within layouts/application (2.1ms)
Completed 200 OK in 29ms (Views: 17.1ms | ActiveRecord: 0.3ms)

users_controller.rb

class UsersController < ApplicationController
    def new
        @user = User.new
    end

    def create
        @user = User.new(params[:user])

        if @user.save
            redirect_to 'Static#index', :notice => "Thanks for registering!"
        else
            render :new
        end
    end
end

モデル/user.rb:

class User < ActiveRecord::Base
   authenticates_with_sorcery!

  attr_accessible :username, :email, :password
  validates_presence_of :username
  validates_presence_of :password, :on => :create
  validates_presence_of :email
  validates_length_of :password, :minimum => 7
  validates_length_of :username, :minimum => 10
  validates_uniqueness_of :username
  validates_uniqueness_of :email
end

config/initializers/sorcery.rb:

Rails.application.config.sorcery.submodules = []

Rails.application.config.sorcery.configure do |config|

config.user_config do |user|

end

config.user_class = "User"
end

魔法の移行:

class SorceryCore < ActiveRecord::Migration
    def self.up
        create_table :users do |t|

            t.string :username,         :null => false
            t.string :email,            :default => nil
            t.string :crypted_password, :default => nil
            t.string :salt,             :default => nil
            t.timestamps

        end
    end

    def self.down
        drop_table :users
    end
end
4

3 に答える 3

1

ここで私が飛び出すのはpasswordフィールドです。attr_accessibleフィールドがデータベースにある場合にのみ使用するように設定しました。Sorcery は、ほとんどの認証ソリューションと同様に、生のパスワードをデータベースに保存しません。これは、passwordフィールドを含まない移行ファイルから確認できます。

代わりに仮想属性を使用passwordして、生の文字列が保存されないようにします。

attr_accessor :password
attr_accessible :username, :email

実際のパスワードはソーサリー プロセスによって暗号化され、crypted_passwordフィールドに保存されます。

このセットアップでは、すべての検証が引き続き機能します。

于 2012-02-20T12:00:40.743 に答える
0

ログファイルで確認する必要があるのは、多かれ少なかれ次のとおりです。

   (0.1ms)  SELECT 1 FROM "users" WHERE "users"."username" = 'testusername' LIMIT 1
   (0.1ms)  SELECT 1 FROM "users" WHERE "users"."email" = 'bogusbogus@bogusbogus.com' LIMIT 1
Binary data inserted for `string` type on column `crypted_password`
  SQL (3.7ms)  INSERT INTO "users" ("created_at", "crypted_password", "email", "salt", "updated_at", "username") VALUES (?, ?, ?, ?, ?, ?)  [["created_at", Mon, 23 Jan 2012 20:39:46 UTC +00:00], ["crypted_password", "$2a$10$za6RqGnvHpAiNASQ86NCl.t/LyrGn1U1wHfzQ3X9f/NJYjY/ramJG"], ["email", "bogusbogus@bogusbogus.com"], ["salt", "xxRspPQysvq5yzp7xpFh"], ["updated_at", Mon, 23 Jan 2012 20:39:46 UTC +00:00], ["username", "testusername"]]

INSERT ステートメントが表示されない場合は、データが検証に合格しなかったことを意味します。同じユーザー名/電子メールで別のユーザーを追加しようとしている可能性がありますか? それ以外の場合は動作するはずです。Railsコンソールでユーザーを作成してみてください:

irb> u = User.create username: 'testusername', ........
irb> u.errors.full_messages

メッセージは返されますか?

編集:申し訳ありませんが、コンソールでユーザーを作成できると書いた更新に気付きました。ログ ファイルから、パラメータは問題ないようです。あなたが言った、それはエラーのある新しいページにリダイレクトします。このエラーは何を示していますか?

于 2012-01-23T20:51:34.480 に答える
0

ユーザー/新しいビューには何がありますか?

:username と :password の長さの検証があることを忘れないでください。

多分あなたはできる:

attr_accessible \
  :username,
  :email,
  :password,
  :password_confirmation
于 2012-09-13T11:56:08.293 に答える