這兩天寫了一個winsocket的腳本,沒有通過錄制的方式,是直接手寫的。下面貼出來和大家分享:
腳本的寫法很簡單,大體說來,就像把大象放進冰箱一樣,總共分三步:
第一步:把冰箱門打開。
//建立到服務端的連接
rc = lrs_create_socket("socket0", "TCP", "LocalHost=0", "RemoteHost=128.64.64.23:8988", LrsLastArg);
if (rc==0)
lr_output_message("Socket was successfully created ");
else
lr_output_message("An error occurred while creating the socket, Error Code: %d", rc);
第二步:把大象裝進去。
lrs_send("socket0", "buf0", LrsLastArg); //往"socket0"發送"buf0"中的數據
lrs_receive("socket0", "buf1", LrsLastArg);//將"socke0"中返回的數據存放到"buf1"中
第三步:把冰箱門帶上。
//關閉連接
lrs_close_socket("socket0");
大家肯定已經看出來了,整個關鍵是在第二步,要把這么一頭大象裝到冰箱里可不是件容易的事情,我們要對傳送的數據做一些處理才行。如果大家有進行過winsocket協議的腳本錄制就會知道,LR會把你發送的數據包內容寫到data.ws這個文件中,那么我們在此也同樣應該把數據寫到data.ws中去。假設我要發送的是“00100312303456”這一串字符,那么我就直接把它寫到data.ws中,腳本如下:
;WSRData 2 1
send buf0 10
"00100312303456" //注意要加""
recv buf1 128
-1
運行腳本,可以看到執行成功。在日志信息中可以打印出發送的BUFFER和接收到的BUFFER內容。
接下來,我們要對發送的字符串進行參數化,讓腳本每次發送的字符串都不一樣,怎么做呢?
方法有兩種:
1、直接參數化。在data.ws中是可以直接進行參數化的,具體操作我就不多說了。要注意的是默認的參數名稱符號是尖括號(<>),和HTTP協議的大括號({})不同(搞不懂為什么LR要把不同協議的默認參數名稱符號設成不一樣,這不是折騰人嘛)。腳本如下:
send buf0 106
"<string>" //string是自定義的參數名
這種方法最簡單,也容易理解。
2、第二種方法則麻煩一點,下面重點做個介紹。(不是我故意要找麻煩,而是因為我每次遇到的問題總是要比一般的情況麻煩一點,5555~~)
事情是這樣的:話說如果我要發送的數據是很通過簡單的方法拼接起來,舉個簡單的例子,比如是“用戶名(假設是123)+密碼(假設是456)”,在這種情況下,使用第一種方法就夠用了,我可以設置兩個參數<username>和<password>,寫成
send buf0 106
"<username><password>"
的方式就可以了。
但是這邊的情況稍微復雜一些,發送的數據格式還需要加上字符串的長度,比如在上面的例子中,需要這樣表示:00100312303456。
前四位0010是表示后面發送的字符串總長度是10,后面的03則表示用戶名有3位,再后面的123才是真正的用戶名,再后面的03456也是同樣的道理。而每次發送的用戶名長度不同,字符串也就不同,比如用戶名如果是1234,那么我的報文就應該是這樣“001104123403456”這樣一來,我就不能通過簡單地拼接的方式來發送了,而需要再對它進行一些處理。
我的方法是在action中進行字符串的拼接和處理:
char data[200];
char length[20];
len = strlen(lr_eval_string("{usermame}"));
sprintf(length,"%d",len);
strcat(data,length);
strcat(data,"{username}");
然后,再通過lrs_save_param_ex函數把該數據保存到data_param參數中。
lrs_save_param_ex("socket0", "user", data, 0, strlen(data),NULL, "data_param");
最后,在data.ws文件中使用data_param參數發送數據包:
send buf0 "<data_param>"
OK,降龍十八掌第七式--飛龍在天,神龍擺尾、黑龍偷心、雙龍出海、見龍在田、龍飛鳳舞、伏虎降龍、縮龍成寸、龍蛇混雜、龍的傳人、龍鳳呈祥、龍馬精神、望夫成龍~~打完收工!