日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

java安全編碼指南之:表達(dá)式規(guī)則說明

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

簡介

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

注意表達(dá)式的返回值

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

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

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方法是有返回值的,所以我們在調(diào)用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應(yīng)該是最最常見的運(yùn)行時異常了。怎么避免這個異常呢?

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

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

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

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

有時候,我們可能覺得已經(jīng)判斷是為空了,但是條件判斷不準(zhǔn)確,導(dǎo)致未知的異常,看下面這個例子:

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的情況,所以會導(dǎo)致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; }

數(shù)組相等的判斷

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

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

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

返回的結(jié)果是false,因?yàn)閿?shù)組直接使用了Object中定義的equals方法,我們看下該方法的定義:

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

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

其實(shí),我們可以使用Arrays.equals工具類中的方法來進(jìn)行兩個數(shù)組的比較:

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

基礎(chǔ)類型的封裝類間的比較

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

我們可以直接將基礎(chǔ)類型的值賦值給封裝類型,封裝類型會自行進(jìn)行轉(zhuǎn)換。

考慮下面的例子:

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

結(jié)果是多少呢?

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

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

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

這個我們大家應(yīng)該都知道,因?yàn)镾tring有一個字符串常量池,直接從字符串常量構(gòu)建的String對象,其實(shí)是同一個對象。

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

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

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

再考慮下面的例子:

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

輸出的結(jié)果是false,因?yàn)閎oolC使用了new關(guān)鍵字,構(gòu)建了一個新的對象。

集合中類型不匹配

現(xiàn)在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添加進(jìn)去,接著我們又調(diào)用了remove方法把i從集合刪除。

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

看下HashSet的remove方法:

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

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

我們需要這樣修改:

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語句在代碼中做調(diào)試使用,在使用的過程中需要注意Asset語句不要對系統(tǒng)的業(yè)務(wù)邏輯產(chǎn)生副作用,也就是說即使Asset語句不運(yùn)行,也不會修改代碼的業(yè)務(wù)邏輯。

看下面的例子:

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

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

上面的代碼如果assert語句不執(zhí)行的話,會導(dǎo)致業(yè)務(wù)邏輯也不執(zhí)行,所以需要修改成下面這樣:

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

本文的例子:

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

