我正在使用旨在与VUE前端一起使用的Rails API。这是我第一次仅将Rails作为API使用。
我熟悉在其他Rails应用程序中使用devise进行用户身份验证。
我们的登录有效,与注销相同。我不知道如何编辑和删除用户。
我的耙路显示如下:
new_api_user_session GET /api/v1/auth/sign_in(.:format) devise_token_auth/sessions#new
api_user_session POST /api/v1/auth/sign_in(.:format) devise_token_auth/sessions#create
destroy_api_user_session DELETE /api/v1/auth/sign_out(.:format) devise_token_auth/sessions#destroy
new_api_user_password GET /api/v1/auth/password/new(.:format) devise_token_auth/passwords#new
edit_api_user_password GET /api/v1/auth/password/edit(.:format) devise_token_auth/passwords#edit
api_user_password PATCH /api/v1/auth/password(.:format) devise_token_auth/passwords#update
cancel_api_user_registration GET /api/v1/auth/cancel(.:format) devise_token_auth/registrations#cancel
new_api_user_registration GET /api/v1/auth/sign_up(.:format) devise_token_auth/registrations#new
edit_api_user_registration GET /api/v1/auth/edit(.:format) devise_token_auth/registrations#edit
api_user_registration PATCH /api/v1/auth(.:format) devise_token_auth/registrations#update
我的route.rb就像这样:
Rails.application.routes.draw do
root 'home#index'
namespace :api do
scope :v1 do
resource :profile, only: [:show]
mount_devise_token_auth_for "User", at: 'auth'
## other code
end
end
end
我正在使用CURL测试api。以下命令可以成功登录:
curl -X POST -v -H 'Content-Type: application/json' http://localhost:3000/api/v1/auth/sign_in -d '{"email": "test@example.com", "password": "password"}'
没问题。
更新用户的路由应为http://localhost:3000/api/v1/auth/
登录后,会显示出客户端和访问令牌的值。当我将它们弹出到以下curl命令中时,我希望用户进行更新。我要更新的属性是“ sortOrder”。
curl -X PATCH -v -H 'Content-Type: application/json' -H 'access-token: XUbhcAgWlVnARf9Ps4rjR' -H 'client: Lxg5us7MpUyAuM5xQGNuqg' -H 'uid: test@example.com' http://localhost:3000/api/v1/auth/ -d '{"sortOrder": "DESC"}'
从该命令中,我的rails日志显示:
Started PATCH "/api/v1/auth/" for 127.0.0.1 at 2018-12-26 12:10:53 -0800
Processing by DeviseTokenAuth::RegistrationsController#update as */*
Parameters: {"sortOrder"=>"DESC", "registration"=>{"sortOrder"=>"DESC"}}
User Load (0.6ms) SELECT `users`.* FROM `users` WHERE `users`.`uid` = 'test@example.com' LIMIT 1
Unpermitted parameter: registration
Completed 404 Not Found in 101ms (Views: 0.3ms | ActiveRecord: 0.6ms)
curl命令的输出为:
* Trying 127.0.0.1...
* Connected to localhost (127.0.0.1) port 3000 (#0)
> PATCH /api/v1/auth/ HTTP/1.1
> Host: localhost:3000
> User-Agent: curl/7.47.0
> Accept: */*
> Content-Type: application/json
> access-token: XUbhcAgWlVnARf9Ps4rjR
> client: Lxg5us7MpUyAuM5xQGNuqg
> uid: test@example.com
> Content-Length: 50
>
* upload completely sent off: 50 out of 50 bytes
< HTTP/1.1 404 Not Found
< 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
< X-Request-Id: 1e5e61f6-1226-43dc-b8b3-30a576b0c03a
< X-Runtime: 0.104965
< Vary: Origin
< Transfer-Encoding: chunked
<
* Connection #0 to host localhost left intact
{"success":false,"errors":["User not found."],"status":"error"}
我不确定我在这里缺少什么。有了这个装置后,我将无法使用装置/注册控制器。我可能可以自己创建一个,但是应该可以。我无法找到有关devise_token_auth gem的文档,该文档可解决用户更新和删除的问题。
我得到的结果似乎是“找不到用户”。我尝试了几种方法来在请求中获取用户UID,电子邮件和ID,但似乎无济于事。以前有没有人经历过?
答案 0 :(得分:0)
看起来用户没有以某种方式被保存。我会尝试在route.rb中将:create
添加到resource :profile, only: [:show, :create]
中。我只是在学习RoR a Devise,所以我不能说这是100%的治愈方法,但值得一试。按照相同的逻辑,您可以添加:edit
和:destroy
操作来编辑/删除配置文件/用户。