当前位置: 首页 > 面试题库 >

回形针和xhr.sendAsBinary

景辰钊
2023-03-14
问题内容

我使用回形针将文件添加到模型中。

我想使用firefox 3.6的新功能xhr.sendAsBinary来发送带有ajax请求的文件。

这是我建立请求的方式:

var xhr = new XMLHttpRequest();


xhr.open("POST", "/photos?authenticity_token=" + token 
                        + "&photo[name]=" + img.name
                        + "&photo[size]=" + img.size);

xhr.overrideMimeType('text/plain; charset=x-user-defined-binary');
xhr.sendAsBinary(bin);

namesize可以毫无问题地保存在我的模型中,但是回形针不会捕获文件本身。

我的模特

class Photo < ActiveRecord::Base
  has_attached_file :photo, :styles => { :medium => "300x300>", :thumb => "100x100>" }
end

迁移

def self.up
  add_column :photos, :photo_file_name,     :string
  add_column :photos, :photo_content_type,  :string
  add_column :photos, :photo_file_size,     :integer
  add_column :photos, :photo_updated_at,    :datetime
end

和我的控制器

  # POST /photos
  # POST /photos.xml
  def create
    @photo = Photo.new(params[:photo])

    respond_to do |format|
      if @photo.save
        format.html { redirect_to(@photo, :notice => 'Photo was successfully created.') }
        format.xml  { render :xml => @photo, :status => :created, :location => @photo }
      else
        format.html { render :action => "new" }
        format.xml  { render :xml => @photo.errors, :status => :unprocessable_entity }
      end
    end
  end

任何想法如何解决这个问题?

谢谢


问题答案:

我终于成功了!

我的javascript发送文件看起来像这样

 send : function() {
     try {
         var xhr = new XMLHttpRequest;
         //var url = this.form.action;
         var url = '/photos';

         var boundary    = this.generateBoundary();
         var contentType = "multipart/form-data; boundary=" + boundary;

         this.filesToUpload.forEach(function(file, index, all) {

             xhr.open("POST", url, true);
             xhr.setRequestHeader("Content-Type", contentType);

             for (var header in this.headers) {
                 xhr.setRequestHeader(header, headers[header]);
             }


             var CRLF  = "\r\n";
             var request = "--" + boundary  + CRLF;

             request += 'Content-Disposition: form-data; ';
             request += 'name="' + 'photo[name]' + '"' + CRLF + CRLF;
             request += file.name + CRLF;

             request += "--" + boundary + CRLF;

             request += 'Content-Disposition: form-data; ';
             request += 'name="' + 'photo[photo]' + '"; ';
             request += 'filename="'+ file.fileName + '"' + CRLF;

             request += "Content-Type: application/octet-stream" + CRLF + CRLF;
             request += file.value + CRLF;
             request+= "--" + boundary + "--" + CRLF;

             xhr.sendAsBinary(request);
         });
         // finally send the request as binary data
         //xhr.sendAsBinary(this.buildMessage(this.filesToUpload, boundary));
     } catch(e) {
         alert('send Error: ' + e);
     }
 }

现在,回形针可以正常处理文件 input file



 类似资料:
  • 以下是events_controller.rb的代码 为了调试,我尝试将行更改为event.create(params[]),此时错误从参数数错误(1表示0)变为参数数错误(0表示1)。 以下是event.rb的代码

  • 我正在尝试将图像上传到回形针并将其保存到s3。但是,我在控制台中收到以下错误 StackOverflow上有一些关于如何解决此问题的回复,尽管大多数人指出原始解决方案是对Rack的更新。但是,我使用的是Ruby 1.9.3和Rails 3.1.3,并且相信我没有Rack(我没有将其安装为Gem,是吗??)。 我一直在尝试的文件名相当简单,所以我假设问题出在实际的文件中,但是我不确定如何调试错误来自

  • 指针变量也是变量,是变量就可以任意赋值,不要越界即可(32位编译器指针大小为4字节,64位编译器指针大小为8字节),但是,任意数值赋值给指针变量没有意义,因为这样的指针就成了野指针,此指针指向的区域是未知(操作系统不允许操作此指针指向的内存区域)。所以,野指针不会直接引发错误,操作野指针指向的内存区域才会出问题。 int a = 100; int *p; p = a; //把a的值赋值给指针变量p

  • 问题内容: 在客户端,用户使用RecordRTC录制短视频。当用户按下上载时,我将使用来获取视频的数据,并将其上载到我的服务器(使用Rails和回形针处理文件上载)。 首先,我想将字段值更改为数据。事实证明,为了确保浏览器的安全性,我无法使用javascript对其进行更改。 然后,我尝试使用AJAX: 但是,它不起作用。 在档案上,我将得到以下内容,无法处理: 如果我正常使用提交,则参数将如下所

  • 问题内容: 在Go中,有多种方法可以返回值或其片段。对于个人,我已经看到: 我了解两者之间的区别。第一个返回该结构的副本,第二个返回指向在函数内创建的结构值的指针,第三个期望传入现有结构并覆盖该值。 我已经看到所有这些模式都可以在各种情况下使用,我想知道关于这些的最佳实践是什么。什么时候使用?例如,第一个可能适用于小型结构(因为开销很小),第二个适用于较大的结构。第三,如果您想提高存储效率,因为您

  • 在Go中,有多种方法可以返回< code>struct值或其片段。对于我见过的个别例子: 我理解它们之间的区别。第一个返回结构的副本,第二个是指向在函数中创建的结构值的指针,第三个期望传入现有结构并覆盖该值。 我看到所有这些模式都在不同的环境中使用,我想知道关于这些模式的最佳实践是什么。你什么时候用?例如,第一个可以用于小结构(因为开销最小),第二个可以用于大结构。第三,如果你想非常节省内存,因为