一个特殊的内码转换处理对于XML格式的UTF-8
一個特殊的內(nèi)碼轉(zhuǎn)換處理對于XML格式的UTF-8
一般來說我們所使用的中文網(wǎng)站都是基于UTF-8的,只需要在錄制或者是回放時設(shè)置對應(yīng)的編碼就行了,但是隨著技術(shù)的升級,慢慢的我們發(fā)現(xiàn)有些內(nèi)容的UTF-8無法處理了。
例如在新版的discuz!.net 3.0中,采用了新的AJAX處理方法,將登陸成功的信息通過UTF-8?的XML返回,這樣就出現(xiàn)了一個問題,無法針對這個返回進行檢查點函數(shù)了(LR不會對返回的XML進行UTF-8解析),這里給出兩個解決方案:
1.檢查點函數(shù)直接用UTF-8編碼后的亂碼來做
?web_reg_find("Search=Body",
??"SaveCount=loginst",
??"Text=????????????",
??LAST);
?web_submit_data("login.aspx_2",
??"Action=http://172.168.2.200:8081/login.aspx?infloat=1&&inajax=1",
??"Method=POST",
??"TargetFrame=",
??"RecContentType=text/xml",
??"Referer=http://172.168.2.200:8081/",
??"Snapshot=t3.inf",
??"Mode=HTML",
??ITEMDATA,
??"Name=username", "Value=admin", ENDITEM,
??"Name=password", "Value=51testing", ENDITEM,
??"Name=question", "Value=0", ENDITEM,
??"Name=answer", "Value=", ENDITEM,
??"Name=templateid", "Value=0", ENDITEM,
??LAST);
?
2.通過關(guān)聯(lián)獲得這塊文字,再通過函數(shù)轉(zhuǎn)換內(nèi)碼
web_reg_save_param("login",
??"LB=<p>",
??"RB=</p>",
??"Ord=1",
??"Search=Body",
??LAST);
?web_submit_data("login.aspx_2",
??"Action=http://172.168.2.200:8081/login.aspx?infloat=1&&inajax=1",
??"Method=POST",
??"TargetFrame=",
??"RecContentType=text/xml",
??"Referer=http://172.168.2.200:8081/",
??"Snapshot=t3.inf",
??"Mode=HTML",
??ITEMDATA,
??"Name=username", "Value=admin", ENDITEM,
??"Name=password", "Value=51testing", ENDITEM,
??"Name=question", "Value=0", ENDITEM,
??"Name=answer", "Value=", ENDITEM,
??"Name=templateid", "Value=0", ENDITEM,
??LAST);
lr_convert_string_encoding(lr_eval_string("{login}"),"utf-8",NULL,"my");
這里使用函數(shù)lr_convert_string_encoding函數(shù),將login參數(shù)中的utf-8編碼轉(zhuǎn)換為當(dāng)前系統(tǒng)的編碼,最后在my參數(shù)中會出現(xiàn)登陸成功的內(nèi)容,這樣就可以在通過字符串比較來確認(rèn)事務(wù)是否成功了。
?
另:奇怪的是用lr_convert_string_encoding將"登陸成功"轉(zhuǎn)換為utf-8再去做檢查點判斷時,會檢查不到該內(nèi)容,可能是內(nèi)碼轉(zhuǎn)換后格式還是有些不同導(dǎo)致的,所以沒有采用先轉(zhuǎn)內(nèi)碼再對轉(zhuǎn)化后的內(nèi)碼做檢查點的方式。
lr_convert_string_encoding函數(shù)的小技巧
在前幾天的一個帖子談到utf-8的一些處理,其中說到了lr_convert_string_encoding函數(shù),但是在使用這個函數(shù)的時候會有個小問題,就是用該函數(shù)轉(zhuǎn)出來的內(nèi)容會自動附加一個/x00的結(jié)尾,導(dǎo)致如果用他來做關(guān)聯(lián)或者檢查點的匹配會錯誤。
lr_convert_string_encoding("登陸成功",NULL,"UTF-8","temp");
如果這樣用得出的結(jié)果是
????????????\x00
而正確的結(jié)果應(yīng)該是
????????????
為了去掉這個最后的\x00,可以通過下面這個辦法去掉
lr_save_string(lr_eval_string("{temp}"),"temp");
當(dāng)你對一個帶有/x00的參數(shù)通過lr_eval_string函數(shù)取參數(shù)值時,會自動去除掉/x00,所以只需要將去掉
/x00后的字符串再通過lr_save_string函數(shù)保存為lr的參數(shù)就行了
?
總結(jié)
以上是生活随笔為你收集整理的一个特殊的内码转换处理对于XML格式的UTF-8的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Spring+Quartz 集群
- 下一篇: ADO.NET学习笔记--数据分组