原文鏈接:http://www.jianshu.com/p/638da64422a0
我是服務器小白。不了解真正的服務器是怎么搭建的。但是小編在本文將會講述如何在十分鍾內,在自己的電腦上搭建出服務器。並帶領大家使用搭建好的服務器。總之,干貨滿滿。
本文源碼點此下載:源碼
注:本文客戶端使用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]; }]; }
源碼點擊這里獲得。
如果覺得文章還不錯,請點一波關注吧!干貨系列會繼續給你帶來更多實用的東西。