成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Flash真的適合做網(wǎng)站應用嗎?

開發(fā) 前端 后端
Flash真的適合像阿里巴巴這樣的網(wǎng)站使用嗎?閉源和性能是Flash最大的問題。但在HTML 5被廣泛支持前,F(xiàn)lash和傳統(tǒng)Ajax還是我們最主要的富客戶端應用開發(fā)技術,相對于ActiveX、 Silverlight、JavaFX、Gear等技術來說,F(xiàn)lash還是有安裝率優(yōu)勢的。

兩年前,我們開發(fā)了一套基于Flash的文件(主要是圖片)上傳RIA應用,提供給阿里巴巴的用戶使用。如果你使用過Wordpress或flickr上傳圖片,你應該已經(jīng)用過類似的產(chǎn)品。這個程序基于YUI Uploader開發(fā),增加了一個實用的功能——在客戶端先將圖片縮小,再上傳到服務器。用戶用數(shù)碼相機拍攝的照片往往有600萬以上的像素,但產(chǎn)品圖片放到阿里巴巴網(wǎng)站上 顯示,并不需要這么大的像素,通常等比例縮小到1024×1024之內就可以了。借助于Flash對圖片先縮小再上傳的技術,我們在沒有增加服務器投入的情況下,將原先上傳圖片的尺寸限制由250KB/張?zhí)嵘搅?MB/張。同時,F(xiàn)lash上傳還比傳統(tǒng)HTML表單方式上傳有更好的體驗,例如可以多選一 批文件同時上傳、可以實時展示上傳進度、選擇文件時可以過濾非圖片文件。

Flash真的適合做網(wǎng)站應用嗎?

這個組件獲得了很大的成功。上線后不久,阿里巴巴網(wǎng)站上用戶的圖片上傳數(shù)量由日均1萬張左右上升至日均15萬張左右。但在這個上傳應用投入應用的兩年中,我們遇到了各種問題。

1. bug

[[21591]]

在基于IE多標簽瀏覽器中的偽沙箱問題就 不說了,最嚴重的是cookie的問題。使用FileReference.upload的方式上傳文件,http請求中附帶的cookie信息不一定是當 前瀏覽器進程的cookie,在Firefox、chrome等非IE瀏覽器中非常嚴重,可能傳輸?shù)氖荌E中的cookie。即便是IE,也可能傳輸?shù)?cookie內容和當前頁面的cookie記錄不符合。這直接導致服務器端在收到文件之后的安全驗證中失敗。而對于阿里巴巴這樣的大型網(wǎng)站,有比較成熟的 java web框架,要去掉對cookie的依賴非常麻煩。于是結果就是,首先我們只有在用戶使用IE系瀏覽器的時候才使用Flash上傳,其次我們隔三岔五的還 會收到使用IE的某些客戶的投訴,在花費了大量的時間排查之后,我發(fā)現(xiàn)是由于cookie的問題導致上傳失敗。這個bug已經(jīng)存在很多年,但是隨著Flash從9升級到10,許多版本過去了,問題依然沒有被解決。對于閉源的Flash,我們非常被動。

2.性能

[[21592]]

相對于現(xiàn)今數(shù)碼相機的像素量,5MB的大小限制非常保守。但大于5M的時候,在一些低配置的電腦上,讀取文件內容的時候就會發(fā)生瀏覽器假死現(xiàn)象。假死很容易導致瀏覽器崩潰,所以我們采取了保守的限制——5MB。

另外一個性能消耗是將BitmapData編碼成JPEG文件的時候。Adobe提供了JPEGEncoder,但由于是Array實現(xiàn)的,所以性能是個問題。編碼一個2880×2880的圖片在一臺中等配置的電腦上大約需要15秒時間。

我用Vector改寫了這個類,時間縮短為3.5秒左右。使用Alchemy,時間進一步縮短到1.5秒左右。但還是不夠安全,所以***采用了異步Vector的方式,延長編碼的時間,以保證程序的穩(wěn)定性。(評測在這里)

3.圖片質量

[[21593]]

Flash內置的***的圖片縮小算法(用BitmapData.draw,并將smoothing參數(shù)設為true),在縮小圖片的時候容易產(chǎn)生鋸齒。因此我改寫了Jacwright提供的縮小算法,圖片質量的問題解決,但代價是性能又降低了一些。

4.安全限制

[[21594]]

