Django实现图片文字同时提交的方法


Posted in Python onMay 26, 2015

本文实例讲述了Django实现图片文字同时提交的方法。分享给大家供大家参考。具体分析如下:

jQuery为我们网站开发解决了很多问题,使我们的网站用户体验大大的提高了。举个简单的例子,我们用AJAX技术来实现对表单的异步提交,使用户在体验上有了很大的改观,用户在提交数据的同时还可以干一些其他的事情。

不过,今天在开发中遇到一个特别头痛的问题,刚开始不知道,以为可以实现,纠结了将近4个小时之久,但结果很是令人失望。

问题是这样的:为了提高用户体验,我决定使用AJAX异步提交,于是我用jQuery的$.post去异步提交表单数据,文本信息可以很轻松的提交,但是,却怎么也无法提交图片数据。怎么办呢?

在网上查了很多资料,后来发现jQuery不支持图片上传(附件上传),但是有相关的插件,于是我开始慢慢琢磨,开始用另一个专门上传文件的插件jquery.ajaxfileupload.js,折腾了很久,总可以上传图片了。但是新的问题有产生了。

通过ajaxfileupload来异步上传图片的同时,却不能提交文本数据。?灏 ??

在网上查了很多资料,折腾了许久,没有Django开发的相关资料,怎么办?自己想办法…….

后来找到了解决方案,跟大家分享一下:

思路:

由于使用jquery.ajaxfileupload.js插件不能传递自定义的参数,肿么办?自己改写插件呗。碰巧,网上有别人改过的现成代码,二话不说,先拿来试试。以下即是我试验的过程。

1. 前台页面(部分代码):

<table border="0" width="100%"> 
  <form action="." method="post" id="annex_form_2"></form> 
  <tbody> 
  <tr> 
    <td class="col_name" nowrap="nowrap" width="26%">证书名称:</td>
    <td width="64%"><input size="65" class="input_general" id="prove_name_2" maxlength="50" name="prove_name" 
                type="text"></td> 
    <td nowrap="nowrap" width="7%"></td> 
    <td nowrap="nowrap" width="3%"><a href="javascript:void(0);" onclick="SubmitAnnexInfo(2)" title="保存"><img 
        src="/static/img/hr_manage/btn_save.gif" alt="点此保存"></a></td> 
  </tr> 
  <tr> 
    <td class="col_name">证件类型:</td> 
    <td><select id="prove_type_2" name="prove_type"> 
      <option selected="selected" value="1">身份证</option> 
      <option value="2">学位证</option> 
      <option value="3">其他证</option> 
    </select></td> 
    <td> </td> 
    <td> </td> 
  </tr> 
  <tr> 
    <td class="col_name">证书描述:</td> 
    <td><input size="80" class="input_general" id="prove_desc_2" maxlength="60" name="prove_desc" type="text"></td> 
    <td> </td> 
    <td> </td> 
  </tr> 
  <tr> 
    <td class="col_name">附件地址:</td> 
    <td><input size="45" class="input_general" id="prove_url_2" maxlength="45" name="prove_url" style="border:0px;" 
          type="file"></td> 
    <td> </td> 
    <td> </td> 
  </tr> 
  <tr> 
    <td colspan="4"> 
      <hr> 
    </td> 
  </tr> 
  </tbody> 
</table>

2. 更改后的jquery.ajaxfileupload.js:

