国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > ASP > 正文

chr(9)、chr(10)、chr(13)、chr(32)、chr(34)與特殊空格

2024-05-04 11:06:46
字體:
供稿:網(wǎng)友
chr(9)、chr(10)、chr(13)、chr(32)、chr(34)

所有關(guān)于 ASCII碼的表格:[url]http://www.asciitable.com/[/url]

chr(13) 是一個(gè)回車

Chr(10) 是個(gè)換行符

chr(32) 是一個(gè)空格符

9/34 是tab,未確定?

以下是一些示列
特殊的空格字符

特殊的空格字符 
在asp編程中,我們常常使用trim(rtrim,ltrim)函數(shù)去掉一些數(shù)據(jù)的開頭和結(jié)尾的空格,筆者最近寫了一個(gè)asp聊天室,有下面的一段代碼:  

<% dim name,title  
name=trim(request.form("name"))  
password=trim(request.form("password"))  
if name=""or password="" then response.redirect "error.asp?error=name&name=null"   
myDSN="DSN=test;uid=test;pwd=test"  
set cn=server.createobject("adodb.connection")  
cn.open myDSN  
sql="insert into test(name,title) values('"&name&"','"&password&"')"  
cn.execute(sql)  
cn.close%>  

筆者使用了trim函數(shù)來去掉開頭和結(jié)尾的空格,在一般的情況下,這段程序執(zhí)行的很正常,但是后來筆者竟然發(fā)現(xiàn)有人竟然可以使用空格進(jìn)來,意思就是說,該用戶的name完全為空格,但是筆者嘗試自己使用空格卻無論都不能通過(即被程序監(jiān)測了出來),開頭和結(jié)尾的空格都被trim函數(shù)給去掉了,即使中間有空格,筆者需要的話也可以使用一個(gè)函數(shù)把中間的空格給去掉,由于筆者使用的是sql數(shù)據(jù)庫記錄下的用戶資料,于是筆者懷疑他使用了其它什么的東西讓系統(tǒng)看不到,于是去察看紀(jì)錄用戶資料的sql數(shù)據(jù)庫(筆者曾經(jīng)使用這種方法看到了帶換行符的用戶),但是筆者仍然看到數(shù)據(jù)庫中的改用戶的資料也是空格,這難道說該用戶使用了一種手段可以繞過我的用戶名和密碼監(jiān)測嗎???實(shí)在找不到程序上的漏洞,于是只能向這位用戶請(qǐng)教,幸運(yùn)的是這位用戶爽快的告訴了筆者,原來是"Alt+255",按住alt鍵然后依次按下小鍵盤中"2","5","5"就會(huì)產(chǎn)生一個(gè)比較特殊的東西"空格"字符(這個(gè)概念筆者也不是比較清楚,這是一種控制字符,在一些編輯器中可以看到word2000,應(yīng)該還有其他的控制字符),這個(gè)空格字符不同于傳統(tǒng)的按下空格鍵產(chǎn)生的字符,它的asc代碼是255,而傳統(tǒng)的space鍵入的空格的asc代碼是32,trim函數(shù)只能認(rèn)識(shí)asc代碼為32的代碼并去除,所以出現(xiàn)了出現(xiàn)空格用戶的情況!針對(duì)這種情況筆者設(shè)計(jì)了下面的兩種函數(shù)去掉這"空格"字符:
function xuankong(str)  
dim result  
dim j  
   j=len(str)  
   result=""  
