电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:6日期: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)該是最最常見的運行時異常了。怎么避免這個異常呢?

我們要做的就是在調(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ù)組是一個特殊的Object,那么數(shù)組對象也有一個equals方法,考慮下面的例子:

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

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

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

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

其實,我們可以使用Arrays.equals工具類中的方法來進行兩個數(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ǔ)類型的值賦值給封裝類型,封裝類型會自行進行轉(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)該都知道,因為String有一個字符串常量池,直接從字符串常量構(gòu)建的String對象,其實是同一個對象。

同樣的對于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,因為boolC使用了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添加進去,接著我們又調(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è)務(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

補充知識: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)文章:
主站蜘蛛池模板: 组织研磨机-高通量组织研磨仪-实验室多样品组织研磨机-东方天净 传递窗_超净|洁净工作台_高效过滤器-传递窗厂家广州梓净公司 | 裹包机|裹膜机|缠膜机|绕膜机-上海晏陵智能设备有限公司 | 六维力传感器_六分量力传感器_模腔压力传感器-南京数智微传感科技有限公司 | 耐驰泵阀管件制造-耐驰泵阀科技(天津)有限公司 | 潍坊大集网-潍坊信息港-潍坊信息网 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 新材料分散-高速均质搅拌机-超声波分散混合-上海化烁智能设备有限公司 | 石膏基自流平砂浆厂家-高强石膏基保温隔声自流平-轻质抹灰石膏粉砂浆批发-永康市汇利建设有限公司 | 英国公司注册-新加坡公司注册-香港公司开户-离岸公司账户-杭州商标注册-杭州优创企业 | 上海租车公司_上海包车_奔驰租赁_上海商务租车_上海谐焕租车 | 冷却塔降噪隔音_冷却塔噪声治理_冷却塔噪音处理厂家-广东康明冷却塔降噪厂家 | 交变/复合盐雾试验箱-高低温冲击试验箱_安奈设备产品供应杭州/江苏南京/安徽马鞍山合肥等全国各地 | IP检测-检测您的IP质量| 我爱古诗词_古诗词名句赏析学习平台| 回转炉,外热式回转窑,回转窑炉-淄博圣元窑炉工程有限公司 | 粉末冶金注射成型厂家|MIM厂家|粉末冶金齿轮|MIM零件-深圳市新泰兴精密科技 | 天一线缆邯郸有限公司_煤矿用电缆厂家_矿用光缆厂家_矿用控制电缆_矿用通信电缆-天一线缆邯郸有限公司 | 青州开防盗门锁-配汽车芯片钥匙-保险箱钥匙-吉祥修锁店 | 橡胶接头_橡胶软接头_套管伸缩器_管道伸缩器厂家-巩义市远大供水材料有限公司 | 苏州防水公司_厂房屋面外墙防水_地下室卫生间防水堵漏-苏州伊诺尔防水工程有限公司 | 气动机械手-搬运机械手-气动助力机械手-山东精瑞自动化设备有限公司 | 依维柯自动挡房车,自行式国产改装房车,小型房车价格,中国十大房车品牌_南京拓锐斯特房车 - 南京拓锐斯特房车 | 三防漆–水性三防漆–水性浸渍漆–贝塔三防漆厂家 | 小程序开发公司_APP开发多少钱_软件开发定制_微信小程序制作_客户销售管理软件-济南小溪畅流网络科技有限公司 | 罗氏牛血清白蛋白,罗氏己糖激酶-上海嵘崴达实业有限公司 | 酒水灌装机-白酒灌装机-酒精果酒酱油醋灌装设备_青州惠联灌装机械 | 火锅底料批发-串串香技术培训[川禾川调官网] | 电磁流量计_智能防腐防爆管道式计量表-金湖凯铭仪表有限公司 | 福州甲醛检测-福建室内空气检测_环境检测_水质检测-福建中凯检测技术有限公司 | 郑州律师咨询-郑州律师事务所_河南锦盾律师事务所 | 上海橡胶接头_弹簧减震器_金属软接头厂家-上海淞江集团 | 深圳侦探联系方式_深圳小三调查取证公司_深圳小三分离机构 | 洗瓶机厂家-酒瓶玻璃瓶冲瓶机-瓶子烘干机-封口旋盖压盖打塞机_青州惠联灌装机械 | 色油机-色母机-失重|称重式混料机-称重机-米重机-拌料机-[东莞同锐机械]精密计量科技制造商 | 冷油器-冷油器换管改造-连云港灵动列管式冷油器生产厂家 | 二手电脑回收_二手打印机回收_二手复印机回_硒鼓墨盒回收-广州益美二手电脑回收公司 | 硫化罐-电加热蒸汽硫化罐生产厂家-山东鑫泰鑫智能装备有限公司 | MES系统-WMS系统-MES定制开发-制造执行MES解决方案-罗浮云计算 | 北京租车公司_汽车/客车/班车/大巴车租赁_商务会议/展会用车/旅游大巴出租_北京桐顺创业租车公司 | 电动车头盔厂家_赠品头盔_安全帽批发_山东摩托车头盔—临沂承福头盔 | 纸张环压仪-纸张平滑度仪-杭州纸邦自动化技术有限公司 |