使用Rails构建登录API后端功能

时间:2019-06-18 08:09:28

标签: ruby-on-rails ruby rails-api

我有React应用,正在调用Rails上的ruby。我正在建立登录页面,但卡在了密码验证部分。出现错误

 "#<ArgumentError: wrong number of arguments (given 0, expected 1)>"

此行发生错误

  if user && user.authenticate(password)

这是逗号行 enter image description here

这是users_controller.rb

class Api::V1::UsersController < ApplicationController
before_action :authenticate_with_token!, only: [:logout]

def facebook
 enter code hereif params[:facebook_access_token]
  graph = Koala::Facebook::API.new(params[:facebook_access_token])
  user_data = graph.get_object("me?fields=name,email,id,picture")

  user = User.find_by(email: user_data['email'])
  if user
    user.generate_authentication_token
    user.save
    render json: user, status: :ok
  else
    user = User.new(
                fullname: user_data['fullname'],
                email: user_data['email'],
                uid: user_data['id'],
                provider: 'Facebook',
                image: user_data['picture']['data']['url']
            )
    user.generate_authentication_token

    if user.save
      render json: user, status: :ok
    else
      render json: { error: user.errors, is_success: false}, status: 422
    end
  end
  else
  render json: { error: "Invalid Facebook Token", is_success: false}, status: :unprocessable_entity
  end
end

def logout
 user = User.find_by(access_token: params[:access_token])
 user.generate_authentication_token
 user.save
 render json: { is_success: true}, status: :ok
end

def login
 email = user_params[:email]
 password = user_params[:password]
 user = User.find_by(email: email)
 if user && user.authenticate(password)
    session[:user_id] = user.id
    render json: user, status: :ok
 else
 render json: { error: user.errors, is_success: false}, status: 422
 end
end

def add_card
user = User.find(current_user.id)
if user.stripe_id.blank?
  customer = Stripe::Customer.create(
    email: user.email
  )
  user.stripe_id = customer.id
  user.save
else
  customer = Stripe::Customer.retrieve(user.stripe_id)
end

customer.sources.create(source: params[:stripe_token])
render json: { is_success: true}, status: :ok
rescue Stripe::CardError => e
render json: { error: e.message, is_success: false}, status: :not_found
end

def user_params
  params.require(:user).permit(:email, :password)
end

end

这是routes.rb

Rails.application.routes.draw do
namespace :api, defautls: {format: :json} do
namespace :v1 do
  get '/logout' => 'users#logout'
  get '/login' => 'users#login'
  post '/login' => 'users#login'
  post '/signup' => 'users#signup'
  end
 end
end

这是user.rb模型

class User < ApplicationRecord
 has_secure_password
 before_create :generate_authentication_token
 devise :database_authenticatable, :registerable,
     :recoverable, :rememberable, :trackable, 
 :validatable,
     :confirmable, :omniauthable
 validates :fullname, presence: true, length: {maximum: 
 50}
end
def generate_authentication_token
 begin
  self.access_token = Devise.friendly_token
 end while self.class.exists?(access_token: access_token)
end

这是我正在制作的api调用 enter image description here

这是即时通讯的json

{"email": "bearatamer+testfour@gmail.com", "password": "amer1234"}

2 个答案:

答案 0 :(得分:1)

如果您看到随附的控制台的屏幕截图,您会发现参数为: email, password, defaultsuser ,如果仔细观察,您将看到此user有一个哈希,其中仅包含电子邮件,没有密码。 这给了我们一个提示。

现在,在您的user_params方法中:

def user_params
  params.require(:user).permit(:email, :password)
end

在这里, params.require(:user)将要求提供一个名为user的密钥,该密钥存在,否则将引发错误。接下来,您将拥有:.permit(:email, :password),它允许在父user键的哈希值中使用这两个参数。

现在,似乎在发送JSON时出现了一些问题,要么您没有发布完整的json,要么在发送之前或在将其处理给控制器之前正在对json进行转换(如果有人这样做,这是极不可能的)自定义,但谁知道)。

解决方案:如果我是您,则将再次检查我的json,或者实际上我将仅发送以下json:{"user": {"email": "bearatamer+testfour@gmail.com", "password": "amer1234"}},或者如果您不想在user键下嵌套,则必须从require键上的强参数中删除user

答案 1 :(得分:0)

问题在于此行

 if user && user.authenticate(password)

一旦我更改为有效

 if user && user.valid_password?(params[:password])