2010-06-29 3 views
3

) 다음 코드를 사용하여 Flex (PNG 이미지)에서 Ruby on Rails 서버 백엔드로 동적으로 생성 된 파일을 업로드하려고합니다 (Flex on Rails book) :플렉스에서 레일스로 파일 업로드시 예외 (

 public function save():void 
     { 

      var bitmapData:BitmapData = new BitmapData(width, height); 
      bitmapData.draw(this); 

      var ba:ByteArray = (new PNGEncoder()).encode(bitmapData); 
      var fileRef:FileReference = new FileReference(); 

      //TODO: Remove HardCoding of URL here 
      var request : URLRequest = new URLRequest("http://localhost:3000/doodles"); 
      request.method = URLRequestMethod.POST; 
      var boundary : String = "----------Ij5GI3GI3ei4GI3ei4KM7GI3KM7KM7"; 
      request.contentType = "multipart/form-data; boundary=" + boundary; 
      request.data =getMultiPartRequestData(boundary,'doodle','',ba); 

      loader.load(request);    
     } 

및 getMultiPartRequestData 기능은 다음과 같습니다

 private function getMultiPartRequestData(boundary:String, 
               resourceName:String, 
               filename:String, 
               bytes:ByteArray):ByteArray { 
      Alert.show("haha"); 
      var lf:String = "\r\n"; 

      var part1:String = '--' + boundary + lf + 
       'Content-Disposition: form-data; name="Filename"' + lf + lf + 
       '{0}' + lf + 
       '--' + boundary + lf ; 
      if (_model.authenticityToken != "") { 
       part1 += 'Content-Disposition: form-data; name="authenticity_token";' + lf + lf + 
        '{2}' + lf + 
        '--' + boundary + lf ;      
      } 
      part1 += 'Content-Disposition: form-data; name="{1}[x]";' + lf + lf + 
        '{3}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[y]";' + lf + lf + 
        '{4}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[width]";' + lf + lf + 
        '{5}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[height]"' + lf + lf + 
        '{6}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[rotation]"' + lf + lf + 
        '{7}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[day_id]"' + lf + lf + 
        '{8}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[privacy]"' + lf + lf + 
        '{9}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[canvas_height]"' + lf + lf + 
        '{10}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="{1}[canvas_width]"' + lf + lf + 
        '{11}' + lf + 
        '--' + boundary + lf + 
        'Content-Disposition: form-data; name="commit"' + lf + lf + 
        'Create' + lf + 
        '--' + boundary + lf +      
        'Content-Disposition: form-data; name="{1}[photo]";' + 
        'filename="{0}"' + lf +       
        'Content-Type: application/octet-stream' + lf + lf  

      var part2:String = '--' + boundary + lf + 
           'Content-Disposition: form-data; name="Upload"' + lf + lf + 
           'Submit Query' + lf + 
           '--' + boundary + '--' 

      var result:ByteArray = new ByteArray(); 
      // Filling in the parameters as per comment above 
      result.writeMultiByte(StringUtil.substitute(part1, 
                 filename, 
                 resourceName, 
                 _model.authenticityToken, 
                 _model.boundMinX, 
                 _model.boundMinY, 
                 Constants.DEFAULT_DOODLE_WIDTH, 
                 Constants.MINIMUM_CANVAS_HEIGHT, 
                 0, 
                 _model.current_day.id, 
                 privacyGroup.selectedValue.toString(), 
                 FlexGlobals.topLevelApplication.height, 
                 FlexGlobals.topLevelApplication.width), "ascii"); 
      result.writeBytes(bytes,0,bytes.length); 
      result.writeMultiByte(part2, "ascii"); 
      return result; 
     } 

나는 다음과 같은 예외가 얻을 :

TypeError (can't convert nil into String): 
    vendor/plugins/paperclip/lib/paperclip/iostream.rb:8:in `extname' 
    vendor/plugins/paperclip/lib/paperclip/iostream.rb:8:in `to_tempfile' 
    vendor/plugins/paperclip/lib/paperclip/attachment.rb:89:in `assign' 
    vendor/plugins/paperclip/lib/paperclip.rb:262:in `block in has_attached_file' 
    activerecord (2.3.5) lib/active_record/base.rb:2746:in `block in attributes=' 
    activerecord (2.3.5) lib/active_record/base.rb:2742:in `each' 
    activerecord (2.3.5) lib/active_record/base.rb:2742:in `attributes=' 
    activerecord (2.3.5) lib/active_record/base.rb:2438:in `initialize' 
    app/controllers/doodles_controller.rb:16:in `new' 
    app/controllers/doodles_controller.rb:16:in `create' 
    actionpack (2.3.5) lib/action_controller/base.rb:1331:in `perform_action' 
    actionpack (2.3.5) lib/action_controller/filters.rb:617:in `call_filters' 
    actionpack (2.3.5) lib/action_controller/filters.rb:610:in `perform_action_with_filters' 
    actionpack (2.3.5) lib/action_controller/benchmarking.rb:68:in `block in perform_action_with_benchmark' 
    activesupport (2.3.5) lib/active_support/core_ext/benchmark.rb:17:in `block in ms' 
    /Users/tammam56/.rvm/rubies/ruby-1.9.1-p378/lib/ruby/1.9.1/benchmark.rb:309:in `realtime' 
    activesupport (2.3.5) lib/active_support/core_ext/benchmark.rb:17:in `ms' 
    actionpack (2.3.5) lib/action_controller/benchmarking.rb:68:in `perform_action_with_benchmark' 
    actionpack (2.3.5) lib/action_controller/rescue.rb:160:in `perform_action_with_rescue' 
    actionpack (2.3.5) lib/action_controller/flash.rb:146:in `perform_action_with_flash' 
    vendor/plugins/newrelic_rpm/lib/new_relic/agent/instrumentation/controller_instrumentation.rb:253:in `block in perform_action_with_newrelic_trace' 
    vendor/plugins/newrelic_rpm/lib/new_relic/agent/method_tracer.rb:141:in `trace_execution_scoped' 
    vendor/plugins/newrelic_rpm/lib/new_relic/agent/instrumentation/controller_instrumentation.rb:246:in `perform_action_with_newrelic_trace' 
    actionpack (2.3.5) lib/action_controller/base.rb:532:in `process' 
    actionpack (2.3.5) lib/action_controller/filters.rb:606:in `process_with_filters' 
    actionpack (2.3.5) lib/action_controller/base.rb:391:in `process' 
    actionpack (2.3.5) lib/action_controller/base.rb:386:in `call' 
    actionpack (2.3.5) lib/action_controller/routing/route_set.rb:437:in `call' 
    actionpack (2.3.5) lib/action_controller/dispatcher.rb:87:in `dispatch' 
    actionpack (2.3.5) lib/action_controller/dispatcher.rb:121:in `_call' 
    actionpack (2.3.5) lib/action_controller/dispatcher.rb:130:in `block in build_middleware_stack' 
    activerecord (2.3.5) lib/active_record/query_cache.rb:29:in `call' 
    activerecord (2.3.5) lib/active_record/query_cache.rb:29:in `block in call' 
    activerecord (2.3.5) lib/active_record/connection_adapters/abstract/query_cache.rb:34:in `cache' 
    activerecord (2.3.5) lib/active_record/query_cache.rb:9:in `cache' 
    activerecord (2.3.5) lib/active_record/query_cache.rb:28:in `call' 
    activerecord (2.3.5) lib/active_record/connection_adapters/abstract/connection_pool.rb:361:in `call' 
    actionpack (2.3.5) lib/action_controller/string_coercion.rb:25:in `call' 
    rack (1.0.1) lib/rack/head.rb:9:in `call' 
    rack (1.0.1) lib/rack/methodoverride.rb:24:in `call' 
    actionpack (2.3.5) lib/action_controller/params_parser.rb:15:in `call' 
    actionpack (2.3.5) lib/action_controller/session/cookie_store.rb:93:in `call' 
    actionpack (2.3.5) lib/action_controller/failsafe.rb:26:in `call' 
    rack (1.0.1) lib/rack/lock.rb:11:in `block in call' 
    <internal:prelude>:8:in `synchronize' 
    rack (1.0.1) lib/rack/lock.rb:11:in `call' 
    actionpack (2.3.5) lib/action_controller/dispatcher.rb:114:in `block in call' 
    actionpack (2.3.5) lib/action_controller/reloader.rb:34:in `run' 
    actionpack (2.3.5) lib/action_controller/dispatcher.rb:108:in `call' 
    rails (2.3.5) lib/rails/rack/static.rb:31:in `call' 
    rack (1.0.1) lib/rack/urlmap.rb:46:in `block in call' 
    rack (1.0.1) lib/rack/urlmap.rb:40:in `each' 
    rack (1.0.1) lib/rack/urlmap.rb:40:in `call' 
    rails (2.3.5) lib/rails/rack/log_tailer.rb:17:in `call' 
    rack (1.0.1) lib/rack/content_length.rb:13:in `call' 
    rack (1.0.1) lib/rack/chunked.rb:15:in `call' 
    rack (1.0.1) lib/rack/handler/mongrel.rb:64:in `process' 
    mongrel (1.1.5) lib/mongrel.rb:159:in `block in process_client' 
    mongrel (1.1.5) lib/mongrel.rb:158:in `each' 
    mongrel (1.1.5) lib/mongrel.rb:158:in `process_client' 
    mongrel (1.1.5) lib/mongrel.rb:285:in `block (2 levels) in run' 
,536,913을 내가 요청 데이터로 볼 때 63,210

나는 다음과 같은 얻을 :

(I 대신 플렉스의 HTML 페이지를 사용하는 경우) HTML 요청 데이터와 매우 유사하다
Processing DoodlesController#create (for 127.0.0.1 at 2010-06-28 22:51:57) [POST] 
    Parameters: {"Filename"=>"doodle.png", "authenticity_token"=>"4UoCgzNbH1UccJbqV4P+R1mCuLk54fWTXxkZvVBin+I=", "doodle"=>{"x"=>"0", "y"=>"100", "width"=>"1024", "height"=>"768", "rotation"=>"0", "day_id"=>"16", "privacy"=>"meonly", "canvas_height"=>"1298", "canvas_width"=>"2560", "photo"=>#<File:/var/folders/RH/RHekFGKME9uDJbX4d4DG3E+++TI/-Tmp-/RackMultipart20100628-1685-1v2epqd-0>}, "commit"=>"Create"} 

:

Processing DoodlesController#create (for 127.0.0.1 at 2010-06-28 21:55:23) [POST] 
    Parameters: {"authenticity_token"=>"4UoCgzNbH1UccJbqV4P+R1mCuLk54fWTXxkZvVBin+I=", "doodle"=>{"privacy"=>"myonly", "day_id"=>"1", "x"=>"10", "y"=>"10", "width"=>"1000", "height"=>"1000", "rotation"=>"0", "canvas_height"=>"1000", "canvas_width"=>"1000", "photo"=>#<File:/var/folders/RH/RHekFGKME9uDJbX4d4DG3E+++TI/-Tmp-/RackMultipart20100628-1685-1gnfm5q-0>}, "commit"=>"Create"} 

작품 !

내가 (맥에서)를 입력하면

open /var/folders/RH/RHekFGKME9uDJbX4d4DG3E+++TI/-Tmp-/RackMultipart20100628-1685-1v2epqd-0 

는 (임시 파일)이 의도 된 PNG 파일을 엽니 다!

어떻게 작동시킬 수 있습니까?

+0

답변을 모르겠지만 flex에서 이진 문자열을 게시하고 RoR 측의 파일에 쓰려고 했습니까? – Amarghosh

+0

고마워요 @Amarghosh 어떻게 그렇게 제안합니까? – Tam

+0

원시 BitmapData 또는 ByteArray로 인코딩 된 png를 문자열로 변환하고 urlloader를 사용하여 전송합니다. 비트 맵 데이터를 보내는 경우 서버 측에서 png 인코더를 사용해야합니다. 데이터의 길이가 http 게시가 허용하는 것보다 클 수도 있습니다. – Amarghosh

답변

1

꽤 오랫동안 머리카락을 당긴 후. 나는 그 문제가 매우 어리 석다는 것을 깨달았다!

나는 역 추적 오류라는되어 오른쪽 종이 클립 pluging (내부 디버그 코드를 삽입 :

vendor/plugins/paperclip/lib/paperclip/iostream.rb:8:in `extname' 

나는 약간의 디버그 변수 I를 인쇄 한 후이

name = respond_to?(:original_filename) ? original_filename : (respond_to?(:path) ? path : "stream") 

같은 라인을 발견 original_filename이 nil이라는 것을 깨달았습니다. 실제 파일 이름이 내 코드에 따라 doodle.png로되어있는 서버에 업로드되어야합니다. 단지 'filename'앞에 하나의 공백을 잊어 버렸습니다. 데이터를 보내고 있습니다. 그래서 내 코드 :

'Content-Disposition: form-data; name="{1}[photo]";' + 
        'filename="{0}"' + lf +       
        'Content-Type: application/octet-stream' + lf + lf 

이 잘못되었습니다. 이 코드 :

'Content-Disposition: form-data; name="{1}[photo]"; ' + //note extra space added here 
        'filename="{0}"' + lf +       
        'Content-Type: application/octet-stream' + lf + lf 

작동. 그게 다야!

+0

공간을 틀린 곳에두면 ... 따옴표보다 세미콜론 뒤에 있어야한다. :) – unsorted

+0

어쨌든, 나는 그것이 당신의 잘못이라고 생각하지 않습니다. 나는 github에서 그 남자의 repo를 복제하고 동일한 문제가있었습니다. – unsorted

+0

Sever 사이드 코드를 보내 주시겠습니까?또는 작업 클라이언트 측/서버 측 코드를 github으로 푸시 할 수 있습니까? 너는 우리에게 큰 은혜를 줄 것이다! – simo

관련 문제