Merge branch 'szzh' into develop

Conflicts:
	app/controllers/avatar_controller.rb
This commit is contained in:
sw 2015-05-25 14:48:01 +08:00
commit 010036ffa5
5 changed files with 43 additions and 13 deletions

View File

@ -24,6 +24,7 @@ class AvatarController < ApplicationController
else else
@image_file=params[:filename] @image_file=params[:filename]
end end
@temp_file = StringIO.new(@temp_file)
end end
end end
end end
@ -32,7 +33,7 @@ class AvatarController < ApplicationController
if @temp_file.size > Setting.upload_avatar_max_size.to_i if @temp_file.size > Setting.upload_avatar_max_size.to_i
@status = 1 @status = 1
@msg = l(:error_upload_avatar_to_large, :max_size => number_to_human_size(Setting.upload_avatar_max_size.to_i)) @msg = l(:error_upload_avatar_to_large, :max_size => number_to_human_size(Setting.upload_avatar_max_size.to_i))
elsif Trustie::Utils::Image.new(@temp_file.tempfile.path).image? elsif Trustie::Utils::Image.new(@temp_file).image?
diskfile=disk_filename(@source_type,@source_id) diskfile=disk_filename(@source_type,@source_id)
@urlfile='/' << File.join("images","avatars",avatar_directory(@source_type),avatar_filename(@source_id,@image_file)) @urlfile='/' << File.join("images","avatars",avatar_directory(@source_type),avatar_filename(@source_id,@image_file))
@ -50,6 +51,7 @@ class AvatarController < ApplicationController
md5 = Digest::MD5.new md5 = Digest::MD5.new
File.open(diskfile, "wb") do |f| File.open(diskfile, "wb") do |f|
if @temp_file.respond_to?(:read) if @temp_file.respond_to?(:read)
@temp_file.rewind
buffer = "" buffer = ""
while (buffer = @temp_file.read(8192)) while (buffer = @temp_file.read(8192))
f.write(buffer) f.write(buffer)

View File

@ -9,10 +9,14 @@ class ZipdownController < ApplicationController
#统一下载功能 #统一下载功能
def download def download
begin if User.current.logged?
send_file "#{OUTPUT_FOLDER}/#{params[:file]}", :filename => params[:filename], :type => detect_content_type(params[:file]) begin
rescue => e send_file "#{OUTPUT_FOLDER}/#{params[:file]}", :filename => params[:filename], :type => detect_content_type(params[:file])
render file: 'public/no_file_found.html' rescue => e
render file: 'public/no_file_found.html'
end
else
render_403
end end
end end

View File

@ -659,6 +659,16 @@ ActiveRecord::Schema.define(:version => 20150514133640) do
add_index "journal_details", ["journal_id"], :name => "journal_details_journal_id" add_index "journal_details", ["journal_id"], :name => "journal_details_journal_id"
create_table "journal_details_copy", :force => true do |t|
t.integer "journal_id", :default => 0, :null => false
t.string "property", :limit => 30, :default => "", :null => false
t.string "prop_key", :limit => 30, :default => "", :null => false
t.text "old_value"
t.text "value"
end
add_index "journal_details_copy", ["journal_id"], :name => "journal_details_journal_id"
create_table "journal_replies", :id => false, :force => true do |t| create_table "journal_replies", :id => false, :force => true do |t|
t.integer "journal_id" t.integer "journal_id"
t.integer "user_id" t.integer "user_id"

View File

@ -17,21 +17,20 @@ module Trustie
end end
def jpeg?(data) def jpeg?(data)
data[0,4]== 0xff.chr + 0xd8.chr + 0xff.chr + 0xe0.chr data[0,3]== 0xff.chr + 0xd8.chr + 0xff.chr
end end
def png?(data) def png?(data)
data[0,2]==0x89.chr + 80.chr data[0,2]==0x89.chr + 80.chr
end end
def image? def image?
begin data = ''
f = File.open(@file,'rb') # rb means to read using binary if @file.respond_to?(:read)
return false if f.size < 9 data = @file.read(9)
data = f.read(9) # magic numbers are up to 9 bytes @file.rewind
return bitmap?(data) || gif?(data) || jpeg?(data) || png?(data)
ensure
f.close
end end
return false if data.size < 9
bitmap?(data) || gif?(data) || jpeg?(data) || png?(data)
end end
def compress(size=300) def compress(size=300)

View File

@ -0,0 +1,15 @@
require 'rails_helper'
RSpec.describe "avatar request", type: :request do
describe "上传头像" do
let(:user){FactoryGirl.create(:user)}
it "参数正确,可以成功上传头像" do
data = File.open("#{Rails.root}/spec/fixtures/test.jpg").read
binding.pry
post upload_avatar_path(source_type: 'User', source_id: user.id, filename: 'test.jpg')
expect(response).to have_http_status(:success)
expect(response.body).to include(/\/images\/avatars\/User\//)
end
end
end