我想用正则过滤JS里代码,可是老是写欠好!
好比 <script>function tt () {xffdfdfdfdfd}</script>
把所有的<script>function tt () {xffdfdfdfdfd}</script> 都删除去
<?php $html ='777444553sdg<script>function tt () {xffdfdfdfdfd}</script>gsgsdasdaad124'; $search ="/<script[^>]*?>.*?<\/script>/si"; $rr = preg_replace($search,' ',$html); echo $rr; ?>正则表达式代码:
/<script[^>]*?>.*?<\/script>/si
正则表达式教程:(你只想要功效,以下内容可以不消看了)
其实这个正则很简朴
为了匹配<script>。。</script>内容我第一时间就想到这样写
/<script>.+<\/script>/si
相信方才打仗正则的城市这样写。
因为正则的贪婪性。会导致这样的字符串也会被匹配,
如: <script>……a……</script>……<div>……</div>……<script>……b……</script>
后头我这样写
/<script>.*?<\/script>/si
已经可以匹配了。
尚有漏掉,就是 <script type="text/javascript" >这种环境没有思量
厥后看了PHP手册才知道还要这样写
/<script[^>]*?>.*?<\/script>/si
[^>]*?
是什么意思呢?
[^>] 是对>取反,也就是说,取一个字符不为">" 的字符
*?就是取0次到无限次。
整个来说是: 取0个到无限个不为“>”的字符。
对付以上例子是匹配 <script type="text/javascript" >部门
本人本领不敷只表明到这里了。有关回溯的问题今后再接头了。