ruby-on-rails - 为什么我的 Angular 应用程序不向我的 Entangle rails Controller 发送参数?

标签 ruby-on-rails angularjs redis real-time

为了了解实时应用程序,我正在尝试使用 Entangled 创建一个基本的留言板.

我有一个 Angular 应用程序和一个带有包含 Entangled::Controller 的消息 Controller 的 Rails 后端。当从 Angular 应用程序提交表单时,此 Rails Controller 成功接收到请求 - 使用 Entangled 提交表单。 (点击提交后,Angular Controller 中会触发一个函数,该函数应在后端创建一条新消息并更新所有订阅该后端的客户端。)

我知道 Angular 函数在点击提交时被触发,我知道函数从表单接收到正确的信息:console.log($scope.message) 显示 {socket :“ws://message-board-olliehm.c9users.io:8080/messages”,用户名:“ggg”,内容:“gggggg” 我在用户名字段中提交“ggg”和“gggggg” "在内容字段中。

问题是这些字段没有到达 Rails Controller 。当我单击提交时,在 Rails Controller 中触发了正确的操作,但参数不包含正确的信息: def create 中的 p params 返回 { “controller”=>“messages”、“action”=>“create”,没有“message”散列,也没有“username”或“content”键。

我不知道 Entangled 对用户名和内容字段做了什么。

Redis 对我来说是新手,所以我不确定是否存在问题。我安装了 Redis,redis-server 正在按照 Entangled 的要求运行。我有一个如下所示的 redis 初始化程序,它在 Rails 控制台中成功连接并让我将数据放入数据库:

$redis = Redis.new(:host => $IP, :port => 6379)

这是我的 Angular Controller :

var controllers = angular.module('controllers');

controllers.controller('MessageboardController', ['$scope','Message', function($scope,Message){

  $scope.message = Message.new();

  $scope.post = function() {
    console.log($scope.message);
    $scope.message.$save(function() {
      $scope.$apply(function() {
        $scope.message = Message.new();
      });
    });
  };

  Message.all(function(err, messages) {
    $scope.$apply(function() {
      $scope.messages = messages;
    });
  });

}]);

这里的消息是指这个工厂:

messageboard.factory('Message', function(Entangled){
  return new Entangled('ws://message-board-olliehm.c9users.io:8080/messages');
});

这是我的 Angular View :

<h1>Messageboard</h1>

<section class='row' ng-if='messages'>
  <ul>
    <li ng-repeat='message in messages'>
      {{message.username}}
      {{message.content}}
    </li>
  </ul>
</section>

<section class='row'>
  <form ng-submit="post()">
    <div class='form-group'>
      <label for='username'>Message as</label>
      <input ng-model='message.username' name='username' type='text'>
    </div>
    <div class='form-group'>
      <input ng-model='message.content' name='message' type='text' placeholder='Write your message here'>
    </div>
    <div class='form-group'>
      <input type="submit">
    </div>
  </form>
</section>

非常感谢您的建议 - 这导致了长期的挫败感,我非常渴望着手创建具有实时更新的内容。

最佳答案

经过反复试验,我意识到后端 Controller 显然接收到的空参数具有误导性。只要我对 Controller 接收到的原始参数执行以下操作,参数就会正确到达并创建并广播一个新的消息对象:

params.require(:message).permit(:content,:username)

即正是您对按预期到达的表单参数所做的事情。对我来说奇怪的是 params 不包含“消息”哈希,直到您需要如上所述的哈希。我想这与它不是常规的 HTTP 请求有关,但将不胜感激......

关于ruby-on-rails - 为什么我的 Angular 应用程序不向我的 Entangle rails Controller 发送参数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39231320/

相关文章:

javascript - 指令中的 element.remove() 将所有 sibling 的 parentElement/Node 设置为 null

angularjs - 如何让这个过滤器变得更好

redis - 删除Redis中的完整文件夹

python - Python中Redis池中的默认连接数

ruby-on-rails - 使用 docker 卷时,本地更改不反射(reflect)浏览器中的更改

ruby-on-rails - Paperclip::Errors::MissingRequiredValidatorError 与 Rails 4

ruby-on-rails - ArticlesController 的未定义方法 `action'(表不存在):Class - Ruby on Rails error

angularjs - 从 Controller $scope 发出的事件 $ 并不总是到达 $rootScope 中定义的监听器

redis - 为什么redis集群只有16384个槽位?

ruby-on-rails - 使用 gmail 配置 Rails 邮件程序 smtp