0 added
0 removed
Original
2026-01-01
Modified
2026-03-10
1
<p>Теги: visual studio, тестирование, csharp, asp.net, программирование на c#, restful веб-сервис</p>
1
<p>Теги: visual studio, тестирование, csharp, asp.net, программирование на c#, restful веб-сервис</p>
2
<p>В прошлый раз<a>мы создали</a>RESTful веб-сервис. Что же, пришла пора его запустить и протестировать. Начнём с запуска.</p>
2
<p>В прошлый раз<a>мы создали</a>RESTful веб-сервис. Что же, пришла пора его запустить и протестировать. Начнём с запуска.</p>
3
<p>Итак, кликаем правой кнопкой по файлу нашего проекта Webservice.REST, потом выбираем "Назначить автозагружаемым проектом", дабы Visual Studio запускала данный проект при запуске всего решения:</p>
3
<p>Итак, кликаем правой кнопкой по файлу нашего проекта Webservice.REST, потом выбираем "Назначить автозагружаемым проектом", дабы Visual Studio запускала данный проект при запуске всего решения:</p>
4
<p>Запустить проект предельно просто. Рядом с кнопкой запуска будет имя веб-браузера, где станет запускаться наш проект. Автоматически Visual Studio предложит браузер по умолчанию, но ничего не мешает выбрать и другой веб-браузер:</p>
4
<p>Запустить проект предельно просто. Рядом с кнопкой запуска будет имя веб-браузера, где станет запускаться наш проект. Автоматически Visual Studio предложит браузер по умолчанию, но ничего не мешает выбрать и другой веб-браузер:</p>
5
<p>После выполнения запуска откроется браузерное окно. Перейдя по адресу http://localhost:52645/TutorialService.svc/Tutorial, вы увидите что-то похожее:</p>
5
<p>После выполнения запуска откроется браузерное окно. Перейдя по адресу http://localhost:52645/TutorialService.svc/Tutorial, вы увидите что-то похожее:</p>
6
<p>Браузер осуществляет GET-запрос, вызывая тем самым нами написанный метод GetAllTutorials(), возвращающий список со всеми туториалами. Кстати, сервис можно запускать на localhost и с другим портом.</p>
6
<p>Браузер осуществляет GET-запрос, вызывая тем самым нами написанный метод GetAllTutorials(), возвращающий список со всеми туториалами. Кстати, сервис можно запускать на localhost и с другим портом.</p>
7
<h2>Выполняем тестирование веб-сервиса</h2>
7
<h2>Выполняем тестирование веб-сервиса</h2>
8
<p>Мы уже видели, как веб-браузер осуществляет GET-запрос для вызова GetAllTutorials(). Но нам нужно проверить и другие сценарии.</p>
8
<p>Мы уже видели, как веб-браузер осуществляет GET-запрос для вызова GetAllTutorials(). Но нам нужно проверить и другие сценарии.</p>
9
<ul><li><strong>GET Tutorial/TutorialId</strong>- при выполнении вызова данного RESTful API клиент должен получить TutorialName, который соответствует переданному TutorialId.</li>
9
<ul><li><strong>GET Tutorial/TutorialId</strong>- при выполнении вызова данного RESTful API клиент должен получить TutorialName, который соответствует переданному TutorialId.</li>
10
</ul><p>Чтобы сделать вызов, просто просто добавьте в конце URL строку "/1", в результате чего получится http://localhost:52645/TutorialService.svc/Tutorial/1. Перейдя по ссылке, вы должны увидеть следующее:</p>
10
</ul><p>Чтобы сделать вызов, просто просто добавьте в конце URL строку "/1", в результате чего получится http://localhost:52645/TutorialService.svc/Tutorial/1. Перейдя по ссылке, вы должны увидеть следующее:</p>
11
<p>Теперь мы вызвали метод GetTutorialByID(), вернувший туториал с индексом 1 - "Queues".</p>
11
<p>Теперь мы вызвали метод GetTutorialByID(), вернувший туториал с индексом 1 - "Queues".</p>
12
<ul><li><strong>POST Tutorial/TutorialName</strong>- вызывая этот API, клиент посылает запрос на добавление переданного TutorialName, который сервер должен добавить в список. Здесь нам не обойтись без такого инструмента, как<strong>Fiddler</strong>.</li>
12
<ul><li><strong>POST Tutorial/TutorialName</strong>- вызывая этот API, клиент посылает запрос на добавление переданного TutorialName, который сервер должен добавить в список. Здесь нам не обойтись без такого инструмента, как<strong>Fiddler</strong>.</li>
13
</ul><p>Запустите его и выполните следующие шаги: 1. Переключаемся на вкладку Composer (применяется для создания запросов, которые можно отправить любому web-приложению). 2. Устанавливаем тип запроса равным "POST", а в URL вставляем адрес сервиса (http://localhost:52645/TutorialService.svc/Tutorial). 3. В окне, где есть строка "User-Agent: Fiddler" добавляем "Content-Type: application/json" (сервис ведь работает лишь с данными в формате JSON, не забывайте об этом). 4. Теперь вводим данные в поле "Request Body". Метод для POST-запросов осуществляет приём параметра str. При передаче строки {"str": "Trees"}, мы указываем, что желаем добавить в список значение "Trees".</p>
13
</ul><p>Запустите его и выполните следующие шаги: 1. Переключаемся на вкладку Composer (применяется для создания запросов, которые можно отправить любому web-приложению). 2. Устанавливаем тип запроса равным "POST", а в URL вставляем адрес сервиса (http://localhost:52645/TutorialService.svc/Tutorial). 3. В окне, где есть строка "User-Agent: Fiddler" добавляем "Content-Type: application/json" (сервис ведь работает лишь с данными в формате JSON, не забывайте об этом). 4. Теперь вводим данные в поле "Request Body". Метод для POST-запросов осуществляет приём параметра str. При передаче строки {"str": "Trees"}, мы указываем, что желаем добавить в список значение "Trees".</p>
14
<p>В результате нашему сервису отправится запрос на добавление "Trees".</p>
14
<p>В результате нашему сервису отправится запрос на добавление "Trees".</p>
15
<ul><li><strong>DELETE Tutorial/TutorialId</strong>- при вызове этого API клиент отправляет запрос на удаление из списка TutorialName, соответствующее переданному TutorialId.</li>
15
<ul><li><strong>DELETE Tutorial/TutorialId</strong>- при вызове этого API клиент отправляет запрос на удаление из списка TutorialName, соответствующее переданному TutorialId.</li>
16
</ul><p>Запускаем Fiddler и выполняем следующие шаги: 1. Переключаемся на вкладку Composer. 2. Устанавливаем тип запроса равным "DELETE", в URL вставляем адрес сервиса вместе с id-элемента, который желаем удалить. Например, если речь идёт о втором элементе, адрес будет следующий: http://localhost:52645/TutorialService.svc/Tutorial/1.</p>
16
</ul><p>Запускаем Fiddler и выполняем следующие шаги: 1. Переключаемся на вкладку Composer. 2. Устанавливаем тип запроса равным "DELETE", в URL вставляем адрес сервиса вместе с id-элемента, который желаем удалить. Например, если речь идёт о втором элементе, адрес будет следующий: http://localhost:52645/TutorialService.svc/Tutorial/1.</p>
17
<p>Теперь нажимаем на кнопку "Execute" и отправляем DELETE-запрос на удаление элемента "Queues". В самом деле, если мы сейчас снова запросим список туториалов, то окажется, что их стало на один меньше:</p>
17
<p>Теперь нажимаем на кнопку "Execute" и отправляем DELETE-запрос на удаление элемента "Queues". В самом деле, если мы сейчас снова запросим список туториалов, то окажется, что их стало на один меньше:</p>
18
<p><em>Источник "<a>RESTful Web Services Tutorial with Example</a>".</em></p>
18
<p><em>Источник "<a>RESTful Web Services Tutorial with Example</a>".</em></p>
19
19