TypeError(没有将nil隐式转换为String)在生产环境中使用Rails devise-jwt gem

问题描述 投票:1回答:1

投入ENV ['DEVISE_JWT_SECRET_KEY']在生产控制台中返回密钥。

DEVICE_JWT_SECRET_KEY是在Centos OS上通过导出命令设置的。

devise.rb文件

 config.jwt do |jwt|
    jwt.secret = ENV['DEVISE_JWT_SECRET_KEY']
    jwt.dispatch_requests = [
      ['POST', %r{^/users/sign_in.json$}]
    ]
    jwt.revocation_requests = [
      ['DELETE', %r{^/logout$}]
    ]
    jwt.expiration_time = 1.day.to_i
  end

在登录请求时出现此错误。


==> log/production.log <==
I, [2020-03-29T11:15:05.149855 #18692]  INFO -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] Started POST "/users/sign_in.json" for 110.93.200.118 at 2020-03-29 11:15:05 +0000
I, [2020-03-29T11:15:05.150525 #18692]  INFO -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] Processing by Devise::SessionsController#create as JSON
I, [2020-03-29T11:15:05.150604 #18692]  INFO -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c]   Parameters: {"user"=>{"email"=>"[email protected]", "password"=>"[FILTERED]"}, "session"=>{"user"=>{"email"=>"[email protected]", "password"=>"[FILTERED]"}}}
D, [2020-03-29T11:15:05.152091 #18692] DEBUG -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c]   User Load (0.3ms)  SELECT  "users".* FROM "users" WHERE "users"."email" = $1 ORDER BY "users"."id" ASC LIMIT $2  [["email", "[email protected]"], ["LIMIT", 1]]
D, [2020-03-29T11:15:05.325258 #18692] DEBUG -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c]   Clinic Load (1.4ms)  SELECT  "clinics".* FROM "clinics" WHERE "clinics"."id" = $1 LIMIT $2  [["id", 3], ["LIMIT", 1]]
I, [2020-03-29T11:15:05.326744 #18692]  INFO -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] Completed 500 Internal Server Error in 176ms (ActiveRecord: 1.7ms)
F, [2020-03-29T11:15:05.327800 #18692] FATAL -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c]   
F, [2020-03-29T11:15:05.328843 #18692] FATAL -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] TypeError (no implicit conversion of nil into String):
F, [2020-03-29T11:15:05.329247 #18692] FATAL -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c]   
F, [2020-03-29T11:15:05.329333 #18692] FATAL -- : [9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] jwt (2.2.1) lib/jwt/algos/hmac.rb:14:in `digest'
[9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] jwt (2.2.1) lib/jwt/algos/hmac.rb:14:in `sign'
[9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] jwt (2.2.1) lib/jwt/signature.rb:37:in `sign'
[9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] jwt (2.2.1) lib/jwt/encode.rb:57:in `encode_signature'
[9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] jwt (2.2.1) lib/jwt/encode.rb:34:in `encoded_signature'
[9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] jwt (2.2.1) lib/jwt/encode.rb:20:in `segments'
[9f71ec3f-d4ac-4efa-9ba1-09276c1e5f1c] jwt (2.2.1) lib/jwt.rb:24:in `encode'

ruby-on-rails ruby devise rubygems jwt
1个回答
0
投票

似乎我在生产区中错过了gem 'dotenv-rails'

仅需两个步骤即可完成。

gem 'dotenv-rails', :groups => [:development, :test, :production]

添加

set :linked_files, fetch(:linked_files, []).push('config/database.yml', '.env')
© www.soinside.com 2019 - 2024. All rights reserved.