搜尋

搜尋結果

「時尚匯」購物中心完美揉合奢華時尚與精緻美 麗思酒廊獨家呈獻「KWANPEN 80週年慶典下午茶」
生活在我城
LifeMag Editor・2017-12-17

澳門最具時尚風格的購物熱點「時尚匯」購物中心,於12月特別聯同澳門麗思卡爾頓酒店的麗思酒廊隆重呈獻「KWANPEN 80週年慶典下午茶」,慶祝奢華皮革品牌KWANPEN傳承亞洲傳統,以卓越工藝創造出一系列雋永不凡的鱷魚皮革手提袋。由即日起至2018年1月31日,麗思酒廊獨家推出精緻的主題下午茶,配以一系列精選茗茶,帶來時尚優雅的午後時光。下午茶套餐價格為澳門幣488元(供兩位用),賓客另可選擇澳門幣688元之下午茶套餐,享用兩杯PerrierJoueuml;t香檳。套餐提供多款精美甜點,包括銀朱古力蒙布朗、紅莓朱古力樹幹蛋糕、開心果泡芙、藍莓薰衣草撻,以及精選鬆餅;咸點方面,則有牛油果慕絲配鮮蝦沙律、黃甜椒銀杏伴三文魚籽、帝皇蟹腳沙律伴蕃茄碎、煙熏鰻魚餅,以及火雞樹幹蛋糕。KWANPEN經典的 Raffles系列色彩鮮豔,使用鱷魚皮革腹部中央剪裁,以及獨有配件設計。而「KWANPEN 80週年慶典下午茶」則以Raffles系列作為靈感,將美食與品牌的超卓工藝完美融合。賓客在細意品嘗下午茶美點之餘,更可於「時尚匯」購物中心的KWANPEN專門店親身探索全人手製作的Raffles系列。一貫KWANPEN皮革工藝傳統,工匠都為Raffles系列的每個手袋一絲不苟地挑選合適大小的皮革、圖案和紋理。「澳門銀河」零售助理高級副總裁黃興齡表示:「『時尚匯』購物中心薈萃國際知名時尚品牌,提供優質的服務及餐飲選擇,讓賓客感受精彩獨特的休閒體驗。KWANPEN 創立80週年,意義非凡,為此我們十分雀躍能透過麗思酒廊特別設計的主題下午茶,展現KWANPEN的家族傳承及亞洲頂尖皮革工藝。」來自新加坡的KWANPEN創立於1938年,每件產品的設計均精緻奢華,工藝超凡,至今已發展成為市場領先的鱷魚皮革和奢華配件品牌。為慶祝品牌成立80週年,賓客可親臨位於「時尚匯」購物中心的KWANPEN專門店,探索別出心裁的 Raffles 系列,同時可於麗思酒廊細味主題下午茶,盡享時尚與美食共冶一爐的精彩時光。上述價格須加10%服務費及5%政府稅

「聚焦.美藝.MGM」攝影比賽現正接受報名
文化創意
LifeMag Editor・2015-07-15

