ruby – 应用程序和actioncable不会共享cookie

前端之家收集整理的这篇文章主要介绍了ruby – 应用程序和actioncable不会共享cookie前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用设计进行身份验证,但是当我实现您的方法时,我得到“未经授权的连接尝试被拒绝”

经过几个小时的搜索,我发现:

cookies.signed['user.id']

返回零.在以下代码块中.

def find_verified_user
  if verified_user = User.find_by(id: cookies.signed['user.id'])
    verified_user
  else
    reject_unauthorized_connection
  end
end

我检查了肯定有一个cookie,但它不包含Devise设置的cookie数据.

要检查’user.id’是否实际设置,我在视图中提升它.这是例外,返回用户ID

Signed in as @#{cookies.signed[:username]}.
- raise(cookies.signed['user.id'].inspect)
%br/
%br/
#messages
%br/
%br/
= form_for :message,url: messages_path,remote: true,id: 'messages-form' do |f|
 = f.label :body,'Enter a message:'
 %br/
 = f.text_field :body
 %br/
 = f.submit 'Send message'

我的问题/问题:

似乎cookie在actioncable服务器上不可用.
有没有办法与有线服务器共享Devise设置的cookie?

https://github.com/stsc3000/actioncable-chat.git

解决方法

检查连接到Action Cable服务器的客户端JavaScript文件.有些教程你把它放在’app / assets / javascripts / application_cable.coffee’和其他’app / assets / javascripts / channels / index.coffee’中,但它看起来像这样:
#= require cable

@App = {}
App.cable = Cable.createConsumer("ws://cable.example.com:28080")

您需要WebSocket地址指向您的Cable服务器,并且该地址需要与您的应用程序的其余部分共享cookie命名空间.你很可能指向错误的地方,例如,如果你在本地工作,你需要改变:

App.cable = Cable.createConsumer("ws://cable.example.com:28080")

App.cable = Cable.createConsumer("ws://localhost:28080")

假设您的Cable服务器正在端口28080上运行(在bin / cable可执行文件中指定).还要确保清除浏览器缓存,以便更新的文件是浏览器使用的文件.

原文链接:https://www.f2er.com/ruby/265320.html

猜你在找的Ruby相关文章