javascript - 求一套有關于IP地址的JS正則!
問題描述
例如想要匹配這種
22.22.22.0/1633.33.33.1/24
這樣的正則改怎么寫?求指教
這樣好像可以
/((2[0-4]d|25[0-5]|[01]?dd?).){3}(2[0-4]d|25[0-5]|[01]?dd?)/[0-2][0-4]/
問題解答
回答1:《正則表達式必知必會》里面給的。自己寫的話容易有紕漏
^((0|1[0-9]{0,2}|2[0-9]{0,1}|20-4|25[0-5]|3-9{0,1}).){3}(0|1[0-9]{0,2}|2[0-9]{0,1}|20-4|25[0-5]|3-9{0,1})(?(/)/([0-9]|1-2|3[0-2])|)$
回答3:new RegExp(/([0-9]{1,3}.{1}){3}[0-9]{1,3}/)
回答4:你可以直接在網上找到一個匹配IP的正則,但是網上的也不一定對,也不好做驗證,那么我們就自己來寫一個。
有個數(shù)字范圍生成正則的工具。【工具可以網上找】ip規(guī)則0-255.0-255.0-255.0-255/0-32
0-255([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])
0-255.([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]).
重復3次(([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]).){3}
再拼接一次0-255(([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]).){3}([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])
0-32([0-9]|[12][0-9]|3[0-2])
全部拼接(([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]).){3}([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])/([0-9]|[12][0-9]|3[0-2])
添加首位分隔符^(([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]).){3}([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])/([0-9]|[12][0-9]|3[0-2])$或者(?^|s)(([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5]).){3}([0-9]|[1-8][0-9]|9[0-9]|1[0-9]{2}|2[0-4][0-9]|25[0-5])/([0-9]|[12][0-9]|3[0-2])(?:s|$)
分割符號根據(jù)實際情況更換
如果不添加分隔符,則33.33.33.1/24會拼匹配成33.33.33.1/2或者 99933.33.33.1/24也會被匹配
相關文章:
1. mysql - 如何減少使用或者不用LEFT JOIN查詢?2. mysql - jdbc的問題3. python - 編碼問題求助4. python - 我在使用pip install -r requirements.txt下載時,為什么部分能下載,部分不能下載5. 視頻文件不能播放,怎么辦?6. 網頁爬蟲 - python 爬取網站 并解析非json內容7. python - Scrapy存在內存泄漏的問題。8. mysql - 分庫分表、分區(qū)、讀寫分離 這些都是用在什么場景下 ,會帶來哪些效率或者其他方面的好處9. node.js - nodejs開發(fā)中常用的連接mysql的庫10. mysql - 千萬級數(shù)據(jù)的表,添加unique約束,insert會不會很慢?