澳門美高梅天幕廣場資訊中心 作為澳門一流的文化藝術交流平台,澳門美高梅一直致力將文化和藝術融入公眾生活。是次與澳門攝影學會合辦「聚焦.美藝.MGM」攝影比賽,旨在讓市民大眾在欣賞藝術作品的同時,更有機會展示攝影才能,透過鏡頭從不同角度和個性思維表達對藝術作品的感悟。澳門美高梅亦鼓勵年輕人在參觀藝術品和藝術裝置展覽時,透過攝影培養欣賞藝術之美的能力,善用餘暇時間,度過一個豐富的暑假。 「聚焦.美藝.MGM」攝影比賽歡迎市民大眾參加,參賽作品必須以澳門美高梅酒店內展示之藝術品為攝影主題,如現正在天幕廣場展出之巨型藝術裝置「八面靈龍」(Valkyrie Octopus)、薩爾瓦多 bull; 達利(Salvador Dali)的銅像雕塑、獅子雙年展的獅子雕塑或植皓禮(Dale Chihuly)的玻璃藝術品等。是次攝影比賽分為「行動裝置組」及「相機拍攝組」,每組均設有冠、亞、季軍、優異奬及「八面靈龍」最佳攝影作品。 「行動裝置組」 「行動裝置組」之攝影作品需由智能手機或平板電腦拍攝,作品規格為2 5 MB,須為JPEG格式。比賽分三期進行,截止日期分别為7月 17日、7月 31日及8月14日。參賽者需按時將作品上載至www.discoveringartatmgm.com,評審委員會從中選出每期優秀作品,然後上載到攝影比賽之Facebook專頁 www.discoveringartatmgm.comfb 作公開投票,每期得票最高者可進入最後評審階段。此組別另設有「最ldquo;Likerdquo;大奬」及「最佳自拍大獎」。 「相機拍攝組」 「相機拍攝組」之參賽作品需由數碼相機或者菲林相機拍攝,作品規格為10rdquo;x15rdquo;,黑白或彩色皆可,相片無需裝裱。若參賽者提交由數碼相機拍攝之作品,則需同時提交作品的數碼檔案光碟,格式須為JPEG或RAW,檔案之最長邊不低於3,000像素。參賽者需於8月 21日前填妥宣傳單張內的參賽表格,並連同參賽相片於辦公時間內親送到以下指定收件處,信封上需註明『「聚焦.美藝.MGM」攝影比賽』, 逾期不予受理。參賽作品必須是原創作品,參賽者必須擁有其參賽作品的全部版權。 評審及獎品 每組之冠軍獎品包括獎狀、 葡萄牙里斯本來回機票及酒店住宿;亞軍及季軍獎品包括獎狀及現金獎最高為澳門幣8,000元。其他獎項包括最高澳門幣3,000元現金獎、價值澳門幣800元之美高梅餐飲禮券及澳門美高梅豪華客房免費住宿一晚等。 澳門美高梅天幕廣場資訊中心 辦公時間:星期一至星期五 中午1200 ndash; 晚上900 ; 星期六,星期日及公眾假期 上午1100 ndash; 晚上900 電話:853 8802 3834 有關更多攝影比賽之詳情及查詢,請到www.discoveringartatmgm.com或致電(853)8802 3834或電郵至artspace@mgmmacau.com。

教育家陳康妮:全球科研正研發新型口罩 易殺菌
文化創意
陳康妮・2020-08-17

【作者簡介】 陳康妮 Miss Connie,大學講師,現任澳門作家協會秘書長。澳州墨爾本大學主修高等教育管理學,澳門高等教育管理學專家。主力高等教育管理學的教育硏究。澳門教育專欄作家,澳門兒童文學作家。 陳康妮提出「澳門創新創業教育」概念。希望將創新創業的教育帶給澳門的每一位大學生。充分學習國外學校的優點,同時保持澳門本土特色,創造最好的未來大學,也給迷茫的大學生未來的學習以及人生建議。讓澳門的學生走向世界! 全球科研人員設計多種新的口罩,他們相信設計各種口罩可以像N95口罩一樣有效地阻止病毒顆粒。 隨著全球新的Covid19病例數量的持續增加,仍然急需醫療人員和其他人員使用N95口罩。全球設計新型口罩由耐用的矽橡膠製成,這種矽橡膠與傳統的N95面罩相比,它需要的N95材料要少得多。 有外國科研人員他們早就認識到的關鍵因素之一是,為了滿足需求,他們將自己真正限制在可以擴展的方法上。他們還希望最大限度地提高系統的可重用性,並且希望可以採用許多不同的方式對系統進行消毒。rdquo; 根據外國科研人員的反饋,並且正在努力建立可以支持大規模生產的公司。 全球科研研究新口罩容易殺菌 全球醫護人員佩戴的N95口罩是由專門設計用來過濾微小病毒顆粒的聚丙烯纖維製成的,以防止暴露於SARSCoV2和其他病毒。理想情況下,全球醫護人員每次見到不同的病人時都應換上新的口罩,但是由於這些口罩的短缺,醫生和護士不得不將其佩戴的時間超過本應佩戴的時間。 近幾個月來,許多醫院已開始使用過氧化氫蒸汽對N95口罩進行消毒,單個口罩最多可使用20次。但是,此過程需要到處都沒有的專用設備,即使採用此過程,一個口罩也只能戴一天。 全球科研團隊著手設計一種可以安全消毒並重複使用多次的口罩。 外國有科研團隊使用矽橡膠(矽酮烤盤中使用的材料以及其他產品),因為它非常耐用。液態矽橡膠容易使用注射成型法成型為任何形狀,這是一種高度自動化的過程,可以快速生成產品。 口罩以3M 1860型N95口罩的形狀為基礎,這種口罩通常在全球各醫院使用。 大部分面罩由矽橡膠製成,並且還可以容納一兩個N95過濾器。這些過濾器設計為在每次使用後都要更換,而其餘的口罩可以進行消毒和重複使用。 採用這種設計,可以將濾鏡彈出,然後在使用後丟棄。與N95口罩相比,您所丟棄的材料要少得多。rdquo; 全球研究人員對有機矽口罩測試了幾種不同的滅菌方法,包括將其通過高壓滅菌器(蒸汽滅菌器),將其放入烤箱中以及將其浸泡在漂白劑和異丙醇中。他們發現滅菌後,有機矽材料未受損。 適合測試 為了測試口罩的舒適性和貼合性,外國研究人員現在正在研究口罩的第二種版本,他們希望使這種面具更舒適,更耐用。他們還計劃進行其他實驗室測試,以測量口罩過濾病毒顆粒的能力。 由於過去一個月美國許多地區的Covid19病例激增,這些地區的醫院面臨口罩短缺的可能性。在世界某些地區,還需要更多的口罩,而這些口罩沒有過氧化氫滅菌所需的設備。 我們明白在疫苗流行之前,Covid確實不會消失,未來無論是在醫療保健場所還是在普通公眾中,始終都需要口罩。 (圖片作者:澳門資深攝影家 高影陳)