補(bǔ)充知識: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安全編碼指南之:表達(dá)式規(guī)則說明就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
五月激情久久| 亚洲精品大片| 国产精品欧美三级在线观看 | 国产成人免费精品| 精品美女视频| 热三久草你在线| 中文字幕一区久| 99tv成人| 国产精品色网| 蜜臀久久久久久久| 日韩av一级片| 国产精品二区影院| 国产伦精品一区二区三区视频| 国产欧美久久一区二区三区| 免费在线亚洲| bbw在线视频| 性欧美69xoxoxoxo| 一本综合精品| 国产精品第十页| 日本激情一区| 欧美不卡高清| 亚洲资源网站| 国产精品地址| 日韩精品影视| 亚洲伊人精品酒店| 国产精品一卡| 日韩精品欧美| 亚洲欧美日韩一区在线观看| 日本综合视频| 精品理论电影在线| 亚洲特色特黄| 亚洲三区欧美一区国产二区| 欧美激情综合| 欧美成人日韩| 欧美一区二区三区久久精品| 毛片在线网站| 丝袜国产日韩另类美女| 久久gogo国模啪啪裸体| 欧美午夜不卡| 国产日韩一区| 成人羞羞视频播放网站| 免费国产亚洲视频| 国产激情综合| 精品91久久久久| 国产欧美88| 亚洲高清二区| 日韩av网站在线免费观看| 精品99久久| 夜夜嗨网站十八久久| 国产伦精品一区二区三区千人斩| 色婷婷精品视频| 欧美一区在线观看视频| 久久久精品网| 国产欧美在线| 婷婷综合网站| 免费日韩一区二区三区| 日韩视频一区| 免费视频一区二区三区在线观看| 亚洲精品2区| 免费一级欧美在线观看视频 | 国产高清亚洲| 伊人久久亚洲影院| 美女久久久久久| 99综合视频| av在线最新| 国产欧美一区二区三区国产幕精品| 久久青草久久| 日韩一区二区三区精品| 99精品综合| 国产精品蜜月aⅴ在线| 精品在线99| 成人一区不卡| 国产精品夜夜夜| 日韩国产欧美视频| 欧美成人国产| 黑人精品一区| 国产区精品区| 亚洲+小说+欧美+激情+另类| 99久久夜色精品国产亚洲1000部| 国产精品久一| 蜜臀精品久久久久久蜜臀 | 久久精品三级| 蜜臀91精品一区二区三区| 中文av在线全新| 国产精品毛片视频| 亚洲免费毛片| 99热精品在线观看| 色88888久久久久久影院| 久久精品资源| 国产日韩欧美一区二区三区| 日韩中文字幕亚洲一区二区va在线 | 美美哒免费高清在线观看视频一区二区| 日本在线高清| 国产精品香蕉| 日韩av不卡一区二区| 女人av一区| 久久精品二区三区| 成人一区不卡| 福利一区二区| 精品一区二区三区在线观看视频 | 亚洲在线免费| 成人av三级| 国产精品毛片久久| 久久中文在线| 国产精品成人自拍| 欧美一区精品| 欧美日韩视频免费看| 免费成人性网站| 美女91精品| 亚洲尤物在线| 午夜宅男久久久| 日韩视频一区| 久久大逼视频| 国产亚洲在线观看| 婷婷综合亚洲| 一区在线视频观看| 亚洲免费高清| 亚洲免费中文| 日韩中文欧美在线| 首页欧美精品中文字幕| 亚洲免费在线| 亚洲综合色婷婷在线观看| 另类亚洲自拍| 亚洲理论在线| 日韩**一区毛片| 日本午夜精品一区二区三区电影| 日韩精品一级| 91精品丝袜国产高跟在线| 日韩国产精品久久久久久亚洲| 欧美日韩精品一区二区三区视频 | 国产 日韩 欧美一区| 美女网站视频一区| 国产 日韩 欧美一区| 精品在线播放| 中文亚洲免费| 日韩专区欧美专区| 日韩精品成人在线观看| 日本成人在线网站| 国产乱人伦丫前精品视频| 69堂免费精品视频在线播放| 国产精品久久久久久久久久齐齐 | 日韩精品久久久久久久电影99爱| 亚洲不卡av不卡一区二区| 久久香蕉国产| 免费观看在线综合| 欧美日韩99| 国产一区二区三区四区二区| 亚洲精品成人图区| 亚洲男女av一区二区| 亚洲精品欧美| 日韩高清欧美激情| 国产精品a级| caoporn视频在线| 色88888久久久久久影院| 午夜在线精品| 国产精品网站在线看| 成人美女视频| 欧美专区18| 国产精品mv在线观看| 日韩欧美一区二区三区免费看| 亚洲午夜精品久久久久久app| 蜜桃视频一区二区三区在线观看| 国产精品黄色| 欧美 日韩 国产精品免费观看| 蜜臀av一区二区在线免费观看| 日韩1区2区日韩1区2区| 精品72久久久久中文字幕| 亚洲天堂黄色| 国产日产精品_国产精品毛片 | 亚洲欧美久久久| 国产精品777777在线播放| 国产在线看片免费视频在线观看| 久久亚洲精品中文字幕蜜潮电影| 视频精品一区二区| 精品亚洲成人| 亚洲一区二区三区四区五区午夜 | 日韩精品91亚洲二区在线观看| 国产一区二区三区久久| 国产视频欧美| 麻豆久久久久久| 国产高清久久| 日韩国产一区二| 99久精品视频在线观看视频| 综合视频一区| 精品丝袜在线| 日本免费在线视频不卡一不卡二| 在线亚洲人成| 日本午夜精品视频在线观看| 国产91精品对白在线播放| 911精品国产| 亚洲国产一区二区三区在线播放| 国产精品sss在线观看av| 国产午夜久久| 国产精品伦理久久久久久| 蜜桃av一区二区| av高清不卡| 青青草视频一区| 一区久久精品| 国产一区二区三区四区五区传媒| 亚洲毛片网站|