我是服務器小白。不了解真正的服務器是怎么搭建的。但是小編在本文將會講述如何在十分鐘內,在自己的電腦上搭建出服務器。并帶領大家使用搭建好的服務器。總之,干貨滿滿。
本文源碼點此下載:源碼
注:本文客戶端使用AFNetworking框架來請求測試服務器數據。
本文目錄
1. 搭建測試服務器
2. 測試POST、GET網絡數據請求
3. 在實際項目中的運用
1. 搭建測試服務器
小編選擇moco基于 Java 開發的開源項目來搭建測試服務器。
moco使用的場景是什么呢?
- 我是一個企業級軟件開發人員,每次面對集成就是我頭疼開始的時候,漫長集成拉鋸戰拖延了我們的進度。幸好有了moco,幾行配置就可以模擬一個服務,我再也不需要看集成服務團隊的臉色了。
- 我是一個移動開發人員,老板催得緊,可服務器端開發進度慢,我空有一個漂亮的iPhone應用,發揮不出作用。幸好有了moco,很快就可以搭建出一個模擬服務,我再也不用把生命浪費在無效的等待上了。
- 我是一個前端開發人員,做Inception的時候,客戶總想看到一個完整的應用演示,可哪有時間開發后端服務啊!幸好有了moco,幾下就可以弄出一個模擬服務,我做的頁面一下就有了生命力。
moco搭建出模擬服務器是不是很麻煩啊?
moco有兩種使用模式:
- API 模式
- 獨立運行模式
如果你編寫的是個Java應用(或是以其它JVM上的語言編寫的應用),你可以采用直接調用API。
本文采用的是獨立運行模式,點擊此處下載moco服務端(其實就是一個jar包),當然你可以從官網下載源代碼按照官網的說明編譯生成jar包。小編不想搞的過于復雜,我們需要的快速搭建測試服務器。小編選擇直接下載jar包。
測試打印Hello world!
注意:為了易于表述,小編在桌面上創建moco-server文件夾,我把剛才下載的moco-runner-0.10.2-standalone.jar。其中0.10.2代表的是當前的版本號。
moco-server文件夾里,創建一個test.json文件(.json是文件后綴)。
在文件里輸入以下內容后保存。
[
{
"response": {
"text": "Hello world!"
}
}
]
注:一定要是英文 " 引號 ,否則會報錯。使用文件編輯經常會莫名其妙的改變引號,所以小編建議使用
右鍵-打開方式-選擇Xcode
編輯內容。
打開終端,輸入以下內容:
//指向moco-server當前目錄
cd /Users/macOne/Desktop/moco-server
回車后再輸入以下內容:
java -jar moco-runner-0.10.2-standalone.jar start -p 12306 -c test.json
出現下圖表示運行成功:
在瀏覽器流輸入:http://localhost:12306
可以看到"Hello World!"字樣。
說明模擬服務器是可以正常使用的。到此服務器就搭建完畢了。是不是很簡單!
2. 測試POST、GET網絡數據請求
小編將一步步帶你使用配置文件配置網絡請求和響應數據。
小編在本篇文章介紹客戶端常用Http請求方法 Get
和 Post
。moco同樣也支持PUT
、 DELETE
方法。
-
Get 方法 不帶參數
在test.json里輸入一下內容
[
{
"response": {
"text": "Hello world!"
}
},
{
"request": {
"method" : "get",
"uri": "/getMethod"
},
"response": {
"text": "This is a Get Method!"
}
}
]
在瀏覽器里輸入http://localhost:12306/getMethod
回車后結果如下:
This is a Get Method!
request 請求
有14個固定的屬性:method
,headers
,json
,factory
,uri
,text
,cookies
,xpaths
,json_paths
,version
,file
,queries
,path_resource
,forms
。一定要遵循這些方法。 常用的method(請求方式)
,headers(heads參數)
,uri(url地址)
,file(指定調用的請求文件)
,queries(請求帶參)
,forms(表單內容)
。response 響應
有12個固定屬性:status
,attachment
,headers
,version
,factory
,file
,text
,proxy
,cookies
,json
,latency
,path_resource
。
在本篇文章中用到file
,text
。
通過命令返回的數據,可以看到當前的數據請求和返回的信息:
-
Get方法 帶參數
默認的請求方式是Get,你可以不用寫method
。
{
"request": {
"uri": "/getMethodWithParams",
"queries": {
"param1": "1",
"param2": "2"
}
},
"response": {
"text": "This is a method with params!"
}
}
注意同一級的屬性后要有 " , ",支持運行過程中編輯文件內容。編輯的內容是否合法在終端上會有提示。
在瀏覽器里輸入http://localhost:12306/getMethodWithParams?param1=1¶m2=2
回車后結果如下:
This is a method with params!
- Post 方法
寫一個復雜的帶有headers,body的Post 請求方法:
{
"request": {
"method" : "post",
"uri": "/postMethod",
"headers" : {
"content-type" : "application/json",
"sessionid": "e566288ba77de98d"
},
"forms" :{
"name" : "Airfei",
"password" : "123456"
}
},
"response": {
"text": "This is a POST Method!"
}
}
小編是通過Paw http客戶端請求工具進行驗證。
以上就是常用的使用配置數據方法。此test.json文件從此處查看。
3. 在實際項目中的運用
我要創建一個項目,結合此項目使用moco服務器。此項目中包括登陸界面和資產列表界面。
在實際項目中,請求接口數據比較多。因此把所有的配置放在同一個文件里,是非常不合適的。需要進行全局配置,參見官網的Global Settings。
前期準備,寫配置文件
在moco-server文件夾創建settings.json
,同時創建login和asset兩個文件夾(為了方便查找)。
- 在login文件夾內創建
login.json
和login_response.json
兩個文件。 - 在asset文件夾內創建
assetList.json
和assetList_response.json
兩個文件。
- 在
settings.json
文件輸入以下內容:
//是不是像導入文件頭文件
[
{
"include" : "login/login.json"
},
{
"include" : "asset/assetList.json"
}
]
-
login.json
輸入以下內容:
[
{
"request" :
{
"uri" : "/assetApp/login",
"method" : "get",
"queries" :
{
"username" : "Airfei",
"password" : "123456"
}
},
"response" :
{
"file" : "./login/login_response.json"
}
}
]
-
login_response.json
輸入以下內容:
//返回結果OK
[
{
"status" : "OK"
}
]
-
assetList.json
內容
//請求資產列表接口
[
{
"request" :
{
"uri" : "/assetApp/assetList",
"method" : "post",
"headers" : {
"content-type" : "application/json",
"sessionid": "e566288ba77de98d"
}
},
"response" :
{
"file" : "./asset/assetList_response.json"
}
}
]
-
assetList_response.json
內容
//資產列表清單
[
{
"assettype": "TD固定資產",
"assetname": "空調",
"assetcode": "4435-22333111",
"barcode": "4435-22333111",
"manufacturer": "天津市xxxxx",
"unit": "臺",
"amount": "2",
"addrname": "河北省xxxxxxx",
"cost": "3500"
},
{
"assettype": "TD固定資產",
"assetname": "電腦",
"assetcode": "4435-2234566",
"barcode": "4435-2234566",
"manufacturer": "北京市xxxxx",
"unit": "臺",
"amount": "7",
"addrname": "河北省xxxxxxx",
"cost": "4500"
},
{
"assettype": "TD固定資產",
"assetname": "飲水機",
"assetcode": "4735-22333123",
"barcode": "4735-22333123",
"manufacturer": "上海市xxxxx",
"unit": "臺",
"amount": "5",
"addrname": "河北省xxxxxxx",
"cost": "1250"
},
{
"assettype": "TD固定資產",
"assetname": "打印機",
"assetcode": "4435-2334567",
"barcode": "4435-2334567",
"manufacturer": "天津市xxxxx",
"unit": "臺",
"amount": "5",
"addrname": "河北省xxxxxxx",
"cost": "2760"
},
{
"assettype": "TD固定資產",
"assetname": "電腦桌",
"assetcode": "4435-2267998",
"barcode": "4435-2267998",
"manufacturer": "天津市xxxxx",
"unit": "臺",
"amount": "4",
"addrname": "河北省xxxxxxx",
"cost": "650"
},
{
"assettype": "TD固定資產",
"assetname": "手機",
"assetcode": "4435-22345881",
"barcode": "4435-22345881",
"manufacturer": "天津市xxxxx",
"unit": "臺",
"amount": "2",
"addrname": "河北省xxxxxxx",
"cost": "5500"
},
{
"assettype": "TD固定資產",
"assetname": "柜式空調",
"assetcode": "4435-6666444",
"barcode": "4435-6666444",
"manufacturer": "天津市xxxxx",
"unit": "臺",
"amount": "1",
"addrname": "河北省xxxxxxx",
"cost": "8800"
},
{
"assettype": "TD固定資產",
"assetname": "立式衣架",
"assetcode": "4435-8944444",
"barcode": "4435-8944444",
"manufacturer": "天津市xxxxx",
"unit": "個",
"amount": "2",
"addrname": "河北省xxxxxxx",
"cost": "300"
},
{
"assettype": "TD固定資產",
"assetname": "加濕器",
"assetcode": "4435-3277778",
"barcode": "4435-3277778",
"manufacturer": "天津市xxxxx",
"unit": "臺",
"amount": "5",
"addrname": "河北省xxxxxxx",
"cost": "180"
},
{
"assettype": "TD固定資產",
"assetname": "轉椅",
"assetcode": "4435-7844442",
"barcode": "4435-7844442",
"manufacturer": "天津市xxxxx",
"unit": "個",
"amount": "14",
"addrname": "河北省xxxxxxx",
"cost": "400"
}
]
配置完以上內容后在終端里輸入以下方法
cd /Users/macOne/Desktop/moco-server
//注意 -g 不是 -c
java -jar moco-runner-0.10.2-standalone.jar start -p 12306 -g settings.json
得到以下內容說明你的配置文件沒有錯誤。Server is started!
INFO Server is started at 12306
INFO Shutdown port is 51783
創建客戶端并使用AFNetwoking網絡請求
登錄界面其實輸入用戶名和密碼請求服務器驗證是否通過。其實也可以返回一些認證信息。用于校驗以后的所有請求的合法性。
客戶端上的登錄數據請求代碼:
-(void)requestLogin
{
MBProgressHUD *hud = [MBProgressHUD showHUDAddedTo:self.view animated:YES];
NSString *url=@"http://localhost:12306/assetApp/login";
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
manager.responseSerializer = [AFHTTPResponseSerializer serializer];
//請求所帶參數
NSDictionary *dic = @{@"username":_name,
@"password":_pwd
};
[manager GET:url parameters:dic success:^(AFHTTPRequestOperation * _Nonnull operation, id _Nonnull responseObject) {
NSString *receiveStr = [[NSString alloc]initWithData:responseObject encoding:NSUTF8StringEncoding];
NSData * data = [receiveStr dataUsingEncoding:NSUTF8StringEncoding];
NSDictionary *jsonDict = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:nil];
hud.mode = MBProgressHUDModeText;
hud.labelText = @"登錄成功";
hud.removeFromSuperViewOnHide = YES;
NSLog(@"result:%@",jsonDict);
//做一個處理,1秒后刷新。也可以不用加
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
//隱藏hub
[hud hide:YES];
//轉到下一界面
[[AppDelegate shareDelegate] setupMainViewController];
});
} failure:^(AFHTTPRequestOperation * _Nullable operation, NSError * _Nonnull error) {
hud.mode = MBProgressHUDModeText;
hud.labelText = @"登錄失敗";
hud.removeFromSuperViewOnHide = YES;
[hud hide:YES afterDelay:1.0];
NSLog(@"登錄失敗");
}];
}
登錄成功后,進入資產列表界面。POST請求服務器獲取資產列表數據,在請求數據需要帶上headers參數用于驗證請求的合法性。請求代碼如下:
-(void)requestAssetList
{
MBProgressHUD *hud = [MBProgressHUD showHUDAddedTo:self.view animated:YES];
NSString *url=@"http://localhost:12306/assetApp/assetList";
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
manager.responseSerializer = [AFHTTPResponseSerializer serializer];
//帶有headers參數
[manager.requestSerializer setValue:@"e566288ba77de98d" forHTTPHeaderField:@"sessionid"];
[manager.requestSerializer setValue:@"application/json" forHTTPHeaderField:@"Content-Type"];
[manager POST:url parameters:nil success:^(AFHTTPRequestOperation * _Nonnull operation, id _Nonnull responseObject) {
NSString *receiveStr = [[NSString alloc]initWithData:responseObject encoding:NSUTF8StringEncoding];
NSData * data = [receiveStr dataUsingEncoding:NSUTF8StringEncoding];
_assetArray = [NSJSONSerialization JSONObjectWithData:data options:NSJSONReadingMutableLeaves error:nil];
//做一個處理,1秒后刷新。模擬請求數據
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
//刷新界面
[_tableView reloadData];
//隱藏hub
[hud hide:YES];
});
} failure:^(AFHTTPRequestOperation * _Nullable operation, NSError * _Nonnull error) {
hud.mode = MBProgressHUDModeText;
hud.labelText = @"請求資產列表失敗";
hud.removeFromSuperViewOnHide = YES;
[hud hide:YES afterDelay:1.0];
}];
}
源碼點擊這里獲得。
如果覺得文章還不錯,請點一波關注吧!干貨系列會繼續給你帶來更多實用的東西。