簡體   English   中英

無法理解這段Java代碼

[英]Can't make sense of this piece of java code

我在舊系統上工作,遇到了我無法理解的這段代碼。

String note = URLDecoder.decode(URLEncoder.encode(
                message.replaceAll("\\<.*?\\>", ""),
               "UTF-8").replace("%0D%0A", "<br>"), "UTF-8");

這是做什么的,為什么要先編碼然后再解碼。 僅供參考:此“消息”被附加到發送的電子郵件中。

輸入的第一個替換項是用<br>標簽替換CRLF (回車符和換行符)。
第二個replaceAll刪除所有標簽(如<tag> )。

UTF-8是字符集編碼,用於將原始字節解碼/編碼為實際字符。 WWWC(萬維網聯合會) 指出應使用UTF-8。

從編碼的角度來看,分解為以下代碼可能有助於更好地理解:

    String updatedMessage = message.replaceAll("\\<.*?\\>", "");
System.out.println(updatedMessage );

    String encodedMessage = URLEncoder.encode(updatedMessage ,"UTF-8");
System.out.println(encodedMessage );

    String updatedEncodedMessage = encodedMessage .replace("%0D%0A", "<br>");
System.out.println(updatedEncodedMessage );

    String note = URLDecoder.decode(updatedEncodedMessage ,"UTF-8");
System.out.println(note );

沒有涉及正則表達式,只是一些字符串替換。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM