2014-07-08 25 views
1

存储当我试图通过图表URL(https://graph.facebook.com)来获取Facebook的图像,回形针店avatar_image_name在数据库中的“图片”。代码的例子:回形针不以正确的格式获取图像的URL

img = UserImages.new 
img.avatar = URI.parse('https://graph.facebook.com/666980153384194/picture?type=large') 
img.save 

MySQL查询在控制台日志:

=> #<URI::HTTPS:0x00000009954490 URL:https://graph.facebook.com/666980153384194/picture?type=large> 
irb(main):009:0> img.save 
    (0.0ms) BEGIN 
    SQL (0.0ms) INSERT INTO `user_images` (`avatar_content_type`, `avatar_file_name`, `avatar_file_size`, `avatar_updated 
_at`, `created_at`, `updated_at`) VALUES ('image/jpeg', 'picture', 6157, '2014-07-08 13:55:53', '2014-07-08 13:56:02', ' 
2014-07-08 13:56:02') 
    (29.1ms) COMMIT 

正如你可以看到名为“画面”获取保存图像文件。但是,如果通过直接URL像抓取图像:

https://scontent-a-lax.xx.fbcdn.net/hphotos-prn2/v/t1.0-9/10478546_662150043867205_2640371404472615909_n.jpg?oh=cb2fe9d421fef3d7d2220bb48a2a36e2&oe=5418E8FB 

取出的图象存储为:

(0.0ms) BEGIN 
Command :: file -b --mime "C:/Users/Windows/AppData/Local/Temp/f1620d075c0642a77f7b98e532d8a8eb20140708-1040-1h5z4e6.jpg 
" 
    SQL (1.0ms) INSERT INTO `user_images` (`avatar_content_type`, `avatar_file_name`, `avatar_file_size`, `avatar_updated 
_at`, `created_at`, `updated_at`) VALUES ('image/jpeg', '10478546_662150043867205_2640371404472615909_n.jpg', 25862, '20 
14-07-08 14:02:45', '2014-07-08 14:02:49', '2014-07-08 14:02:49') 
    (34.1ms) COMMIT 
=> true 

任何建议(溶液),将不胜感激。

UserImages类的源:

class UserImages < ActiveRecord::Base 
    belongs_to :imageable ,polymorphic: true 
    has_attached_file :avatar, 
         :styles => { :medium => "300x300>", :thumb => "125x125>" }, 
         :path => ":rails_root/public/images/users/:id/:style/:hash.:extension", 
         :default_url => "/images/normal/missing.jpg", 
         :url => "/images/users/:id/:style/:hash.:extension", 
         :hash_secret => "EWRWerrew234UTY" 

    validates_attachment :avatar, :content_type => { :content_type => ["image/jpeg", "image/gif", "image/png"] }, 
             :size => { :in => 0..5.megabytes } 

    end 

回答

0

有两种获取网址没问题....无论做工精细... 的区别仅仅是因为曲别针从最后生成的文件名URL的... 所以在第一URL

https://graph.facebook.com/666980153384194/图片?类型=大

而在第二个URL

https://scontent-a-lax.xx.fbcdn.net/hphotos-prn2/v/t1.0-9/10478546_662150043867205_2640371404472615909_n.jpg?哦= cb2fe9d421fef3d7d2220bb48a2a36e2 & OE = 5418E8FB

我加粗的是回形针使用生成的文件名的URL的一部分....而在这两种情况下,你不应该真正困扰自己的文件名......既然你可以做任何操作,你要想到回形针。

而且可以确保该文件是通过检查路径public/images/users/:id(回形针路径配置)

+0

得到它上传。非常感谢您的澄清! :) – ProblemSlover

+0

是,图像被指定的存储路径。文件的名称有一个散列格式,但没有文件扩展名:d8146a48c0f4fc3d916e57257c6270e91205ccbc 这让有点困惑图像是如何解决的:P – ProblemSlover

+0

是啊,如果回形针想不出会发生......如果文件中存在的延伸路径,你可以打开它。然后,它会在回形针工作。 –