您的位置:首页 > 其它

常用的正则表达式(转)

2007-09-06 09:22 218 查看

表 10.2:常用的正则表达式字段




字段 表达式 格式示例 说明


名称


[a-zA-Z'`-´s]{1,40}


John DoeO'Dell


验证名称。最多允许使用 40 个大写字母和小写字母,以及一些在名称中常用的特殊字符。此列表可进行调整。




数字




^D?(d...{3})D?D?(d...{3})D?(d...{4})$


(425)-555-0123


425-555-0123


425 555 0123


验证美国电话号码。




电子邮件


w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*


someone@example.com


验证电子邮件地址。




URL


^(http|https|ftp)://[a-zA-Z0-9-.]+.[a-zA-Z]{2,3}(:[a-zA-Z0-9]*)?/?([a-zA-Z0-9-._?,'//+&%$#=~])*$




验证 URL。




邮政编码




^(d...{5}-d...{4}|d...{5}|d...{9})$|^([a-zA-Z]d[a-zA-Z] d[a-zA-Z]d)$




验证允许使用 5 个或 9 个数字的美国邮政编码。




密码




^(?=.*d)(?=.*[a-z])(?=.*[A-Z])....{8,10}$




验证强密码。字符数必须在 8 至 10 的范围内。必须包含大小写字母和数字的组合,不能使用特殊字符。




非负整数


d+


0986


验证大于零的整数。




货币(非负数)


"d+(.dd)?"




验证正货币金额。要求小数点后有两位数字。




货币(正数或负数)


"(-)?d+(.dd)?"




验证正负货币金额。要求小数点后有两位数字。










222222222222222222222222222222222222222222222222222222222222222222222222222222222




利用正则表达式限制网页表单里的文本框输入内容:




用正则表达式限制只能输入中文:onkeyup="value=value.replace(/[^一-龥]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^一-龥]/g,''))"




用正则表达式限制只能输入全角字符: onkeyup="value=value.replace(/[^＀-?]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^＀-?]/g,''))"




用正则表达式限制只能输入数字:onkeyup="value=value.replace(/[^d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"




用正则表达式限制只能输入数字和英文:onkeyup="value=value.replace(/[W]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))"




222222222222222222222222222222222222222222222222222222222222222222222222222222222




电话号码




<asp:RegularExpressionValidator id="Regex_Tel" runat="server" ControlToValidate="TEL" ValidationExpression="(dd{1,4}-|(dd{1,4}) ?)?d{1,4}-d{4}" ErrorMessage="Tel「XXX-XXX-XXXX」或者「XXX-XXXX-XXXX」" Display="Static">*</asp:RegularExpressionValidator>




日期




<asp:RangeValidator ID="Regx_DateE" Type="Date" MinimumValue="1960/01/01" MaximumValue="2050/01/01" ControlToValidate="DateE" Display="Static" Runat="server" ErrorMessage="请输入日期">*</asp:RangeValidator>




数字,得分




<asp:RegularExpressionValidator Runat="server" ControlToValidate="P" ErrorMessage="数値" Display="Dynamic" ValidationExpression="^[1-9]d*" ID="PInt" />




222222222222222222222222222222222222222222222222222222222222222222222222222222222



http://www.romanfr.com/weblog/archives/125-yoiAE.html



一、验证类


1、数字验证内


1.1 整数


/^(-│+)?d+$/  不可以为空


/^[-+]?d*$/ 可以为空


1.2 大于0的整数 (用于传来的ID的验证)


/^d+$/


1.3 负整数的验证


/^-d+$/


1.4 整数不能大于iMax


根据上面的正则可以写出。


1.5 整数不能小于iMin


根据上面的正则可以写出。


2、时间类


2.1 短时间,形如 (13:04:06)


    function isTime(str)




...{


var a = str.match(/^(d)(?(d)2(d)$/);




if (a == null) ...{alert('输入的参数不是时间格式'); return false;}


if (a[1]>24 ││ a[3]>60 ││ a[4]>60)




...{


alert("时间格式不对";


return false


}


return true;


}




2.2 短日期,形如 (2003-12-05)


function strDateTime(str)




...{


var r = str.match(/^(d)(-│/)(d)2(d)$/);


if(r==null)return false;


var d= new Date(r[1], r[3]-1, r[4]);


return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]);


}




2.3 长时间,形如 (2003-12-05 13:04:06)


function strDateTime(str)




...{


var reg = /^(d)(-│/)(d)2(d) (d)d)d)$/;