Spring Data Jpa 自動化的選擇 - Code First
科技新知
MacauYeah・2025-01-22

Code First vs Database First 在早期SQL資料庫盛行的年代,在設計要使用資料庫儲存資料時,很經常遇到一個策略選擇的問題Code First vs Database First 這兩個策略的差異可能越來越講不清,筆者也找了一些現時網路上的講法。 Code First 先從寫程式的角度出發,設計數據模型,再使用工具把你程式碼中的數據模型類Class,生成一個對應用SQL資料庫的表Table,自動編做好對應的數據結構Schema。這樣你在設計時,以程式設計為主導,方便熟悉程式的人使用。這常見於第一手開發設計,因為資料都是第一次收集和儲存,考慮收集程式的運作最為實際。 Database First 先從SQL資料庫的儲存、取用資料的方式出發,先用SQL成生Table及Schema,再轉變成為程式碼中的數據模型。這樣的資料庫在日後作分析用途時,比較簡單易懂,方便使用熟悉SQL的人去使用。這也常見於二次開發程式,因為這樣可以確保不會錯誤地破壞原有資料庫。 那麼筆者為何講這兩個差異越來越講不清?那是因為現在的資料庫不能單純地只考慮初次或二次開發問題,而是需要考慮多個系統協調運行的問題。 多系統共享協定 Database First 因為隨著資料系統發展,有些資料會作為數據源出現或用作共享媒界,如果一定要對設計策略作分類,在多系統協調運作下,這些應該叫使Database First。不論它們是SQL還是NoSQL資料庫,我們的程式碼都要為這個預先定義好的數據結構作出妥協。不論使用工具,還是人為分析,都要把共享的數據結構轉換成自己程式中的數據模型。 即使不是多系統協調運作,有時候因為要移植系統,但同時又要令兩個系統版本相容。新系統也是被逼使用Database First的方式設計。 自動化考量 Code First 前述我們講到,很多時候我們也是從Database First的方式思考。不過筆者就這個Database First,也弄到滿身傷痕。 首先,拋開工具轉換的誤差,我們人為的把共享數據轉化為數據模型,共享數據有時會有一些先天的缺陷,例如 資料沒有設計Primay Key 主鍵,唯一鍵、日期時間的定義不明確等。面對一些意義不明的數據來源,要整合確實很要命。而且二次開發中,不可能100%重用原有的資料庫結構,很多時都會加入新的欄位或更多表格去計數。一旦加入新欄位,在團隊多人開發中,那麼使用唯一的共享開發環境,就變很易有程式碼上的衝突。 若需要多人開發,各人有一個Code First的開發用資料庫,是很必要的。這也可以在系統正式升級前,對比開發中資料庫及舊資料庫的結構,觀看它們之間的差異,評估升級的風險。 也許Code First並不是重點,重點是可以隨時建立一個測試用的資料庫,這才方便合作開發。自動化的地方,不單只限於數據結構,範例資料也該是如此。如果有維繫一個初始範例資料,可以在有需要時自動生成,對於多變的環境一定有很幫助。 現時,筆者基本上都會人為檢視資料庫,人工對照編寫程式中的資料結構即是人工的Database First,並確保那時程式再次經自動化生成的測試用資料庫,並沒有失真即是Code First。至於範例資料,初期筆者也只使用SQL生成,但後期因為資料結構開始複雜,筆者也暫暫使用程式碼生成,雖然工作量會多了,但對於資料庫升級、品牌更換,這是很有效的手段,程式碼升級測試也更順暢,絕比SQL生成更易維護。 Ref Code First vs Database First httpsbuiltin.comarticlescodefirstvsdatabasefirstapproach

