成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

java安全編碼指南之:表達式規則說明

瀏覽:6日期:2022-08-24 17:57:09

簡介

在java編寫過程中,我們會使用到各種各樣的表達式,在使用表達式的過程中,有哪些安全問題需要我們注意的呢?一起來看看吧。

注意表達式的返回值

我們在使用JDK庫的時候,一定要注意認真的讀一下JDK中方法的含義和它的返回值。

有些返回值可能表示這個操作是否成功,有的返回值可能是方法操作的結果。我們看兩個常見的例子:

public void deleteFileWrong(){ File file= new File('/tmp/www.jb51.net.txt'); file.delete(); System.out.println('File delete success!'); } public void deleteFileRight(){ File file= new File('/tmp/www.jb51.net.txt'); if(file.delete()){ System.out.println('File delete success!'); } }

先看一個文件刪除的例子,delete方法是有返回值的,所以我們在調用delete方法之后,一定要判斷一下返回值,看是否刪除成功。

再看一個常見的String中字符替換的例子:

public void stringReplaceWrong(){ String url='www.jb51.net'; url.replace('www','WWW'); System.out.println('replaced url...'+url); } public void stringReplaceRight(){ String url='www.jb51.net'; url=url.replace('www','WWW'); System.out.println('replaced url...'+url); }

我們要記住,String是不可變的,所以它的replace方法,會返回一個替換過后的String,但是原String是不變的,所以我們需要將返回值重新賦值。

注意避免NullPointerException

NullPointerException應該是最最常見的運行時異常了。怎么避免這個異常呢?

我們要做的就是在調用object的方法時候,一定要判斷這個object是不是為空。

在JDK8之后,我們引入了Stream操作:

public void streamWrong(Collection<Object> collection){ collection.stream().filter(obj->obj.equals('www.jb51.net')); }

Stream操作的過程中,我們需要注意stream中的元素是否為空。

有時候,我們可能覺得已經判斷是為空了,但是條件判斷不準確,導致未知的異常,看下面這個例子:

public int countWrong(Collection<Object> collection, Object object){ int count=0; if(collection ==null){ return count; } for(Object element: collection){ if((element ==null && object== null) || element.equals(object)){ count++; } } return count; }

這個例子是用來查找collection中到底有多少元素和object相同,如果兩者都為空,也記為相同。

但是上面的例子有一個漏洞,它沒有考慮element ==null 而 object !=null的情況,所以會導致NullPointerException的生成。

我們需要這樣修改:

public int countRight(Collection<Object> collection, Object object){ int count=0; if(collection ==null){ return count; } for(Object element: collection){ if((element ==null && object== null) || (element !=null && element.equals(object))){ count++; } } return count; }

數組相等的判斷

如果我們需要比較兩個數組是否相等,其實我們想比較的是兩個數組中的元素是否相等。

我們知道數組是一個特殊的Object,那么數組對象也有一個equals方法,考慮下面的例子:

public boolean compareWrong(){ int[] array1 = new int[10]; int[] array2 = new int[10]; return array1.equals(array2); }

返回的結果是false,因為數組直接使用了Object中定義的equals方法,我們看下該方法的定義:

public boolean equals(Object obj) { return (this == obj); }

可以看到,該方法比較的是兩個地址是否相等。所以我們的到了false結果。

其實,我們可以使用Arrays.equals工具類中的方法來進行兩個數組的比較:

public boolean compareRight(){ int[] array1 = new int[10]; int[] array2 = new int[10]; return Arrays.equals(array1, array2); }

基礎類型的封裝類間的比較

在java中,我們知道有一些基礎類型像boolean, byte,char, short, int他們會有相對應的封裝類型:Boolean,Byte,Character,Short,Integer等。

我們可以直接將基礎類型的值賦值給封裝類型,封裝類型會自行進行轉換。

考慮下面的例子:

Boolean boolA=true; Boolean boolB=true; System.out.println(boolA==boolB);

結果是多少呢?

答案是true。為什么兩個不同對象的比較會是true呢?

在回答這個問題之前,我們看一下字符串的比較:

String stringA='www.jb51.net'; String stringB='www.jb51.net'; System.out.println(stringA==stringB);

這個我們大家應該都知道,因為String有一個字符串常量池,直接從字符串常量構建的String對象,其實是同一個對象。

同樣的對于Boolean和Byte來說,如果直接從基礎類值構建的話,也是同一個對象。

而對于Character來說,如果值的范圍在u0000 to u007f,則屬于同一個對象,如果超出了這個范圍,則是不同的對象。

