打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
django与百度ueditor 集成之二:涂鸦,抓图,搜视频,图片浏览
上一篇文章提到django与百度ueditor 结合实现文件上传,图片上传。但还有如下功能没实现:
1. 在线涂鸦后,图片的保存,并显示
2. 图片的在线管理,浏览(目录递归浏览)
3. 在线视频搜索
4. 远程抓图
在看测试代码之前,请注意在django程序的settings.py 中配置:
程序代码
MEDIA_ROOT = os.path.join(os.path.dirname(__file__),'static/upload/').replace('\\','/'),
这是我的配置,你可以改成适合你的配置。
今天又抽了一个小时,参考了下java 的代码,将上面的四个功能也实现,有需要的朋友可以参考. 同样在前面文章的基础上,在views.py 里面添加代码:
在线涂鸦
程序代码
@csrf_exempt
def ueditor_ScrawUp(request):
""" 涂鸦文件,处理 """
print request
param = request.POST.get("action",'')
fileType = [".gif" , ".png" , ".jpg" , ".jpeg" , ".bmp"];
if  param=='tmpImg':
fileObj = request.FILES.get('upfile', None)
source_pictitle = request.POST.get('pictitle','')
source_filename = request.POST.get('fileName','')
response = HttpResponse()
myresponse = __myuploadfile(fileObj, source_pictitle, source_filename,'pic')
myresponsedict=dict(myresponse)
url=myresponsedict.get('url','')
response.write("<script>parent.ue_callback('%s','%s')</script>" %(url,'SUCCESS'))
return response
else:
#========================base64上传的文件=======================
base64Data = request.POST.get('content','')
subfolder = time.strftime("%Y%m")
if not os.path.exists(settings.MEDIA_ROOT[0] + subfolder):
os.makedirs(settings.MEDIA_ROOT[0] + subfolder)
file_name = str(uuid.uuid1())
path = str(subfolder + '/' + file_name + '.' + 'png')
phisypath = settings.MEDIA_ROOT[0] + path
f=open(phisypath,'wb+')
f.write(base64.decodestring(base64Data))
f.close()
response=HttpResponse()
response.write("{'url':'%s',state:'%s'}" % ('/static/upload/' + subfolder + '/' + file_name + '.' + 'png','SUCCESS'));
return response
图片的在线管理,浏览(目录递归浏览)
程序代码
def listdir(path,filelist):
""" 递归 得到所有图片文件信息 """
phisypath = settings.MEDIA_ROOT[0]
if os.path.isfile(path):
return '[]'
allFiles=os.listdir(path)
retlist=[]
for cfile in allFiles:
fileinfo={}
filepath=(path+os.path.sep+cfile).replace("\\","/").replace('//','/')
if os.path.isdir(filepath):
listdir(filepath,filelist)
else:
if cfile.endswith('.gif') or cfile.endswith('.png') or cfile.endswith('.jpg') or cfile.endswith('.bmp'):
filelist.append(filepath.replace(phisypath,'/static/upload/').replace("//","/"))
@csrf_exempt
def ueditor_imageManager(request):
""" 图片在线管理  """
filelist=[]
phisypath = settings.MEDIA_ROOT[0]
listdir(phisypath,filelist)
imgStr="ue_separate_ue".join(filelist)
response=HttpResponse()
response.write(imgStr)
return response
在线视频搜索
程序代码
@csrf_exempt
def ueditor_getMovie(request):
""" 获取视频数据的地址 """
content ="";
searchkey = request.POST.get("searchKey");
videotype = request.POST.get("videoType");
try:
url = "http://api.tudou.com/v3/gw?method=item.search&appKey=myKey&format=json&kw="+ searchkey+"&pageNo=1&pageSize=20&channelId="+videotype+"&inDays=7&media=v&sort=s";
content=urllib2.urlopen(url).read()
except Exception,e:
pass
response=HttpResponse()
response.write(content);
return response
远程抓图,将别人网站的图片保存到本地,并显示出来
程序代码
@csrf_exempt
def ueditor_getRemoteImage(request):
print request
""" 把远程的图抓到本地,爬图 """
file_name = str(uuid.uuid1())
subfolder = time.strftime("%Y%m")
if not os.path.exists(settings.MEDIA_ROOT[0] + subfolder):
os.makedirs(settings.MEDIA_ROOT[0] + subfolder)
#====get request params=================================
urls = str(request.POST.get("upfile"));
urllist=urls.split("ue_separate_ue")
outlist=[]
#====request params end=================================
fileType = [".gif" , ".png" , ".jpg" , ".jpeg" , ".bmp"];
for url in urllist:
fileExt=""
for suffix in fileType:
if url.endswith(suffix):
fileExt=suffix
break;
if fileExt=='':
continue
else:
path = str(subfolder + '/' + file_name + '.' + fileExt)
phisypath = settings.MEDIA_ROOT[0] + path
piccontent= urllib2.urlopen(url).read()
picfile=open(phisypath,'wb')
picfile.write(piccontent)
picfile.close()
outlist.append('/static/upload/' + subfolder + '/' + file_name + '.' + fileExt)
outlist="ue_separate_ue".join(outlist)
response=HttpResponse()
myresponse="{'url':'%s','tip':'%s','srcUrl':'%s'}" % (outlist,'成功',urls)
response.write(myresponse);
return response
更新 urls.py
程序代码
url(r'^ueditor_imgup$','MyNet.app.Ueditor.views.ueditor_ImgUp'),
url(r'^ueditor_fileup$','MyNet.app.Ueditor.views.ueditor_FileUp'),
url(r'^ueditor_getRemoteImage$','MyNet.app.Ueditor.views.ueditor_getRemoteImage'),
url(r'^ueditor_scrawlUp$','MyNet.app.Ueditor.views.ueditor_ScrawUp'),
url(r'^ueditor_getMovie$','MyNet.app.Ueditor.views.ueditor_getMovie'),
url(r'^ueditor_imageManager$','MyNet.app.Ueditor.views.ueditor_imageManager'),
更改ueditor config 配置文件
程序代码
,imageUrl:"/ueditor_imgup"
,imagePath:""
//涂鸦图片配置区
,scrawlUrl:"/ueditor_scrawlUp"
,scrawlPath:""
//附件上传配置区
,fileUrl:"/ueditor_fileup"
,filePath:""
//远程抓取配置区
,catcherUrl:"/ueditor_getRemoteImage"
,catcherPath:""
//图片在线管理配置区
,imageManagerUrl:"/ueditor_imageManager"
,imageManagerPath:""
//屏幕截图配置区
,snapscreenHost: '127.0.0.1'
,snapscreenServerUrl: "/ueditor_imgup"
,snapscreenPath: ""
//word转存配置区
,wordImageUrl:"/ueditor_imgup"
,wordImagePath:""
//获取视频数据的地址
,getMovieUrl:"/ueditor_getMovie"
到此为止,这两篇文章将所有需要集成的都集成了。
源码下载: django ueditor集成源码
除非申明,文章均为一号门原创,转载请注明本文地址,谢谢!
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
Scrapy分布式爬虫可视化调度框架Gerapy升级django版本自用
教你快速删除电脑久存的无用文件夹 为电脑腾出空间
Django中实现文件上传功能
Django REST Framework教程(7): 如何使用JWT认证(神文多图)
使用Python Django搭建个人博客系统(完整过程)!
django模板中引用js css
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服