jQuery.extend({ 
  createUploadIframe: function(id, uri) 
   { 
        //create frame 
      var frameId = 'jUploadFrame' + id; 
      if(window.ActiveXObject) { 
        var io = document.createElement('<iframe id="' + frameId + '" name="' + frameId + '" />'); 
        if(typeof uri== 'boolean'){ 
          io.src = 'javascript:false'; 
        } 
        else if(typeof uri== 'string'){ 
          io.src = uri; 
        } 
      } 
      else { 
        var io = document.createElement('iframe'); 
        io.id = frameId; 
        io.name = frameId; 
      } 
      io.style.position = 'absolute'; 
      io.style.top = '-1000px'; 
      io.style.left = '-1000px'; 
      document.body.appendChild(io); 
      return io        
  }, 
  createUploadForm: function(id, fileElementId, data) 
   { 
     //create form   
     var formId = 'jUploadForm' + id; 
     var fileId = 'jUploadFile' + id; 
     var form = $('<form action="" method="POST" name="' + formId + '" id="' + formId + '" enctype="multipart/form-data"></form>');   
     var oldElement = $('#' + fileElementId); 
     var newElement = $(oldElement).clone(); 
     $(oldElement).attr('id', fileId); 
     $(oldElement).before(newElement); 
     $(oldElement).appendTo(form); 
     //增加文本参数的支持 
     if (data) { 
        for (var i in data) { 
          $('<input type="hidden" name="' + i + '" value="' + data[i] + '" />').appendTo(form); 
        } 
     } 
     //set attributes 
     $(form).css('position', 'absolute'); 
     $(form).css('top', '-1200px'); 
     $(form).css('left', '-1200px'); 
     $(form).appendTo('body');      
     return form; 
  }, 
  ajaxFileUpload: function(s) { 
    // TODO introduce global settings, allowing the client to modify them for all requests, not only timeout      
    s = jQuery.extend({}, jQuery.ajaxSettings, s); 
    var id = new Date().getTime()     
     var form = jQuery.createUploadForm(id, s.fileElementId, s.data); 
     var io = jQuery.createUploadIframe(id, s.secureuri); 
     var frameId = 'jUploadFrame' + id; 
     var formId = 'jUploadForm' + id;      
    // Watch for a new set of requests 
    if ( s.global && ! jQuery.active++ ) 
     { 
        jQuery.event.trigger( "ajaxStart" ); 
     }       
    var requestDone = false; 
    // Create the request object 
    var xml = {}  
    if ( s.global ) 
      jQuery.event.trigger("ajaxSend", [xml, s]); 
    // Wait for a response to come back 
    var uploadCallback = function(isTimeout) 
     {        
        var io = document.getElementById(frameId); 
      try 
        {           
          if(io.contentWindow) 
          { 
             xml.responseText = io.contentWindow.document.body?io.contentWindow.document.body.innerHTML:null; 
           xml.responseXML = io.contentWindow.document.XMLDocument?io.contentWindow.document.XMLDocument:io.contentWindow.document;
          }else if(io.contentDocument) 
          { 
             xml.responseText = io.contentDocument.document.body?io.contentDocument.document.body.innerHTML:null; 
           xml.responseXML = io.contentDocument.document.XMLDocument?io.contentDocument.document.XMLDocument:io.contentDocument.document; 
          }                
      }catch(e) 
        { 
          jQuery.handleError(s, xml, null, e); 
        } 
      if ( xml || isTimeout == "timeout") 
        {           
        requestDone = true; 
        var status; 
        try { 
          status = isTimeout != "timeout" ? "success" : "error"; 
          // Make sure that the request was successful or notmodified 
          if ( status != "error" ) 
             { 
            // process the data (runs the xml through httpData regardless of callback) 
            var data = jQuery.uploadHttpData( xml, s.dataType );   
            // If a local callback was specified, fire it and pass it the data 
            if ( s.success ) 
              s.success( data, status ); 
            // Fire the global callback 
            if( s.global ) 
              jQuery.event.trigger( "ajaxSuccess", [xml, s] ); 
          } else 
            jQuery.handleError(s, xml, status); 
        } catch(e) 
          { 
          status = "error"; 
          jQuery.handleError(s, xml, status, e); 
        } 
        // The request was completed 
        if( s.global ) 
          jQuery.event.trigger( "ajaxComplete", [xml, s] ); 
        // Handle the global AJAX counter 
        if ( s.global && ! --jQuery.active ) 
          jQuery.event.trigger( "ajaxStop" ); 
        // Process result 
        if ( s.complete ) 
          s.complete(xml, status); 
        jQuery(io).unbind() 
        setTimeout(function() 
          {   try 
            { 
              $(io).remove(); 
              $(form).remove();   
            } catch(e) 
            { 
              jQuery.handleError(s, xml, null, e); 
            }                       
          }, 100) 
        xml = null 
      } 
    } 
    // Timeout checker 
    if ( s.timeout > 0 ) 
     { 
      setTimeout(function(){ 
        // Check to see if the request is still happening 
        if( !requestDone ) uploadCallback( "timeout" ); 
      }, s.timeout); 
    } 
    try 
     { 
      // var io = $('#' + frameId); 
        var form = $('#' + formId); 
        $(form).attr('action', s.url); 
        $(form).attr('method', 'POST'); 
        $(form).attr('target', frameId); 
      if(form.encoding) 
        { 
        form.encoding = 'multipart/form-data';
      } 
      else 
        {           
        form.enctype = 'multipart/form-data'; 
      }        
      $(form).submit(); 
    } catch(e) 
     {        
      jQuery.handleError(s, xml, null, e); 
    } 
    if(window.attachEvent){ 
      document.getElementById(frameId).attachEvent('onload', uploadCallback); 
    } 
    else{ 
      document.getElementById(frameId).addEventListener('load', uploadCallback, false); 
    }      
    return {abort: function () {}};   
  }, 
  uploadHttpData: function( r, type ) { 
    var data = !type; 
    data = type == "xml" || data ? r.responseXML : r.responseText; 
    // If the type is "script", eval it in global context 
    if ( type == "script" ) 
      jQuery.globalEval( data ); 
    // Get the JavaScript object, if JSON is used. 
    if ( type == "json" ) 
      eval( "data = " + data ); 
    // evaluate scripts within html 
    if ( type == "html" ) 
      jQuery("<div>").html(data).evalScripts(); 
        //alert($('param', data).each(function(){alert($(this).attr('value'));})); 
    return data; 
  } 
})

3. 调用方法

//保存附件信息 
function SaveAnnexInfo() { 
  var prove_name = $("#id_prove_name").val(); //从界面得到值 
  var prove_type = $("#id_prove_type").val(); 
  var prove_desc = $("#id_prove_desc").val(); 
  $.ajaxFileUpload({  
    url: "/test/annex_info /",   //请求的Url地址 
    secureuri:false,  
    fileElementId:'id_prove_url',  
    dataType: 'json',  
    data: {   //加入的文本参数  
      "prove_name":prove_name, 
      "prove_type":prove_type,  
      "prove_desc":prove_desc 
    },  
    success: function(data) {  
      asyncbox.tips('操作成功!', 'success');          
    },  
    error: function() {  
      asyncbox.tips("上传失败,请检查文件是否符合格式要求。");  
     }  
  });  
}

4. Python后台处理(代码片段)

if annex_form.is_valid(): 
     annex_info = annex_form.save(commit=False) 
     #获取上传 
     annex_url = request.FILES.get('prove_url','') #取附件 
     annex_info.entry = entry_info 
     annex_info.prove_url = annex_url 
     annex_info.save() 
     return HttpResponse(1) #操作成功 
return HttpResponse(0) #操作失败

希望本文所述对大家的Python程序设计有所帮助。

Python 相关文章推荐
Python脚本实现12306火车票查询系统
Sep 30 Python
python fabric实现远程部署
Jan 05 Python
python 寻找优化使成本函数最小的最优解的方法
Dec 28 Python
Python Numpy 数组的初始化和基本操作
Mar 13 Python
python logging重复记录日志问题的解决方法
Jul 12 Python
解析PyCharm Python运行权限问题
Jan 08 Python
pytorch使用 to 进行类型转换方式
Jan 08 Python
Django更新models数据库结构步骤
Apr 01 Python
Python函数的迭代器与生成器的示例代码
Jun 18 Python
Python unittest如何生成HTMLTestRunner模块
Sep 08 Python
Python爬取酷狗MP3音频的步骤
Feb 26 Python
解决pytorch 保存模型遇到的问题
Mar 03 Python
Python实现的简单算术游戏实例
May 26 #Python
Django中使用group_by的方法
May 26 #Python
python3序列化与反序列化用法实例
May 26 #Python
python实现用于测试网站访问速率的方法
May 26 #Python
Python函数可变参数定义及其参数传递方式实例详解
May 25 #Python
Python易忽视知识点小结
May 25 #Python
Python中类型关系和继承关系实例详解
May 25 #Python
You might like
PHP格式化MYSQL返回float类型的方法
2016/03/30 PHP
微信随机生成红包金额算法php版
2016/07/21 PHP
利用 fsockopen() 函数开放端口扫描器的实例
2017/08/19 PHP
PHP大文件分块上传功能实例详解
2019/07/22 PHP
javascript获取ckeditor编辑器的值(实现代码)
2013/11/18 Javascript
使用upstart把nodejs应用封装为系统服务实例
2014/06/01 NodeJs
jQuery搜索子元素的方法
2015/02/10 Javascript
使用RequireJS优化JavaScript引用代码的方法
2015/07/01 Javascript
jquery实现触发时更新下拉列表内容的方法
2015/12/02 Javascript
js倒计时抢购实例
2015/12/20 Javascript
javascript基础语法学习笔记
2016/01/04 Javascript
jQuery插件 Jqplot图表实例
2016/06/18 Javascript
对Angular.js Controller如何进行单元测试
2016/10/25 Javascript
详解Angular 4.x NgTemplateOutlet
2017/05/24 Javascript
angularjs定时任务的设置与清除示例
2017/06/02 Javascript
JavaScript实现身份证验证代码实例
2019/08/26 Javascript
element-ui中按需引入的实现
2019/12/25 Javascript
原生js实现日历效果
2020/03/02 Javascript
JS 创建对象的模式实例小结
2020/04/28 Javascript
[54:47]Liquid vs VP Supermajor决赛 BO 第五场 6.10
2018/07/05 DOTA
python实现基于SVM手写数字识别功能
2020/05/27 Python
python爬虫模拟浏览器访问-User-Agent过程解析
2019/12/28 Python
使用pth文件添加Python环境变量方式
2020/05/26 Python
美国CVS药店官网:CVS Pharmacy
2018/07/26 全球购物
全球最大的瓷器、水晶和银器零售商:Replacements
2020/06/15 全球购物
Python面试题集
2012/03/08 面试题
户外婚礼策划方案
2014/02/08 职场文书
委托公证书范本
2014/04/03 职场文书
2014年妇幼卫生工作总结
2014/12/09 职场文书
工作能力自我评价2015
2015/03/05 职场文书
涨价通知
2015/04/23 职场文书
Redis Cluster集群动态扩容的实现
2021/07/15 Redis
Python 多线程处理任务实例
2021/11/07 Python
Golang解析JSON对象
2022/04/30 Golang
python和anaconda的区别
2022/05/06 Python
如何使用注解方式实现 Redis 分布式锁
2022/07/23 Redis