Если размер шрифта достаточно велик, может показаться, что он не центрирован из-за заполнения шрифтов.
Попробуйте использовать уже упомянутые свойства в сочетании с android:includeFontPadding
, примерно так:
android:gravity="center"
android:includeFontPadding="false"
Я использовал оба руководства, упомянутых в других ответах, Railscast # 210 и Devise Wiki . Однако, насколько я могу судить, они явно не говорят, как проверять наличие и / или уникальность поля имени пользователя.
Если вы добавили имя пользователя с простой миграцией -
rails generate migration addUsernameToUser username:string
Тогда devise не делает ничего особенного с этим полем, поэтому вам нужно добавить проверки для проверки и уникальности самостоятельно в User модель.
class User < ActiveRecord::Base
...
validates_presence_of :username
validates_uniqueness_of :username
Однако, если вы посмотрите на RailsCast # 209, есть пример миграции, использованной для создания модели User.
class DeviseCreateUsers < ActiveRecord::Migration
def self.up
create_table(:users) do |t|
t.database_authenticatable :null => false
# t.confirmable
t.recoverable
t.rememberable
t.trackable
# t.lockable :lock_strategy => :failed_attempts, :unlock_strategy => :both
t.timestamps
end
add_index :users, :email, :unique => true
# add_index :users, :confirmation_token, :unique => true
add_index :users, :reset_password_token, :unique => true
# add_index :users, :unlock_token, :unique => true
end
def self.down
drop_table :users
end
end
Обратите внимание, что электронная почта пользователя определяется как уникальная. Возможно, если имя пользователя будет добавлено с использованием того же синтаксиса, тогда devise magic позаботится о присутствии и уникальности.
Rails 4 и сильные параметры
Вдобавок к вышесказанному мне нужно было сгенерировать представления с помощью:
$ rails g devise:views
, затем в devise.rb
добавить:
config.scoped_views = true
и, наконец, настройте разрешенные параметры, как показано ниже для sign_up
, как показано ниже:
class ApplicationController < ActionController::Base
before_filter :configure_permitted_parameters, if: :devise_controller?
protected
def configure_permitted_parameters
devise_parameter_sanitizer.for(:sign_up) do |u|
u.permit :username, :email, :password, :password_confirmation
end
end
end
Кроме того, моя проверка для username
заключается в следующем:
validates :username, presence: true
validates :username, uniqueness: true, if: -> { self.username.present? }
Я использую две строки, поэтому, если username
пусто, я получаю только одну ошибку.
Если кто-либо задается вопросом, как заставить логин проверять на имя пользователя, если у его бланка или удостоверяться пользователям не может быть того же имени пользователя. Я провел довольно много часов, пытаясь понять это, и в ned я только должен был добавить:
validates_uniqueness_of :username, case_sensitive: false
validates_presence_of :username
к Вашему user.rb файлу в приложении/моделях /
Вот доктора https://api.rubyonrails.org/classes/ActiveRecord/Validations/ClassMethods.html
, Это теперь бросает ошибки, в которых я нуждаюсь. Я чувствую себя подобно идиоту, потому что я нашел uniquness_of сначала, затем вернулся к и провел часы, пытаясь выяснить, как проверить на чистую область, тогда нашел, что это находится в той же документации как другой... Я - новичок.
Теперь на фигуру, как изменить сообщения об ошибках, так как они не находятся в devise.en.yml