對于Integer和Short來說,如果值的范圍在-128 and 127,則屬于同一個對象,如果超出了這個范圍,則是不同的對象。

再考慮下面的例子:

Boolean boolA=true;Boolean boolC=new Boolean(true);System.out.println(boolA==boolC);

輸出的結果是false,因為boolC使用了new關鍵字,構建了一個新的對象。

集合中類型不匹配

現在java集合可以通過指定類型,從而只存儲特定類型的對象。考慮下面的一個例子:

public void typeMismatch(){ HashSet<Short> shortSet= new HashSet<>(); for(int i=0;i<10;i++){ shortSet.add((short)i); shortSet.remove(i); } System.out.println(shortSet.size()); }

上面代碼我們定義了一個Short的集合,然后將0-9添加進去,接著我們又調用了remove方法把i從集合刪除。

但是最后輸出結果是10,表明我們并沒有刪除成功。為什么呢?

看下HashSet的remove方法:

public boolean remove(Object o) { return map.remove(o)==PRESENT; }

remove方法的參數是Object,我們傳入的i是int類型的,跟short不匹配,所以導致刪除失敗。

我們需要這樣修改:

public void typeMatch(){ HashSet<Short> shortSet= new HashSet<>(); for(int i=0;i<10;i++){ shortSet.add((short)i); shortSet.remove((short)i); } System.out.println(shortSet.size()); }

Asset的副作用

我們會使用Asset語句在代碼中做調試使用,在使用的過程中需要注意Asset語句不要對系統的業務邏輯產生副作用,也就是說即使Asset語句不運行,也不會修改代碼的業務邏輯。

看下面的例子:

public void assetWrong(ArrayList<Integer> list){ assert list.remove(0)>0; }

上的代碼我們從list中刪除第一個元素,并判斷刪除的元素是否大于0.

上面的代碼如果assert語句不執行的話,會導致業務邏輯也不執行,所以需要修改成下面這樣:

public void assetRight(ArrayList<Integer> list){ int result=list.remove(0); assert result>0; }

本文的例子:

learn-java-base-9-to-20/tree/master/security

補充知識:Slow HTTP Denial of Service Attack 漏洞解決

解決漏洞需要修改tomcat conf 下 server.xml 文件

<Connector port='8080' protocol='HTTP/1.1' connectionTimeout='2000' redirectPort='8443' URIEncoding='UTF-8'/> connectionTimeout='20'

