Jusqu'à présent, j'avais implémenté des fonctions d'authentification telles que la connexion et la déconnexion par moi-même, mais j'aimerais utiliser la conception lors de la création d'un portefeuille cette fois, je laisserai donc cet article pour vous rappeler comment l'utiliser.
Il a été confirmé que cet article fonctionne dans les environnements suivants. ruby 2.7.1 rails 6.0.3 devise 4.7.3
Ajouté à Gemfile. Je vais le traduire en japonais dans la seconde moitié, donc j'inclurai également ce bijou.
Gemfile
gem 'devise'
gem 'devise-i18n'
gem 'devise-i18n-views'
Exécutez bundle install
.
$ bundle install
Créez des fichiers associés.
$ rails g devise:install
Ensuite, un fichier sera créé et le texte anglais suivant sera affiché.
Running via Spring preloader in process 5911
create config/initializers/devise.rb
create config/locales/devise.en.yml
===============================================================================
Depending on your application's configuration some manual setup may be required:
1. Ensure you have defined default url options in your environments files. Here
is an example of default_url_options appropriate for a development environment
in config/environments/development.rb:
config.action_mailer.default_url_options = { host: 'localhost', port: 3000 }
In production, :host should be set to the actual host of your application.
* Required for all applications. *
2. Ensure you have defined root_url to *something* in your config/routes.rb.
For example:
root to: "home#index"
* Not required for API-only Applications *
3. Ensure you have flash messages in app/views/layouts/application.html.erb.
For example:
<p class="notice"><%= notice %></p>
<p class="alert"><%= alert %></p>
* Not required for API-only Applications *
4. You can copy Devise views (for customization) to your app by running:
rails g devise:views
* Not required *
===============================================================================
config/environments/development.rb
config.action_mailer.default_url_options = { host: 'localhost', port: 3000 }
config/routes.rb
root to: 'homes#index'
<p class="notice"><%= notice %></p>
<p class="alert"><%= alert %></p>
$ rails g devise User
En regardant le fichier de migration créé, il n'y a que l'email et le mot de passe, alors ajoutez les colonnes que vous souhaitez ajouter. Après l'ajout, exécutez la migration.
$ rails db:migrate
À ce stade, ouvrez http: // localhost: 3000 / users / sign_up et une nouvelle page d'inscription sera créée. Si vous oubliez d'ajouter une colonne et que vous souhaitez l'ajouter plus tard, exécutez ce qui suit. (Cette fois, nous supposerons l'ajout de la colonne nom d'utilisateur)
$ rails g migration add_username_to_users username:string
Assurez-vous de saisir le nom d'utilisateur, ajoutez donc une contrainte NOT NULL.
db/migrate/XXXXXXXXXXXXXX_add_username_to_users.rb
class AddUsernameToUsers < ActiveRecord::Migration[6.0]
def change
add_column :users, :username, :string, null: false
end
end
Je souhaite personnaliser la vue, alors exécutez ce qui suit.
$ rails g devise:views users
Reflète le contenu modifié de la vue.
config/initializers/devise.rb
#Config en ligne 247.scoped_views =Décommenter false et passer à true
config.scoped_views = true
Permet aux noms d'utilisateur d'être enregistrés lors de l'inscription.
app/controllers/application_controller.rb
class ApplicationController < ActionController::Base
before_action :configure_permitted_parameters, if: :devise_controller?
protected
def configure_permitted_parameters
devise_parameter_sanitizer.permit(:sign_up, keys: [:username])
end
end
$ rails g devise:controllers users
Le fichier du contrôleur et le texte en anglais s'affichent.
Running via Spring preloader in process 9004
create app/controllers/users/confirmations_controller.rb
create app/controllers/users/passwords_controller.rb
create app/controllers/users/registrations_controller.rb
create app/controllers/users/sessions_controller.rb
create app/controllers/users/unlocks_controller.rb
create app/controllers/users/omniauth_callbacks_controller.rb
===============================================================================
Some setup you must do manually if you haven't yet:
Ensure you have overridden routes for generated controllers in your routes.rb.
For example:
Rails.application.routes.draw do
devise_for :users, controllers: {
sessions: 'users/sessions'
}
end
===============================================================================
Vérifions le routage actuel ici.
$ rails routes
Prefix Verb URI Pattern Controller#Action
new_user_session GET /users/sign_in(.:format) devise/sessions#new
user_session POST /users/sign_in(.:format) devise/sessions#create
destroy_user_session DELETE /users/sign_out(.:format) devise/sessions#destroy
...
new_user_registration GET /users/sign_up(.:format) devise/registrations#new
Si la partie Controller # Action est la conception / les enregistrements, la conception / les sessions comme celle-ci, la méthode à définir ne sera pas reflétée.
Remplacez l'itinéraire en fonction du texte anglais qui était affiché lorsque vous avez créé le contrôleur.
config/routes.rb
devise_for :users, controllers: {
registrations: 'users/registrations',
sessions: 'users/sessions'
}
Maintenant que nous l'avons remplacé, vérifiez le routage actuel.
$ rails routes
Prefix Verb URI Pattern Controller#Action
new_user_session GET /users/sign_in(.:format) users/sessions#new
user_session POST /users/sign_in(.:format) users/sessions#create
destroy_user_session DELETE /users/sign_out(.:format) users/sessions#destroy
...
new_user_registration GET /users/sign_up(.:format) users/registrations#new
Vous pouvez maintenant personnaliser le contrôleur. Définissez la méthode.
app/controllers/users/registrations_controller.rb
#Rediriger la destination après avoir créé un compte
def after_sign_up_path_for(resource)
root_path
end
#Rediriger la destination après avoir modifié le compte
def after_update_path_for(resource)
root_path
end
app/controllers/users/sessions_controller.rb
#Rediriger la destination après la déconnexion
def after_sign_out_path_for(resource)
root_path
end
#Rediriger la destination après la connexion
def after_sign_in_path_for(resource)
root_path
end
Maintenant, toutes les destinations de redirection sont sur la première page.
Tout d'abord, définissez la langue par défaut de cette application Rails sur le japonais.
config/application.rb
require_relative 'boot'
require 'rails/all'
Bundler.require(*Rails.groups)
module ConnectStudy
class Application < Rails::Application
# Initialize configuration defaults for originally generated Rails version.
config.load_defaults 6.0
config.i18n.default_locale = :ja #Ajouter ici
end
end
Générez un fichier de traduction japonais pour la devise.
$ rails g devise:views:locale ja
Ce sera en japonais. N'oubliez pas de redémarrer le serveur lorsque vous modifiez la configuration.
concevoir propose également de nombreuses méthodes d'aide utiles, je voudrais donc les utiliser pour développer efficacement des applications.
Recommended Posts