為程所困-是什麼讓你不想寫自動化測試?
科技新知
MacauYeah・2025-01-08

測試場 VS 自動化測試 筆者一直地更新自己過去所編寫的程式,很恐怖的是,那時的自己很少思考過怎樣寫測試Test Case。致使每次做更新時,都膽戰心驚,要手動建立測試場,人肉去測試每個可能有受影響的地方。在那些年的時候,有能力自己搭建測試場,已經是萬幸。但當面對一些要長期維護的程式,測試場的人肉測試並不是一個有效的方法,一來費時間,二來人腦記憶並不可靠。單靠自己去想想那些地方受影響,再測試,某程度是在挑戰人腦的記憶上限。如果是團隊合作,就更麻煩,你以為修改不會影響到其他人,結果卻是翻天覆地。 所以為求長治久安,編寫自動化測試,是有必要的。這些自動化測試,都算是回歸測試,每次程式有任何地方改動,都確保所有自動化測試被通過。理想始終是理想,但實際操作又會遇到怎麼的問題? 以筆者剛更新的程式為例,難以測試主要是當初沒有想過要測試這件事,所以程式結構通常是【連續順序】地執行。想分段測試?除非先重構。 Function中太多自己創建的Object 回顧自己的程式,初期編寫時,總會我手寫我心,每想要創建任何資源,在java中就會使用 new 字眼,或是自行呼叫某些 builder 類來取得資源,這是其中一個令自己無法寫測試的原因。 我們要想想,這些資源,是不是自己Function中所關心的核心。如果這個資源是被直接回傳的,我們要保留,如果它是HttpClient,只是要來獲取其他資源的媒介,我們或許可以利用依賴注入來取得它,即是把 HttpClient 改為經呼叫方傳入。注入的好處時,我們可以在Test中,修改那些資源的行為和結果。更進一步的是,把那些資源改為 interface 的方式存取,那麼在 Test 中就能更任意地控制該資源的行為。 首次重構某些資源成為依賴注入,大部份都會影響呼叫方,很多地方都要重寫。不論使用constructor injection, setter injection, annotation injection 等,上傳呼叫方,或多或少都會要加減改變參數。極致地,我們把構建都交給Program 框架去做,例如Spring Boot中,各種資源,都交給框架去自動配致。當然,這種做法的學習成本高,除錯成本也高。 【注入】其實是想在控作那些資源,在測試中運行得到固定的行為。使用前述的HttpClient例子,當我們業務邏輯是先訪問外部Web API,再根據結果做處理,那麼我們測試時,就會想模擬Web Api的結果。如果要做到自動化測試,最強硬的手段,就修改自己的HttpClient,模疑給出固定結果。 想要做到這種,在傳統的Java中,我們需要透過進一步抽離Interface去做。但這樣做很累,所以筆者通常會用如Mockito的程式庫,去修改HttpClient的行為。有興趣直接看程式碼的讀者,可以去看 github 。 當然,上述的 HttpClient 例子,使用測試場也有可做測試,自己再去模擬那些Web Api的回傳,有些情況下,這樣會更真實,但大家就必需好好定義測試場的行為。因為測試場可能與團隊的其他成員所共用,有機會其他人可能想要更多互動的測試方式,而非固定的結果。但並上非固定結果的測試場,自動化要測試的可控度就減少。

Docker 來源掃瞄 - Docker Image Scan
科技新知
MacauYeah・2024-12-19

當網安要求越來越高時,我們也要留心 docker image 的來源是不是有漏洞問題。 docker hub 本身就已經有一些安全掃瞄報告,以 nginx 的 1.27.3 版本為例, docker hub nginx 1.27.3 , docker hub 已經列出相當多的CVE漏洞。 不過對於不公開的 docker image ,安全描瞄可是要收費的。作為小團隊,可能想先尋求一些簡單的免費方案。如果你想同樣的需求,可能Trivy會幫到你。 Trivy Trivy 是一個用於描瞄軟件版本依賴或設定檔是否引用到一些有漏洞問題的軟件,它也能檢測 docker image 是否有漏洞或錯誤設定的問題。而且更好的是, Trivy 本身亦有 Docker Image 版本,我們就不用煩惱怎樣弄一個 Trivy 的執行環境,只要可以運行 docker ,有網路就可以了。但使用 Docker Image 版的 Trivy 有一個額外要求,就是它要有主機上的 docker.sock 權限。 描瞄的指令如下,其中 docker.sock 就是為了讓 containers 內部的程式可以存取主機的 docker daemon , .cache 則是為了方便暫在下載資源。 上面故意用 nginx 的兩個同版本號不同平台的 docker image,其實就是為了引出一些潛在問題。nginx 預設是使用的debain OS的,在筆者寫文章的當下,已經更新到最近的 image ,但始終有一大部份可能的漏洞。反觀 alpine OS 版本,就找不到這麼多問題。 這是因為 alpine 預設安裝的依賴較少,所以找到的漏洞也少。正所謂,做多錯多,唔做唔錯(大誤)。這其實有好有不好,因為在發生問題時,在 alpine 下可能連基本的除錯工具都沒有。除非大家有完整測試,或者對 alpine 有相當的認識,你才會選擇一個非官方預設的版本。但就以事論事,引用較少的依賴,長久之下的確是不會有那麼多隱患。大家如果有條件,也可以試試 alpine 或其他版本。 前一節我們可以看到,Trivy需要經過 socket 的方式才能存取主機上的 container daemon 操作權。但 podman 作為一個不主張 daemon daemon less,亦主張不需要 root rootless,那麼它該怎樣執行? 其實podman也有user層面上的 socket,而且 trivy 也有對應的方式去轉用第三方 socket 有點像使用遠端主機 socket,但官方並未宣佈正式支援遠端的方式。 具體使用方式,筆者亦已在 steam deck 上測試,使用方式如下。不過因為 steam deck 預設沒有 root,筆者就省略 cache 指令,免得之後要有權限問題要手動清理。 Ref Podman socket activation Trivy Support for rootless podman

Spring Data 關聯型態 01
科技新知
MacauYeah・2024-07-16