以上這篇java安全編碼指南之:表達式規則說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
亚洲欧美日韩系列| 亚洲欧美日韩国产综合精品二区| 欧美成人69av| 欧美在线观看视频一区二区 | 欧美日韩另类国产亚洲欧美一级| 中文字幕乱码久久午夜不卡| 99re6这里只有精品视频在线观看| 91黄视频在线| 秋霞午夜鲁丝一区二区老狼| 欧美午夜免费影院| 国产欧美日产一区| 不卡av免费在线观看| 亚洲精品一区二区三区精华液| 精品一区二区三区久久| 欧美精品777| 日韩制服丝袜av| 久久久av水蜜桃| 亚洲精品中文在线影院| 亚洲伦理精品| 亚洲视频一区在线| 尤物在线精品| 亚洲精品视频在线观看免费| 午夜精品电影| 自拍偷在线精品自拍偷无码专区| 成人高清在线视频| 久久免费国产精品| av电影在线观看一区| 久久综合狠狠综合久久综合88| 国产米奇在线777精品观看| 9191久久久久久久久久久| 狠狠色丁香久久婷婷综合_中| 欧美一区二区三区免费视频| 久久机这里只有精品| 这里只有精品99re| 成人免费高清视频在线观看| 欧美精品一区二区三区很污很色的| 99国产精品久久久久久久久久久| 精品成人免费观看| 国产综合亚洲精品一区二| 久久久久久一级片| 亚洲一二区在线| 成人欧美一区二区三区小说| 在线亚洲免费| 亚洲地区一二三色| 欧美三级在线播放| 亚洲高清免费在线| 欧美在线视频不卡| 国产一区二区在线观看免费| 在线成人午夜影院| 成人国产一区二区三区精品| 日韩精品一区二| 农村妇女精品| 国产精品网站在线观看| 国产精品推荐精品| 亚洲高清免费视频| 欧美三级欧美一级| 国产精品综合一区二区三区| 精品国产乱码久久| 欧美日韩亚洲三区| 亚洲综合色自拍一区| 欧美亚洲禁片免费| 国产成人免费视频| 成人欧美一区二区三区小说| 国产欧美一级| 国产综合成人久久大片91| 精品少妇一区二区三区在线视频| 你懂的网址国产 欧美| 一区二区三区精品在线| 久久久久久夜| 成人理论电影网| 欧美高清在线精品一区| 香蕉免费一区二区三区在线观看| 日韩av一级片| 久久午夜国产精品| 在线播放日韩| 精品一区二区在线免费观看| 欧美国产在线观看| 国产精品久久久久久久久久直播| 精品一区二区三区在线视频| 日韩欧美国产午夜精品| 最新国产乱人伦偷精品免费网站| 日韩精品电影在线观看| 久久久久久久久久久久电影| 麻豆久久婷婷| 国产成人在线影院| 亚洲人成人一区二区在线观看 | 国产乱码精品| 国产成人精品免费网站| 亚洲国产高清不卡| 色av成人天堂桃色av| 91浏览器打开| 日本成人在线看| 中文字幕免费一区| 欧美日韩国产一级片| 影音先锋久久精品| 国产盗摄视频一区二区三区| 国产精品久久777777| 欧美在线观看视频一区二区| 欧美不卡福利| 另类小说一区二区三区| 中文字幕在线不卡国产视频| 9191久久久久久久久久久| 国产欧美亚洲一区| bt欧美亚洲午夜电影天堂| 午夜精品福利在线| 国产欧美日本一区视频| 欧美私人免费视频| 日韩亚洲国产欧美| 成人久久视频在线观看| 五月综合激情日本mⅴ| 欧美国产成人精品| 欧美一级在线观看| 久久久久在线| 色综合久久综合| 久久成人麻豆午夜电影| 亚洲日本在线视频观看| 日韩精品中文字幕在线一区| 久久精品日产第一区二区三区| 国产精品一区二区在线播放| 亚洲妇女屁股眼交7| 久久久久久久久蜜桃| 欧美主播一区二区三区美女| 亚洲精选在线| 91麻豆福利精品推荐| 美女国产一区二区三区| 亚洲一区二区三区精品在线| 久久久一区二区三区捆绑**| 欧洲视频一区二区| 在线观看日韩av电影| 国产99久久久精品| 视频在线观看一区| 最新久久zyz资源站| 91精品国产综合久久久久久漫画 | 日韩网站在线| 欧美日韩亚洲一区二区三区在线 | 欧美午夜精品一区二区三区| 国产欧美大片| 欧美视频网站| jizzjizzjizz欧美| 国产精品香蕉一区二区三区| 美腿丝袜亚洲三区| 肉丝袜脚交视频一区二区| 亚洲蜜臀av乱码久久精品蜜桃| 日韩欧美视频在线| 欧美日韩国产另类一区| 欧美中文字幕| 一本色道久久综合亚洲二区三区| 欧美激情国产日韩| av日韩在线网站| 黑人巨大精品欧美一区| 午夜久久福利影院| 综合欧美一区二区三区| 国产精品私人自拍| 久久综合色8888| 欧美大片一区二区| 日韩一区二区三免费高清| 欧美日韩国产精品成人| 色哟哟一区二区| 亚洲欧美日韩在线综合| 一本色道久久综合| 亚洲高清自拍| 激情久久婷婷| 国产精品国产精品| 国产精品大片| 91浏览器入口在线观看| 91在线视频18| 波多野结衣中文字幕一区二区三区 | 欧美一区二区三区婷婷月色| 欧美亚洲综合一区| 欧美日韩精品高清| 欧美日产国产精品| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 国产伦精品一区二区三区视频孕妇| 好吊视频一区二区三区四区| 丁香婷婷综合色啪| 国产成人av电影在线观看| 国产成人精品一区二区三区网站观看| 国产老肥熟一区二区三区| 国内精品写真在线观看| 国产精品自拍av| 懂色一区二区三区免费观看| 国产不卡高清在线观看视频| 成人免费视频一区| 91视频观看视频| 国产一区再线| 999亚洲国产精| 免费亚洲电影| 91电影在线观看| 欧美日韩国产天堂| 日韩一区二区影院| 欧美mv日韩mv国产网站| 久久这里只精品最新地址| 欧美国产成人精品| 日韩一区在线免费观看| 亚洲综合男人的天堂| 三级成人在线视频| 韩国女主播一区二区三区| 高清久久久久久| 欧美精品一区二区三区在线看午夜 | 久久成人资源|