我爲我的JSON API使用devise
和simple_token_authentication
。一旦我有一個電子郵件和令牌,根據simple_token_authentication,我應該進行身份驗證,因此能夠訪問控制器操作。但是,當我嘗試以下的curl命令:設計:您必須在繼續之前確認您的電子郵件地址
curl -i -H "Accept: application/json" -H "Content-type: application/json" -H "X-User-Email: [email protected]" -H "X-User-Token: NFHCVtZdjy2zwT_hTezU" -X GET http://localhost:3001/users/11.json
我收到以下錯誤:
HTTP/1.1 401 Unauthorized X-Frame-Options: SAMEORIGIN X-XSS-Protection: 1; mode=block X-Content-Type-Options: nosniff Content-Type: application/json; charset=utf-8 Cache-Control: no-cache Set-Cookie:
_my_app_session=Q0VTT1NNNGx1K2hoK3pSMXBZNFhzaG1BSXd5cGg3WWhkTmVtekEvSkc4Q2FqSkF4anZMYVc1dENWNzJkRUhwcFN2VG8yb0xzeGk4cjFtSm5tWHIxb1E9PS0tZ3V6cXZRL0ZKR3hxSVh1NWxjeENLZz09--145a421cac94ab6be992df6b0f534968ba751231; path=/; HttpOnly X-Request-Id: 8425dd4c-d13e-465b-997e-847288ddbdf0 X-Runtime: 0.027902 Transfer-Encoding: chunked
{"error":"You have to confirm your email address before continuing."}Mac-mini-3:my_app donato$
現在檢查了我的用戶模型了:
User.first.attributes.slice("confirmation_token", "confirmed_at", "confirmation_sent_at", "unconfirmed_email")
=> {"confirmation_token"=>"Lvh4XzW5wAeXmHVFEFQk", "confirmed_at"=>nil, "confirmation_sent_at"=>Fri, 10 Mar 2017 22:15:20 UTC +00:00, "unconfirmed_email"=>nil}
現在看來似乎已經是確認了嗎?
其實,我曾經這樣做:
user.confirmed_at = Time.now
user.save!
那麼這個錯誤就走開了。設計有一個方法skip_confirmation!
。但是當我從我的移動應用程序創建用戶時,devise處理所有事情。我怎麼能鉤入設計來調用這個方法?
那麼你有更新嗎? –