def handle_zip(origin_name, user_id)
if self.image_url=~ /\.zip$/i
begin
folder = origin_name.gsub('.zip', '') if origin_name.present?
dirname = "#{Rails.root}/public/upload_files/a03/html5/#{self.id}"
userid_name = "#{Rails.root}/public/upload_files/temp_zip/#{user_id}"
replaced_url = "http://a03.optimix.asia/html5/#{self.id}"
FileUtils.mkdir_p(dirname) unless File.directory?(dirname)
%x(rm -rf #{dirname}/*)
%x(cp -r #{userid_name}/* #{dirname})
%x(chown xmo:xmo -R #{dirname}) if Rails.env.production?
unless File.exist?("#{userid_name}/index.html")
folder = Dir.entries("#{userid_name}").select{|dir| ![".",".."].include?(dir)}.last.to_s
File.rename("#{dirname}/#{folder}","#{dirname}/html5_assets")
folder = "html5_assets"
end
%x(rm -rf #{userid_name})
read_list_path = File.directory?("#{dirname}/#{folder}") ? "#{dirname}/#{folder}" : dirname
replaced_url = File.directory?("#{dirname}/#{folder}") ? "#{replaced_url}/#{folder}" : replaced_url
ab_index_url = File.directory?("#{dirname}/#{folder}") ? "#{dirname}/#{folder}/index.html" : "#{dirname}/index.html"
sign = read_list_path =~ /#{self.id.to_s}$/ ? self.id.to_s : folder
all_urls = get_file_list(read_list_path, self.id.to_s, folder, sign)
replace_url = all_urls.select{|url| url.downcase =~ /\.(gif|jpg|jpeg|png|js|css)$/i}
all_js_path = replace_url.select{|url| url.downcase =~ /\.js$/i}
replace_js_files(dirname,folder,all_js_path,replace_url,replaced_url)
replace_html_file(ab_index_url, replace_url, replaced_url)
rescue
return {"status" => "invalid" , "message" => 'please reupload zip'}
end
end
end
def get_urls_from_js(js,directory)
reg = /\"([^\"\']+\.(png|gif|jpg|jpeg|js|css))\"|\'([^\'\"]+\.(png|gif|jpg|jpeg|js|css))\'/
urls = js.scan(reg).map{|b| b[0].present? ? b[0] : b[2]}.uniq
urls.present? ? sort_url(urls.select{|url| directory.any?{|dir| dir.include?(url.gsub(/\.(\.|)\//,''))}}) : []
end
def replace_js_files(dirname,folder,all_js_path,replace_url,replaced_url)
all_js_path.each do |path|
js_pathname = File.directory?("#{dirname}/#{folder}") ? "#{dirname}/#{folder}/#{path}" : "#{dirname}/#{path}"
file = File.open(js_pathname)
js = file.read
js_urls_from_file = get_urls_from_js(js.gsub(/\s+/,''), replace_url)
js_urls_from_file.each {|url|
path1 = path.split('/')
(url.scan(/\.\.\//).count + 1).times {path1.pop}
root_url = path1.push(url.gsub(/\.(\.|)\//,'').gsub('.', '00replace00')).join('/')
js = js.gsub(url,"#{replaced_url}/#{root_url}")
}
File.open(js_pathname, "w") { |fw| fw.write(js.gsub('00replace00', '.'))} if js_urls_from_file.present?
end
end
def replace_html_file(ab_index_url, replace_url, replaced_url)
file = File.open(ab_index_url)
html = file.read
replace_url.each{|r| html = html.gsub("./#{r}","#{replaced_url}/#{r.gsub('.','00replace00')}").gsub(r,"#{replaced_url}/#{r}").gsub('00replace00','.')}
File.open(ab_index_url, "w") { |fw| fw.write(html) }
self.update_attributes(:h5_code => html)
end
def sort_url(urls)
urls1 = urls.select{|url| url.match(/\.(\.|)\//)}
sort_has_point(urls1) + (urls - urls1).sort{|x,y| y.scan(/\//).count <=> x.scan(/\//).count}
end
def sort_has_point(urls)
urls.sort{|x,y|
if x.scan(/\.(\.|)\//).count > 0 && x.scan(/\.(\.|)\//).count == y.scan(/\.(\.|)\//).count
x.scan(/\.\.\//).count > y.scan(/\.\.\//).count ? -1 : 1
else
y.scan(/\.(\.|)\//).count <=> x.scan(/\.(\.|)\//).count
end
}
end
def verification_zip(origin_name,user_id)
message = []
begin
folder = origin_name.gsub('.zip', '') if origin_name.present?
pathname = "#{Rails.root}/public/upload_files/a03/#{self.image_url.gsub(/http:\/\/a03.optimix.asia\//, '')}"
userid_name = "#{Rails.root}/public/upload_files/temp_zip/#{user_id}"
FileUtils.mkdir_p(userid_name) unless File.directory?(userid_name)
return {"status" => "invalid" , "message" => I18n.t('pretargetings.validate.html5_too_large') } if File.size("#{pathname}").to_i/1024 > ZIP_MAX_SIZE
%x(rm -rf #{userid_name}/*)
%x(unzip -o -d #{userid_name} #{pathname})
%x(rm -rf #{userid_name}/__MACOSX) if File.directory?("#{userid_name}/__MACOSX")
directory = Dir.entries("#{userid_name}").select{|dir| ![".",".."].include?(dir)}
index_html = directory.select{|dir| dir =~ /\.html$/ }
if index_html.present?
File.rename("#{userid_name}/#{index_html.last}", "#{userid_name}/index.html")
else
folder = directory.last
dire = Dir.entries("#{userid_name}/#{folder}").select{|dir| dir =~ /\.html$/}
File.rename("#{userid_name}/#{folder}/#{dire.last}", "#{userid_name}/#{folder}/index.html")
end
read_list_path = File.directory?("#{userid_name}/#{folder}") ? "#{userid_name}/#{folder}" : userid_name
ab_index_url = File.directory?("#{userid_name}/#{folder}") ? "#{userid_name}/#{folder}/index.html" : "#{userid_name}/index.html"
ve = verification_html(ab_index_url)
message << ve["message"] if ve.is_a?(Hash) && ve["status"] == "invalid"
sign = read_list_path =~ /#{user_id.to_s}$/ ? user_id.to_s : folder
all_urls = get_file_list(read_list_path, user_id.to_s, folder, sign)
ve = verification_file_type(all_urls,ab_index_url)
message << ve["message"] if ve.is_a?(Hash) && ve["status"] == "invalid"
ve = verification_head_size(ab_index_url,self.size)
message << ve["message"] if ve.is_a?(Hash) && ve["status"] == "invalid"
message.present? ? {"status" => "invalid" , "message" => message.join('</p>')} : true
rescue
return {"status" => "invalid" , "message" => 'please reupload zip'}
end
end
def get_file_list(path, id, folder=nil,sign="0")
b = []
Dir.entries(path).each do |sub|
if sub != '.' && sub != '..'
if File.directory?("#{path}/#{sub}")
b = b + get_file_list("#{path}/#{sub}", id, folder, sign)
end
b << (path + '/' + sub).split(sign + '/')[1] unless File.directory?("#{path}/#{sub}")
end
end
b
end
def verification_html(path)
File.open(path) do |fr|
xml = fr.read
match_data = xml.gsub(/\s+/,'').match(/<metaname=(\"|\')ad\.size(\"|\')content=(\"|\')width=\d+,height=\d+(\"|\')(\/|)>/i)
unless match_data.present? && xml =~ /\$clickurl\$/i && xml =~ /\<\!DOCTYPE html\>/i && xml =~ /\<html/i && xml =~ /\<body/i && xml =~ /\<\/body\>/i && xml =~ /\<\/html\>/i
{"status" => "invalid" , "message" => I18n.t('pretargetings.validate.please_upload_effective_material') }
end
end
end
def verification_file_type(array,path)
if array.any?{|item| item.downcase =~ /\.(bmp|pcx|tiff|tga|exif|fpx|svg|psd|cdr|pcd|dxf|ufo|eps|ai|hdri|raw)$/}
{"status" => "invalid" , "message" => I18n.t('pretargetings.validate.image_Format_error') }
end
if array.any?{|item| item.downcase =~ /\.json$/}
{"status" => "invalid" , "message" => I18n.t('pretargetings.validate.please_upload_effective_material') }
end
end
def verification_head_size(path,size)
selected_size = size.split('*')
File.open(path) do |fr|
xml=fr.read.gsub(/\s+/,'')
match_data = xml.match(/<metaname=(\"|\')ad\.size(\"|\')content=(\"|\')width=\d+,height=\d+(\"|\')(\/|)>/i)
{"status" => "invalid" , "message" => I18n.t('pretargetings.validate.size_Format_error') } if match_data.present? && match_data.to_s.scan(/\d+/) != selected_size
end
end
下一步读取数据库的index.html代码显示。
http://www.schooltop.net/blogs/179
分享到:
相关推荐
直接解压运行就可以了,不需要安装,然后点path选择navicat的exe启动文件的路劲,然后点gen按钮就可以获得注册码
用于navicat for Oracle连接Oracle时报错ORA-28547问题解决:打开navicat,工具-->选项-->OCI,将OCI library(oci.dll)修改为:D:\oracle\instantclient_19_6\oci.dll,这是我的路劲,具体改成自己解压instant...
课程设计-基于知识图谱的医疗诊断知识问答系统python源码(含详细使用说明和模型文件).zip 环境 - python >= 3.6 - pyahocorasick==1.4.2 - requests==2.25.1 - gevent==1.4.0 - jieba==0.42.1 - six==1.15.0 - ...
外加热强制循环蒸发器装配图(CAD).rar
数控车床纵向进给系统设计.zip
j
爬虫 bangumi名称和评论数
基于SpringBoot的垃圾分类回收系统,系统包含两种角色:管理员、用户主要功能如下。 【用户功能】 首页:浏览垃圾分类回收系统信息。 个人中心:管理个人信息,查看历史记录和订单状态。 运输管理:查看运输信息,垃圾回收的时间和地点。 公告管理:阅读系统发布的相关通知和公告。 垃圾回收管理:查看垃圾回收的信息,回收类型和进度。 垃圾出库申请管理:提交和查看垃圾出库申请的状态。 【管理员功能】 首页:查看垃圾分类回收系统。 个人中心:管理个人信息。 管理员管理:审核和管理注册管理员用户的信息。 用户管理:审核和管理注册用户的信息。 运输管理:监管和管理系统中的运输信息。 公告管理:发布、编辑和删除系统的通知和公告。 垃圾回收管理:监管和管理垃圾回收的信息。 垃圾出库申请管理:审批和管理用户提交的垃圾出库申请。 基础数据管理:管理系统的基础数据,运输类型、公告类型和垃圾回收类型。 二、项目技术 编程语言:Java 数据库:MySQL 项目管理工具:Maven 前端技术:Vue 后端技术:SpringBoot 三、运行环境 操作系统:Windows、macOS都可以 JDK版本:JDK1.8以上都可以 开发工具:IDEA、Ecplise、Myecplise都可以 数据库: MySQL5.7以上都可以 Maven:任意版本都可以
内容概要:本文档是台湾大学计算机科学与信息工程系2021年秋季学期《算法设计与分析》课程的第一次作业(Homework#1)。作业包含四道编程题和三道手写题,旨在考察学生对算法设计和分析的理解与应用能力。编程题涉及汉诺塔、数组计算、矩形点对、糖果分配等问题;手写题涵盖渐近符号证明、递归方程求解、幽灵腿游戏优化、不公平的卢卡斯问题等。文档详细描述了每个问题的具体要求、输入输出格式、测试用例以及评分标准。此外,还提供了编程技巧和注意事项,如避免延迟提交、正确引用资料、处理大输入文件等。 适合人群:具备一定编程基础的本科生或研究生,特别是修读过或正在修读算法设计与分析相关课程的学生。 使用场景及目标:①帮助学生巩固课堂所学的算法理论知识;②通过实际编程练习提高解决复杂问题的能力;③为后续更深入的学习和研究打下坚实的基础。 其他说明:此作业强调团队合作和个人独立思考相结合的重要性,鼓励学生在讨论后用自己的语言表达解决方案,并注明参考资料。对于编程题,特别提醒学生注意输入文件可能较大,建议采取适当的优化措施以确保程序运行效率。
基于SpringBoot的铁路订票管理系统,系统包含两种角色:管理员、用户主要功能如下。 【用户功能】 首页:浏览铁路订票管理系统的主要信息。 火车信息:查看火车的相关信息,包括车次、出发地、目的地和票价等。 公告资讯:阅读系统发布的相关通知和资讯。 后台管理:进行系统首页、个人中心、车票预订管理、车票退票管理等操作。 个人中心:管理个人信息,查看订单历史记录等。 【管理员功能】 首页:查看铁路订票管理系统。 个人中心:修改密码、管理个人信息。 用户管理:审核和管理注册用户的信息。 火车类型管理:管理系统中的火车类型信息。 火车信息管理:监管和管理系统中的火车信息,添加、编辑、删除等。 车票预订管理:处理用户的车票预订请求。 车票退票管理:处理用户的车票退票请求。 系统管理:管理系统的基本设置,公告资讯、关于我们、系统简介和轮播图管理。 二、项目技术 编程语言:Java 数据库:MySQL 项目管理工具:Maven 前端技术:Vue 后端技术:SpringBoot 三、运行环境 操作系统:Windows、macOS都可以 JDK版本:JDK1.8以上都可以 开发工具:IDEA、Ecplise、Myecplise都可以 数据库: MySQL5.7以上都可以 Maven:任意版本都可以
塑料架注射模具设计.rar
基于json文件数据驱动的的接口测试框架
铁丝缠绕包装机设计-缠绕盘设计.rar
linux
圆柱体相贯线焊接专机工作台设计.rar
硬币分拣机设计.rar
内容概要:本文探讨了开发行业级机器学习和数据挖掘软件的经验与教训,指出当前研究界与工业界之间的脱节问题。作者分享了开发LIBSVM和LIBLINEAR的经验,强调了用户需求的重要性。大多数用户并非机器学习专家,期望简单易用的工具来获得良好结果。文章还详细介绍了支持向量机(SVM)的实际应用案例,包括数据预处理(如特征缩放)、参数选择等步骤,并提出了为初学者设计的简易流程。此外,作者讨论了在设计机器学习软件时应考虑的功能选择、选项数量、性能优化与数值稳定性等问题,强调了软件开发与实验代码的区别以及鼓励研究人员参与高质量软件开发的重要性。 适合人群:对机器学习软件开发感兴趣的科研人员、工程师及从业者,尤其是那些希望了解如何将学术研究成果转化为实际可用工具的人士。 使用场景及目标:①帮助非机器学习专家的用户更好地理解和使用机器学习方法;②指导开发者在设计机器学习软件时考虑用户需求、功能选择、性能优化等方面的问题;③促进学术界与工业界之间的合作,推动高质量机器学习软件的发展。 其他说明:本文不仅提供了具体的开发经验和技巧,还呼吁建立激励机制,鼓励更多研究人员投入到机器学习软件的开发中,以解决当前存在的研究与应用脱节的问题。
一天入门pandas代码
该资源为joblib-0.12.0-py2.py3-none-any.whl,欢迎下载使用哦!
内容概要:本文档《xtuner_requirements.txt》列出了用于支持特定项目(可能是机器学习或深度学习项目)运行所需的所有Python包及其版本。其中不仅包括常见的数据处理和科学计算库如numpy、pandas,还包括了与深度学习密切相关的库如torch、transformers等。值得注意的是,文档中还特别指定了NVIDIA CUDA相关组件的具体版本,确保了GPU加速环境的一致性和兼容性。此外,文档中也包含了从GitHub直接安装的xtuner库,明确了具体的提交哈希值,保证了代码来源的精确性。 适合人群:对机器学习、深度学习领域有一定了解并需要搭建相应开发环境的研发人员,尤其是那些希望复现特定实验结果或基于已有模型进行二次开发的研究者和技术爱好者。 使用场景及目标:①帮助开发者快速搭建完整的开发环境,确保所有依赖项正确无误;②为研究人员提供一个稳定的实验平台,以便于重复实验和验证结果;③作为项目协作的基础,确保团队成员之间的环境一致性,减少因环境差异带来的问题。 阅读建议:由于该文档主要为技术性依赖列表,在阅读时应重点关注所需安装的库及其版本号,特别是CUDA相关组件和自定义库(如xtuner)的安装方式。对于非技术人员而言,可能需要额外查阅相关资料来理解各库的作用。同时,在实际操作过程中,建议按照文档中的顺序逐一安装依赖,避免版本冲突等问题的发生。