Flash10.0 之后,增加了一個安全限制——當URLLoader以標準文件上傳的方式發(fā)送POST請求的時候,需要由用戶的UI操作(鼠標點擊或按鍵事件)觸發(fā)。因為 我們對用戶的圖片做了處理,已經(jīng)無法再通過FileReference上傳,只能通過URLLoader。這個安全性限制規(guī)定每次發(fā)起一個上傳文件的 URLLoader請求,都必須讓用戶點擊一下鼠標才可以。如果用戶選擇了20張圖片,就要點擊20次鼠標。這顯然是無法接受的。因此我們放棄了用標準文件上傳,采用普通post形式。代價是失去了對上傳進度的跟蹤,不知道文件上傳的百分比;同時服務器端也需要改造。

改變

最近,我們做了一個決定:開發(fā)一個類似功能的ActiveX控件,替代Flash作為圖片上傳的主要解決方案。ActiveX的優(yōu)勢是性能,不足之處在于只 能在Windows+IE瀏覽器中使用,但實際上我們的Flash上傳目前也只能在IE中使用。Flash真的適合像阿里巴巴這樣的網(wǎng)站使用嗎?閉源和性能是Flash***的問題。但在HTML 5被廣泛支持前,F(xiàn)lash和傳統(tǒng)Ajax還是我們最主要的富客戶端應用開發(fā)技術,相對于ActiveX、 Silverlight、JavaFX、Gear等技術來說,F(xiàn)lash還是有安裝率優(yōu)勢的。目前Flash依然是我們很重要的RIA技術。

但是HTML 5完全到來的那一天,現(xiàn)在很難說。

原文鏈接:http://news.cnblogs.com/n/97560/

【編輯推薦】

  1. IBM發(fā)布開源HTML 5可視化設計工具Maqetta
  2. HTML 5的革新:結構之美
  3. 2011年2月8款免費HTML和CSS模板推薦
  4. HTML 5標準學習入門之文檔結構
  5. 學習HTML 5十佳站點推薦
責任編輯:陳貽新 來源: 博客園
相關推薦

2021-08-02 09:02:27

架構產(chǎn)品優(yōu)化

2023-07-30 17:12:10

數(shù)字化轉型

2016-01-07 15:03:20

2013-08-13 14:33:17

程序員

2011-03-28 13:05:38

MeeGo諾基亞英特爾

2013-05-31 11:29:06

2018-07-03 10:25:22

CentOsUbuntu服務器

2013-02-01 11:31:53

Linux桌面系統(tǒng)

2010-11-10 11:14:41

項目經(jīng)理

2018-03-27 10:52:59

程序員不適合C++

2022-05-16 10:36:08

GitHub開源項目

2020-10-16 16:20:00

開源開發(fā)管理系統(tǒng)

2020-08-17 07:58:49

互聯(lián)網(wǎng)程序員技術

2016-06-01 15:42:58

Hadoop數(shù)據(jù)管理分布式

2020-05-14 14:45:33

深度學習 PyTorch人工智能

2024-03-14 08:00:51

獨立開發(fā)程序員編程

2019-12-25 13:58:04

網(wǎng)絡安全SD-WAN防火墻

2015-09-07 13:38:41

數(shù)據(jù)分析

2012-10-24 10:16:17

IT工程師云計算網(wǎng)絡管理

2019-08-12 14:22:23

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产一区二区三区免费观看在线 | av中文字幕在线 | 欧美性一区二区三区 | 在线观看视频91 | 婷婷免费在线 | 亚洲精品久久久久久国产精华液 | 精品一区二区久久久久久久网精 | 天天干.com| 午夜精品久久久久久久99黑人 | 国产精品日韩一区二区 | 亚洲免费一区 | 在线激情视频 | 中文字幕国产一区 | 国产网站在线免费观看 | 国产欧美精品一区二区色综合朱莉 | 欧美亚洲综合久久 | 欧美亚洲国产精品 | 免费久久99精品国产婷婷六月 | 99tv| 国产黄色av网站 | 97伦理电影 | 精品久久久久久久久久久久久久 | 一级片在线免费看 | 日日操夜夜操视频 | 国产午夜精品一区二区三区四区 | 日本在线看片 | 欧美成ee人免费视频 | 男人久久天堂 | 国产欧美一区二区三区免费 | 毛片网站在线观看 | 欧美在线成人影院 | 综合久久av | 黄色在线免费播放 | 最新日韩精品 | 黄色免费网址大全 | 欧美精品国产一区二区 | 久久久久99 | 成人精品免费 | 欧美日韩亚洲国产 | 久久人人网 | 国产精品视频网址 |