javascript - 使用 Angular JS 通过 Rails Paperclip 提交文件

标签 javascript ruby-on-rails ruby angularjs ruby-on-rails-3

我正在尝试使用 Angular 将文件作为参数发送到 Rails,然后让 Rails 通过回形针将该文件保存为用户附件。我得到的最远的是让 Rails 上传一些东西,但它最终是一个带有单行“目标文件”的 txt 文件。

这是相关的 Angular

a.uploadAnonRes = function(app){
  if(window.FileReader){ console.log("supported")};
  console.log(($('.anonUploadField'))[0].files);
  http = {
    method: "PUT",
    url: '/admin/upload_anon_res.json',
    params: {
      anon_file: btoa(($('.anonUploadField'))[0].files[0]),
      user_id: app.raw_app.user_id
    }
  };
  $http(http).success(function(data){
      console.log("success");
  });
};

这是相关的 rails

def upload_anon_res
 user = User.find(params[:user_id])
 user.anon_resume = decode_res
 user.save
 respond_to do |format|
  format.json{ render json: user, root: false }
 end
end

def decode_res
 decoded_data = Base64.decode64(params[:anon_file])
 data = StringIO.new(decoded_data)
 return data
end

最后一点,我尝试使用的文件类型是 doc/docx。我试图避免添加新的依赖项,但如果没有其他好方法,那就这样吧。我真的很感谢任何帮助/建议。

最佳答案

这个answer对我帮助很大,但我将仔细阅读其中的每个部分以获得完整的答案。

假设您有一个带有 avatar 属性的 User 模型。

在你的 Angular View 中:

<input type="file" name="avatar" onchange="angular.element(this).scope().uploadFile(this.files)" />

在 Angular Controller 中:

    $scope.uploadFile = function(files) {
        var fd = new FormData();
        fd.append('user[avatar]', files[0]); // 'user[avatar]' is important, so that params[:user][:avatar] contains the file, as expected by Rails
        $http.put('/users.json', fd, { // The update method of the users controller
            withCredentials: true,
            headers: {
                'Content-Type': undefined,
                'X-CSRF-Token': $('meta[name=csrf-token]').attr('content')
            },
            transformRequest: angular.identity
        }).success(function(e) {
            console.log(e);
        }).error(function(e) {
            console.log(e);
        });
    };

在 UserController.rb 中:

class UserController < ApplicationController
  def update
    @user = User.find(params[:id])
    @user.assign_attributes(user_allowed_parameters)
    if (@user.save)
      render json: {msg: 'Successfully updated'}
    else
      render json: {msg: @user.errors.full_messages}, status: 500
    end
  end

  private

  def user_allowed_parameters
    params.fetch(:user, {}).permit(
      :first_name, 
      :last_name,
      :email,
      :avatar
    )
  end
end

关于javascript - 使用 Angular JS 通过 Rails Paperclip 提交文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28726021/

相关文章:

javascript - 无法在 WP7 Web 浏览器控件中通过 Javascript 显示警报

javascript - ng-repeat 中的 Angular 选择

ruby-on-rails - rails 路由:except question

ruby-on-rails - 错误:执行 gem 时 ... (Gem::Package::FormatError) profile.gem 中缺少包元数据

ruby - rake 数据库 :migrate runs into an error for an undefined method

javascript - 插件 "react"在 "package.json ..."和 "BaseConfig ..."之间发生冲突

javascript - 在javascript中保持随机选择的变量静态

ruby-on-rails - 如何正确安装 Kaminari?

ruby-on-rails - 在 Ruby 中获取 URL 的重定向

ruby - 配置 : make: echo: Command not found