干貨系列之零基礎搭建自測服務器

我是服務器小白。不了解真正的服務器是怎么搭建的。但是小編在本文將會講述如何在十分鐘內,在自己的電腦上搭建出服務器。并帶領大家使用搭建好的服務器。總之,干貨滿滿。

本文源碼點此下載:源碼
注:本文客戶端使用AFNetworking框架來請求測試服務器數據。


本文目錄

1. 搭建測試服務器
2. 測試POST、GET網絡數據請求
3. 在實際項目中的運用

1. 搭建測試服務器

小編選擇moco基于 Java 開發的開源項目來搭建測試服務器。

moco使用的場景是什么呢?

  1. 我是一個企業級軟件開發人員,每次面對集成就是我頭疼開始的時候,漫長集成拉鋸戰拖延了我們的進度。幸好有了moco,幾行配置就可以模擬一個服務,我再也不需要看集成服務團隊的臉色了。
  1. 我是一個移動開發人員,老板催得緊,可服務器端開發進度慢,我空有一個漂亮的iPhone應用,發揮不出作用。幸好有了moco,很快就可以搭建出一個模擬服務,我再也不用把生命浪費在無效的等待上了。
  1. 我是一個前端開發人員,做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是文件后綴)。

創建文件.jpg

在文件里輸入以下內容后保存。

[
   {
    "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

出現下圖表示運行成功:

命令行內容.png

在瀏覽器流輸入:http://localhost:12306可以看到"Hello World!"字樣。

說明模擬服務器是可以正常使用的。到此服務器就搭建完畢了。是不是很簡單!

2. 測試POST、GET網絡數據請求

小編將一步步帶你使用配置文件配置網絡請求和響應數據。

小編在本篇文章介紹客戶端常用Http請求方法 GetPost。moco同樣也支持PUTDELETE方法。

  • 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!
  1. 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(表單內容)

  2. response 響應
    有12個固定屬性:status, attachment, headers, version, factory, file, text, proxy, cookies, json, latency, path_resource
    在本篇文章中用到file,text

通過命令返回的數據,可以看到當前的數據請求和返回的信息:

模擬Get請求.jpg
  • 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&param2=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客戶端請求工具進行驗證。

post 請求驗證.jpg

以上就是常用的使用配置數據方法。此test.json文件從此處查看。

3. 在實際項目中的運用

我要創建一個項目,結合此項目使用moco服務器。此項目中包括登陸界面和資產列表界面

在實際項目中,請求接口數據比較多。因此把所有的配置放在同一個文件里,是非常不合適的。需要進行全局配置,參見官網的Global Settings

前期準備,寫配置文件
在moco-server文件夾創建settings.json,同時創建login和asset兩個文件夾(為了方便查找)。

  • 在login文件夾內創建login.jsonlogin_response.json兩個文件。
  • 在asset文件夾內創建assetList.jsonassetList_response.json兩個文件。

  1. settings.json文件輸入以下內容:
//是不是像導入文件頭文件
[
    {
        "include" : "login/login.json"
    },
    {
        "include" : "asset/assetList.json"
    }
]
  1. login.json輸入以下內容:
[
  {
    "request" :
    {
      "uri" : "/assetApp/login",
      "method" : "get",
      "queries" :
        {
         "username" : "Airfei",
         "password" : "123456"
        }
    },
    "response" :
    {
      "file" : "./login/login_response.json"
    }
  }
]
  1. login_response.json 輸入以下內容:
//返回結果OK
[
  {
    "status" : "OK"
  }
]
  1. assetList.json內容
//請求資產列表接口
[
  {
    "request" :
    {
      "uri" : "/assetApp/assetList",
      "method" : "post",
      "headers" : {
          "content-type" : "application/json",
          "sessionid": "e566288ba77de98d"
      }
 
    },
    "response" :
    {
      "file" : "./asset/assetList_response.json"
    }
  }
]
  1. 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];
    }];
}

源碼點擊這里獲得。
如果覺得文章還不錯,請點一波關注吧!干貨系列會繼續給你帶來更多實用的東西。

感謝

可輕松搭建的測試服務器 Moco

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • Spring Cloud為開發人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發現,斷路器,智...
    卡卡羅2017閱讀 134,948評論 18 139
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 173,357評論 25 708
  • 發現 關注 消息 iOS 第三方庫、插件、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,245評論 4 61
  • 國家電網公司企業標準(Q/GDW)- 面向對象的用電信息數據交換協議 - 報批稿:20170802 前言: 排版 ...
    庭說閱讀 11,166評論 6 13
  • 哈哈,來點我啊!
    小小作手閱讀 118評論 1 1