dim i   
for i = 1 to j  
   select case mid(str,i,1)  
       case "<"  
          result=result+"<"  
       case ">"  
          result=result+">"  
       case chr(34)    
          result=result+"""  
       case "&"  
          result=result+"&"  '以上代碼轉(zhuǎn)換一些html標(biāo)記  
       case chr(255) '防止特殊空格  
          result=result  
       case chr(13) '防止回車符  
          result=result+""  
       case chr(10) '防止換行符  
          result=result+""  
       case else  
          result=result+mid(str,i,1)  
  end select  
next   
xuankong=result  
end function  
然后在你的asp程序中使用這個(gè)函數(shù),比如:  
name=xuankong(trim(request.form("name")))  

因?yàn)樽址?-z asc代碼的數(shù)值為 48-122 這一個(gè)區(qū)段 ,所以可以使用如下的方法監(jiān)測: 

dim j  
j=len(trim(request.form("name")))  
for i= 1 to  j  
if  asc(mid(name,i,1))>122 or asc(mid(name,i,1))<48 then response..redirect"error.asp?
error=special"  
next
  
雖然這種“空格”暫時(shí)沒有發(fā)現(xiàn)會(huì)破壞程序的問題,但是卻是可以讓人搗亂的,還是防了的好,不過這種空格也有一種好處,如果作為你得上網(wǎng)密碼的話,嘿嘿… …恐怕沒有幾個(gè)人能看到吧!看到的都是以為是space,但是卻不是… … 筆者不熟悉php和jsp所以不知道在這兩種東西中是否會(huì)存在這種問題
如何讀出空格

如何讀出空格

我們?cè)诰W(wǎng)頁中經(jīng)常要?jiǎng)討B(tài)顯示從文件中取出來的內(nèi)容,假如你編寫了一個(gè)聊天室或論壇之類的程序,每一位發(fā)表言論者的內(nèi)容都要先存在文本文件中,然后再顯示在網(wǎng)頁上。但是我們?cè)诰W(wǎng)頁上讓用戶輸入內(nèi)容的控件是文本框。那么文本框中的內(nèi)容顯示在網(wǎng)頁上時(shí)不能把類似空格、換行的字符顯示出來,也就是說沒有段落。要想在網(wǎng)頁上顯示段落,必須在我們輸入文本的空格、換行字符處插入HTML標(biāo)志才能把這些字符顯示出來,請(qǐng)看下面的例子。

假如在網(wǎng)頁上是一個(gè)聊天室畫面,我們?cè)谖谋究蛑休斎雰?nèi)容后,點(diǎn)擊“提交”就可在頁面上把我們的內(nèi)容顯示出來,文本框名為Text1 ,我們用下面的方法就可以很巧妙地實(shí)現(xiàn)顯示文本換行和空格的功能。

<%
......
......
str=request.querystring("text1")
str=Replace(str, Chr(32), "&nbsp")
'把空格換成&nbsp標(biāo)志
str=Replace(str, vbCrLf, "<br>")
'把回車換行符換成<br>標(biāo)志
Response.write str
......
......
%>

經(jīng)過上面的代碼后,我們就把文本中的回車換行符變?yōu)闉g覽器所能識(shí)別的<br>換行標(biāo),而把空格換為&nbsp空格標(biāo)志。其中Chr(32)表示空格,vbCrLf表示回車換行。
chr(13) 是一個(gè)回車
(
例子:把所有回車符替換為<br/>
#Replace(foo, Chr(13), "<br />", "ALL")#


)

Chr(10) 是個(gè)換行符

所有關(guān)于 ASCII碼的表格:[url]http://www.asciitable.com./[/url]

<cfscript>
/**
* 一個(gè)增強(qiáng)版的文章段落格式化函數(shù)
* 使用)&nbsp;替換TAB,支持多系統(tǒng)
* Rewrite and multiOS support by Nathan Dintenfas.

* @param string The string to format. (Required)
* @return Returns a string. 
* @author Ben Forta ([email]ben@forta.com[/email]) 
* @version 3, June 26, 2002 
*/
function Paragrap1hFormat2(str) {
//first make Windows style into Unix style
str = replace(str,chr(13)&chr(10),chr(10),"ALL");
//now make Macintosh style into Unix style
str = replace(str,chr(13),chr(10),"ALL");
//now fix tabs
str = replace(str,chr(9),"&nbsp;&nbsp;&nbsp;","ALL");
//now return the text formatted in HTML
return replace(str,chr(10),"<br />","ALL");
}
</cfscript>
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 鄂伦春自治旗| 滨海县| 广汉市| 吴堡县| 丹棱县| 即墨市| 榆中县| 南安市| 二连浩特市| 德庆县| 库伦旗| 东至县| 三明市| 马边| 高雄县| 玉屏| 石阡县| 定陶县| 盐山县| 辛集市| 驻马店市| 师宗县| 阿拉善左旗| 聂拉木县| 广昌县| 留坝县| 措勤县| 甘德县| 溧水县| 永州市| 望谟县| 榆中县| 巴塘县| 紫金县| 利辛县| 田林县| 浑源县| 繁昌县| 澄江县| 兴安县| 凤山县|