筆者身邊的朋友,首次接觸 ORM 的關聯型態時都會覺得很難,筆者自己也是。但在好好地理順它的設計時,就會覺得其實很簡單。 因為篇輻很長,我們先以Code First的角度,先體驗一下ORM程式讀取的便捷性,以及解決一個常見的序列化問題。 雙向存取 例如一個Parent,有好幾個Child @Entity public class Parent ... Parent Primay Key @OneToManymappedBy=quot;parentquot; List children = new ArrayList; TODO add remove @Entity public class Child ... Child Primay Key @ManyToOne Parent parent; 上述的寫法很簡潔,ORM會為你自動加入join column,處理關聯的載入。在讀取Parent時,它的所有Children就可以直接在Java層面讀取,在讀取Child時,它的Parent也隨時取得。也就是,開發人員只要經SQL準備其中一方的資料,另一方並不需要手動準備,它就可以自動按需載入。 RESTFul API 坑雙向存取 Spring Data在Java層面的雙向存取,已經做到很方便。但經常坑到我們的是Spring Data與RESTFul API的混合應用。當我們嘗試經API回傳我們的Parent Json時,API會很聰明地把關聯的Children也變成Json回傳。但他也會把child中的parent不斷重複變成json,變成無限輪迴。 坊間有兩種不同的解決方案,可以防止無限輪迴。 讓Json可以認得已經序列化的元素。@JsonIdentityInfo 讓Json只可以單向序列化serialization。@JsonManagedReference, @JsonBackReference, @JsonIgnore 筆者兩個方向都試過,但首個方法並不通用,至少它不能算是一般常見的無腦Json結構。它需要伺服器、客戶端都懂這如何經IdentityInfo認得重複出現的元素。 而單向序列化,是筆者現時的通用解。在設計RESTFul READ API時,筆者就會決定到底是Parent自動回傳Child,還是Child自動回傳Parent。決策的考慮因素,主要在於是否可以簡化Client的API調用次數。通常從Parent出發,自動回傳Child,可以節省API調用。但如果是選項性的結果List of Value,就倒過來。有時候,遇著API需要雙向設計,就只好自己設計DTO資料傳輸對象 Data transfer object, DTO。 例如Parent API,就原封不動回傳原本的元素 @Entity public class Parent ... Parent Primay Key @OneToManymappedBy=quot;parentquot; List children = new ArrayList; @Entity public class Child ... Child Primay Key @ManyToOne @JsonIgnore Parent parent; Child API,就反過來引用。 public class ParentDTO ... Parent Other fields except children public class ChildDTO ParentDTO parent; ... Child Other fields 這種DTO,看起來很麻煩。但其實Spring有提供一個簡便的複制DTO功能,它可以把自動複制兩個class中有同一名稱、同一型別的欄位到另一個class上,不需要逐個欄位明文寫出來。 BeanUtils.copychild, childDTO; BeanUtils.copyparent, parentDTO; childDTO.setParentparentDTO 因為child、childDTO中的parent欄位型別不同,BeanUtils.copy會自動忽略,其他欄位就會自動複制。 註 其實古早的網頁系統設計,DTO的概念一直存取。只是現在RESTFul API的流行,很多框架已經提向便捷的Json轉換。若然平時只需Json單向存取,筆者還是省略DTO的建立。

Spring Boot - Maven Cheat sheet
科技新知
MacauYeah・2024-01-12

基礎 刪除所有結果,全部重新編譯 mvn clean compile 跑起用Spring boot寫的main class,運行Spring boot context。 mvn springbootrun # or mvn clean compile springbootrun 執行測試用例,預設只會測試test資料夾下以某些命名規則的class例如class名以Tests或Test結尾的class,其他命名規則筆者未有能力一一驗證 mvn test # or mvn clean compile test 多Profile、多組件、多測試 使用P指定編譯時的選用pom.xml中的project.profiles.profile參數。也可以用此來傳遞到spring profile,使得編譯後的spring war預設選擇特定profile。 mvn clean compile PmvnProfile # or mvn clean compile springbootrun PmvnProfile 使用pl限定mvn指令只對某個子組件生效,但有時候子組件之間也有引用關係,所以需要再額外加上am參數alsomake mvn clean compile springbootrun pl SUBMODULE_NAME am 使用Dtest=限定只執行某個class的測試用例,或單個測試函數。可以無視class名的命名規則 mvn test Dtest=TEST_CLASS_NAME # or mvn test Dtest=TEST_CLASS_NAME#TES_METHOD_NAME 若屬於多組件情況下,其他子模組找不到同樣名稱的測試,會測試失敗。需要再加上Dsurefire.failIfNoSpecifiedTests=false mvn test pl SUBMODULE_NAME am Dtest=TEST_CLASS_NAME Dsurefire.failIfNoSpecifiedTests=false # or mvn test pl SUBMODULE_NAME am Dtest=TEST_CLASS_NAME#TES_METHOD_NAME Dsurefire.failIfNoSpecifiedTests=false 打包 在本機電腦中,把java變成jar或者war。通常用於自行發佈的環境中。 mvn package 有時特定Profile沒法成功執行測試用例,或者你認為有些測試問題不影響使用,需要跳過package中的test。 mvn package Dmaven.test.skip=true # won't compile test folder mvn package DskipTests=true # compile, but won't run 例外情況 強行把一個第三方jar,種到本機電腦中的.m2repository # copy from httpsmaven.apache.orgguidesminiguide3rdpartyjarslocal.html mvn installinstallfile Dfile= DgroupId= DartifactId= Dversio