var r = str.match(reg);


if(r==null)return false;


var d= new Date(r[1], r[3]-1,r[4],r[5],r[6],r[7]);


return (d.getFullYear()==r[1]&&(d.getMonth()+1)==r[3]&&d.getDate()==r[4]&&d.getHours()==r[5]&&d.getMinutes()==r[6]&&d.getSeconds()==r[7]);


}




2.4 只有年和月。形如(2003-05,或者2003-5)




2.5 只有小时和分钟,形如(12:03)


3、表单类


3.1 所有的表单的值都不能为空


<input onblur="if(this.value.replace(/^s+│s+$/g,'')=='')alert('不能为空!')">




3.2 多行文本框的值不能为空。


3.3 多行文本框的值不能超过sMaxStrleng


//检验文本框中内容是否超长




function CheckTextareaLength(val, max_length) ...{


var str_area=document.forms[0].elements[val].value;


if (str_area!=null&&str_area.length > max_length)




...{


alert("字段文字超长,最多可输入" + max_length +"个字符,请重新输入!";


document.forms[0].elements[val].focus();


document.forms[0].elements[val].select();


return false;


}


return true;


}


3.4 多行文本框的值不能少于sMixStrleng


3.5 判断单选框是否选择。




function CheckRadio(val,msg1,msg2)




...{


var is_radio=document.forms[0].elements[val];


var s_msg1=(msg1==null ││ msg1==""? "请选择 radio!":msg1;


var s_msg2=(msg2==null ││ msg2==""? "没有可选的 radio!":msg2;




if(is_radio)




...{


if (document.forms[0].elements[val].value != null)




...{


if (document.forms[0].elements[val].checked)




...{


return true;


}


else




...{


alert(s_msg1);


return false;


}


}


else




...{


var check_length = document.forms[0].elements[val].length;


var i_count=0


for(var i=0;i<check_length;i++)




...{


if (document.forms[0].elements[val](i).checked)




...{


i_count=i_count+1;


return true;


}


}


if(i_count==0)




...{


alert(s_msg1);


return false;


}


}


}//


else




...{


alert(s_msg2);


return false;


}




}


3.6 判断复选框是否选择.


function CheckCheckbox(val,msg1,msg2)




...{


var is_radio=document.forms[0].elements[val];


var s_msg1=(msg1==null ││ msg1==""? "请选择CheckBox!":msg1;


var s_msg2=(msg2==null ││ msg2==""? "没有可选的CheckBox!":msg2;




if(is_radio)




...{


if (document.forms[0].elements[val].value != null)




...{


if (document.forms[0].elements[val].checked)




...{


return true;


}


else




...{


alert(s_msg1);


return false;


}


}


else




...{


var check_length = document.forms[0].elements[val].length;


var i_count=0


for(var i=0;i<check_length;i++)




...{


if (document.forms[0].elements[val](i).checked)




...{


i_count=i_count+1;


return true;


}


}


if(i_count==0)




...{


alert(s_msg1);


return false;


}


}


}//


else




...{


alert(s_msg2);


return false;


}




}


3.7 复选框的全选,多选,全不选,反选


<form name=hrong>


<input type=checkbox name=All onclick="checkAll('mm')">全选<br/>


<input type=checkbox name=mm onclick="checkItem('All')"><br/>


<input type=checkbox name=mm onclick="checkItem('All')"><br/>


<input type=checkbox name=mm onclick="checkItem('All')"><br/>


<input type=checkbox name=mm onclick="checkItem('All')"><br/>


<input type=checkbox name=mm onclick="checkItem('All')"><br/><br/>






<input type=checkbox name=All2 onclick="checkAll('mm2')">全选<br/>


<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>


<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>


<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>


<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>


<input type=checkbox name=mm2 onclick="checkItem('All2')"><br/>




</form>




<SCRIPT LANGUAGE="JavaScript">


function checkAll(str)




...{


var a = document.getElementsByName(str);


var n = a.length;


for (var i=0; i<n; i++)


a.checked = window.event.srcElement.checked;


}


function checkItem(str)




...{


var e = window.event.srcElement;


var all = eval("document.hrong."+ str);


if (e.checked)




...{


var a = document.getElementsByName(e.name);


all.checked = true;


for (var i=0; i<a.length; i++)




...{




if (!a.checked)...{ all.checked = false; break;}


}


}


else all.checked = false;


}


</SCRIPT>






3.8 文件上传过程中判断文件类型


<input type=file onchange="alert(this.value.match(/^(.*)(.)(.)$/)[3])">




4、字符类


4.1 判断字符全部由a-Z或者是A-Z的字字母组成


<input onblur="if(/[^a-zA-Z]/g.test(this.value))alert('有错')">


4.2 判断字符由字母和数字组成。


<input onblur="if(/[^0-9a-zA-Z]/g.test(this.value))alert('有错')">




4.3 判断字符由字母和数字,下划线,点号组成.且开头的只能是下划线和字母


/^([a-zA-z_])([w]*)$/g.test(str)




4.4 字符串替换函数.Replace();


5、浏览器类


5.1 判断浏览器的类型


window.navigator.appName


5.2 判断ie的版本


window.navigator.appVersion


5.3 判断客户端的分辨率


window.screen.height; window.screen.width;




6、结合类


6.1 email的判断。


function ismail(mail)




...{


return(new RegExp(/^w+((-w+)│(.w+))*@[A-Za-z0-9]+((.│-)[A-Za-z0-9]+)*.[A-Za-z0-9]+$/).test(mail));


}




6.2 手机号码的验证


6.3 身份证的验证


function isIdCardNo(num)




...{




if (isNaN(num)) ...{alert("输入的不是数字!"; return false;}


var len = num.length, re;


if (len == 15)


re = new RegExp(/^(d)()?(d)(d)(d)(d)$/);


else if (len == 1


re = new RegExp(/^(d)()?(d)(d)(d)(d)(d)$/);




else ...{alert("输入的数字位数不对!"; return false;}


var a = num.match(re);


if (a != null)




...{


if (len==15)




...{


var D = new Date("19"+a[3]+"/"+a[4]+"/"+a[5]);


var B = D.getYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];


}


else




...{


var D = new Date(a[3]+"/"+a[4]+"/"+a[5]);


var B = D.getFullYear()==a[3]&&(D.getMonth()+1)==a[4]&&D.getDate()==a[5];


}




if (!B) ...{alert("输入的身份证号 "+ a[0] +" 里出生日期不对!"; return false;}


}


return true;


}


   另外一个


<script>


var aCity=






function cidInfo(sId)...{


var iSum=0


var info=""


if(!/^d(d│x)$/i.test(sId))return false;


sId=sId.replace(/x$/i,"a";


if(aCity[parseInt(sId.substr(0,2))]==null)return "Error:非法地区";


sBirthday=sId.substr(6,4)+"-"+Number(sId.substr(10,2))+"-"+Number(sId.substr(12,2));


var d=new Date(sBirthday.replace(/-/g,"/")


if(sBirthday!=(d.getFullYear()+"-"+ (d.getMonth()+1) + "-" + d.getDate()))return "Error:非法生日";


for(var i = 17;i>=0;i --) iSum += (Math.pow(2,i) % 11) * parseInt(sId.charAt(17 - i),11)


if(iSum%11!=1)return "Error:非法证号";


return aCity[parseInt(sId.substr(0,2))]+","+sBirthday+","+(sId.substr(16,1)%2?"男":"女"


}




document.write(cidInfo("380524198002300016","<br/>";


document.write(cidInfo("340524198002300019","<br/>"


document.write(cidInfo("340524197711111111","<br/>"


document.write(cidInfo("34052419800101001x","<br/>";


</script>


6.4 ip地址校验


<SCRIPT LANGUAGE="JavaScript">




function isip(s)...{




var check=function(v)...{try...{return (v<=255 && v>=0)}catch(x)...{return false}};


var re=s.split("."


return (re.length==4)?(check(re[0]) && check(re[1]) && check(re[2]) && check(re[3])):false


}




var s="202.197.78.129";


alert(isip(s))


</SCRIPT>


6.5 .加sp1后还能用的无边框窗口!!


<HTML XMLNS:IE>


<meta http-equiv="Content-Type" content="text/html; charset=gb2312">


<IEownload ID="include" STYLE="behavior:url(&default;download)" />


<title>Chromeless Window</title>




<SCRIPT LANGUAGE="JScript">




/**//*--- Special Thanks For andot ---*/






/**//*


This following code are designed and writen by Windy_sk <seasonx@163.net>


You can use it freely, but u must held all the copyright items!


*/






/**//*--- Thanks For andot Again ---*/




var CW_width = 400;


var CW_height = 300;


var CW_top = 100;


var CW_left = 100;


var CW_url = "/";


var New_CW = window.createPopup();


var CW_Body = New_CW.document.body;


var content = "";


var CSStext = "margin:1px;color:black; border:2px outset;border-style:expression(onmouseout=onmouseup=function(), onmousedown=function());background-color:buttonface;width:16px;height:14px;font-size:12px;line-height:11px;cursorefault;";




//Build Window


include.startDownload(CW_url, function(source));






function insert_content()...{


var temp = "";


CW_Body.style.overflow = "hidden";


CW_Body.style.backgroundColor = "white";


CW_Body.style.border = "solid black 1px";


content = content.replace(/<a ([^>]*)>/g,"<a onclick='parent.open(this.href);return false' >";


temp += "<table width=100% height=100% cellpadding=0 cellspacing=0 border=0>";


temp += "<tr style=';font-size:12px;background:#0099CC;height:20;cursor:default' ondblclick="Max.innerText=Max.innerText=='1'?'2':'1';parent.if_max=!parent.if_max;parent.show_CW();" onmouseup='parent.drag_up(event)' onmousemove='parent.drag_move(event)' onmousedown='parent.drag_down(event)' onselectstart='return false' oncontextmenu='return false'>";


temp += "<td style='color:#ffffff;padding-left:5px'>Chromeless Window For IE6 SP1</td>";


temp += "<td style='color:#ffffff;padding-right:5px;' align=right>";


temp += "<span id=Help onclick="alert('Chromeless Window For IE6 SP1 - Ver 1.0 Code By Windy_sk Special Thanks For andot')" style=""+CSStext+"font-family:System;padding-right:2px;">?</span>";


temp += "<span id=Min onclick='parent.New_CW.hide();parent.blur()' style=""+CSStext+"font-family:Webdings;" title='Minimum'>0</span>";


temp += "<span id=Max onclick="this.innerText=this.innerText=='1'?'2':'1';parent.if_max=!parent.if_max;parent.show_CW();" style=""+CSStext+"font-family:Webdings;" title='Maximum'>1</span>";


temp += "<span id=Close onclick='parent.opener=null;parent.close()' style=""+CSStext+"font-family:System;padding-right:2px;" title='Close'>x</span>";


temp += "</td></tr><tr><td colspan=2>";


temp += "<div id=include style='overflow:scroll;overflow-x:hidden;overflow-y:auto; HEIGHT: 100%; width:"+CW_width+"'>";


temp += content;


temp += "</div>";


temp += "</td></tr></table>";


CW_Body.innerHTML = temp;


}




setTimeout("insert_content()",1000);




var if_max = true;




function show_CW()...{


window.moveTo(10000, 10000);




if(if_max)...{


New_CW.show(CW_top, CW_left, CW_width, CW_height);




if(typeof(New_CW.document.all.include)!="undefined"...{


New_CW.document.all.include.style.width = CW_width;


New_CW.document.all.Max.innerText = "1";


}






}else...{


New_CW.show(0, 0, screen.width, screen.height);


New_CW.document.all.include.style.width = screen.width;


}


}




window.onfocus = show_CW;


window.onresize = show_CW;




// Move Window


var drag_x,drag_y,draging=false






function drag_move(e)...{




if (draging)...{


New_CW.show(e.screenX-drag_x, e.screenY-drag_y, CW_width, CW_height);


return false;


}


}






function drag_down(e)...{


if(e.button==2)return;


if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height)return;


drag_x=e.clientX;


drag_y=e.clientY;


draging=true;


e.srcElement.setCapture();


}






function drag_up(e)...{


draging=false;


e.srcElement.releaseCapture();


if(New_CW.document.body.offsetWidth==screen.width && New_CW.document.body.offsetHeight==screen.height) return;


CW_top = e.screenX-drag_x;


CW_left = e.screenY-drag_y;


}




</SCRIPT>


</HTML>




6.6 电话号码的验证




要求:


  (1)电话号码由数字、"("、""和"-"构成


  (2)电话号码为3到8位


  (3)如果电话号码中包含有区号,那么区号为三位或四位


  (4)区号用"("、""或"-"和其他部分隔开


  (5)移动电话号码为11或12位,如果为12位,那么第一位为0


  (6)11位移动电话号码的第一位和第二位为"13"


  (7)12位移动电话号码的第二位和第三位为"13"


  根据这几条规则,可以与出以下正则表达式:


  (^[0-9]-[0-9]$)│(^[0-9]$)│(^([0-9])[0-9]$)│(^013[0-9]$)






<script language="javascript">




function PhoneCheck(s) ...{


var str=s;


var reg=/(^[0-9]-[0-9]$)│(^[0-9]$)│(^([0-9])[0-9]$)│(^013[0-9]$)/


alert(reg.test(str));


}


</script>


<input type=text name="iphone">


<input type=button onclick="PhoneCheck(document.all.iphone.value)" value="Check">




二、功能类




1、时间与相关控件类


1.1 日历


精华区的日历




1.2 时间控件




1.3 万年历

http://202.112.86.128/studentspace/...calendars/rili/

1.4 显示动态显示时钟效果(文本,如OA中时间)


特效很容易找到的


1.5 显示动态显示时钟效果 (图像,像手表)


特效很容易找到的


2、表单类


2.1 自动生成表单


2.2 动态添加,修改,删除下拉框中的元素


大版主的js宝库里面的对select 的操作已经可以是精品了。


2.3 可以输入内容的下拉框




2.4 多行文本框中只能输入iMax文字。如果多输入了,自动减少到iMax个文字(多用于短信发送)




3、打印类


3.1 打印控件


<HTML>


<HEAD>


<TITLE> New Document </TITLE>


<META NAME="Generator" CONTENT="EditPlus">


<META NAME="Author" CONTENT="">


<META NAME="Keywords" CONTENT="">


<META NAME="Description" CONTENT="">


<SCRIPT LANGUAGE=javascript>


<!--


function setPrint()




function previewPrint()






//-->


</SCRIPT>


<script language=vbscript>


function setup_page


Dim wsh


Set wsh = CreateObject("WScript.Shell"


on error resume next




wsh.RegWrite "HKCUSoftwareMicrosoftInternet explorerPageSetupheader", "", "REG_SZ"


wsh.RegWrite "HKCUSoftwareMicrosoftInternet ExplorerPageSetupfooter", "", "REG_SZ"




end function




</script>


</HEAD>




<BODY>


<OBJECT classid=CLSID:8856F961-340A-11D0-A96B-00C04FD705A2 height=0 id=WB width=0>


</OBJECT>


<INPUT type="button" value="Set" id=button1 name=button1 onclick="setPrint();">


<INPUT type="button" value="Preview" id=button2 name=button2 onclick="previewPrint();">


<INPUT type="button" value="setup" id=button2 name=button2 onclick="setup_page();">


</BODY>


</HTML>




4、事件类


4.1 屏蔽右键


4.2 屏蔽所有功能键


4.3 --> 和<-- F5 F11,F9,F1


4.4 屏蔽组合键ctrl+N


<script>


//禁止ctrl+n和 禁止ctrl+r和 禁止shift+f10 禁止鼠标右键or左右键 和禁止f5


var oLastBtn=0,bIsMenu=false


if (window.Event)




...{


document.captureEvents(Event.MOUSEUP);


}




function nocontextmenu()




...{


event.cancelBubble=true;


event.returnValue=false;


return false;


}




function norightclick(e)






...{


if(window.Event)




...{


if (e.which !=1)




...{


return false;


}


}


else


if(event.button!=1)




...{


event.cancelBubble=true;


event.returnValue=false;


return false;


}


}




document.oncontextmenu=nocontextmenu;


document.onmousedown=norightclick;




function onKeyDown()




...{


if ((event.altKey)││((event.keyCode==&&(event.srcElement.type!="text"&&event.srcElement.type!="textarea"&&event.srcElement.type!="password")││((event.ctrlKey)&&((event.keyCode==7││(event.keyCode==82)))││(event.keyCode==116))




}


</script>


<body onkeydown="onKeyDown()">


<body>


</html>


5、网页设计类


5.1 连续滚动的文字,图片(注意是连续的,两段文字和图片中没有空白出现)


5.2 html编辑控件类


5.3 颜色选取框控件


5.4 下拉菜单


5.5 两层或多层次的下拉菜单


5.6 仿IE菜单的按钮。(效果如rongshuxa.com的导航栏目)


5.7 状态栏,title栏的动态效果(例子很多,可以研究一下)


5.8 双击后,网页自动滚屏


以上都是特效类,很容易找到的。


6、树型结构。


6.1 asp+SQL版


6.2 asp+xml+sql版


6.3 java+sql或者java+sql+xml


7、无边框效果的制作


8、连动下拉框技术


9、文本排序


10,画图类,含饼、柱、矢量贝滋曲线


<OBJECT


id=S


style="LEFT: 0px; WIDTH: 392px; TOP: 0px; HEIGHT: 240px"


height=240


width=392


classid="clsid:369303C2-D7AC-11D0-89D5-00A0C90833E6">


</OBJECT>


<SCRIPT>


S.DrawingSurface.ArcDegrees(0,0,0,30,50,60);


S.DrawingSurface.ArcRadians(30,0,0,30,50,60);


S.DrawingSurface.Line(10,10,100,100);


</SCRIPT>






11,操纵客户端注册表类


<SCRIPT>


var WshShell = WScript.CreateObject("WScript.Shell";


WshShell.RegWrite ("HKCUSoftwareACMEFortuneTeller", 1, "REG_BINARY";


WshShell.RegWrite ("HKCUSoftwareACMEFortuneTellerMindReader", "Goocher!", "REG_SZ";


var bKey = WshShell.RegRead ("HKCUSoftwareACMEFortuneTeller";


WScript.Echo (WshShell.RegRead ("HKCUSoftwareACMEFortuneTellerMindReader");


WshShell.RegDelete ("HKCUSoftwareACMEFortuneTellerMindReader";


WshShell.RegDelete ("HKCUSoftwareACMEFortuneTeller";


WshShell.RegDelete ("HKCUSoftwareACME";


</SCRIPT>




12,DIV层相关(拖拽、显示、隐藏、移动、增加)


13,TABLAE相关(客户端动态增加行列,模拟进度条,滚动列表等)


<HTML>


<SCRIPT LANGUAGE="JScript">




function numberCells() ...{


var count=0;




for (i=0; i < document.all.mytable.rows.length; i++) ...{




for (j=0; j < document.all.mytable.rows(i).cells.length; j++) ...{


document.all.mytable.rows(i).cells(j).innerText = count;


count++;


}


}


}


</SCRIPT>


<BODY onload="numberCells()">


<TABLE id=mytable border=1>


<TR><TH> </TH><TH> </TH><TH> </TH><TH> </TH></TR>


<TR><TD> </TD><TD> </TD><TD> </TD><TD> </TD></TR>


<TR><TD> </TD><TD> </TD><TD> </TD><TD> </TD></TR>


</TABLE>


</BODY>


</HTML>


14,各种<object classid=>相关类,如播放器,flash与脚本互动等


16, 刷新/模拟无刷新 异步调用类(XMLHttp或iframe,frame)



内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: