幾乎每過一段時間,iOS上就會出現一些神秘消息“代碼”,發送相關文本將導致系統或者聊天APP崩潰。筆者還記得去年在微信上還出現了,發送“15個句號”導致某些品牌的手機卡死的BUG。其中這些多與系統或者程序的文本渲染器有關,而Youtube UP主Tom Scott發現,安卓上也中招了。
簡單來說,如圖所示的這個“黑點”表情,發送和接收都沒有問題,但當點擊它的時候,就會造成當前程序卡死崩潰,老外反饋主要是Whatsapp。
Tom Scott分析后發現,這又是一次Unicode的把戲。Unicode是計算機之間傳輸文本的國際標準,包含數以萬計的字符,并且支持N種語言。
不過,在Unicode之中也有一些隱形的字符,比如定義寬度、定義從左向右(從右向左,阿拉伯/希伯來語使用)、定義連接詞、定義高低音的代碼。這個黑點的“詭計”就在于,使用OBJ編碼后發現,我們看到的黑點之后其實還有一長串字符,編造者使用寬度為0、且定義左右順序的字符進行了隱藏。
當你點擊時,安卓的文本渲染器需要判斷你點擊的是哪個,這個過程存在BUG,導致程序崩潰。
所以,嚴格來講,這是安卓系統的BUG,理論上對于任何安卓消息應用都有效,不僅僅是Whatsapp;第二,其實黑點只是創造者利用的一個表情而已,如果掌握了原理,這個表情可以任意替換。
-
iOS
+關注
關注
8文章
3396瀏覽量
150843 -
安卓
+關注
關注
5文章
2136瀏覽量
57410 -
BUG
+關注
關注
0文章
155瀏覽量
15687
發布評論請先 登錄
相關推薦
評論