ValuesController.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Threading;
  4. using System.Threading.Tasks;
  5. using Microsoft.AspNetCore.Http.Features;
  6. using Microsoft.AspNetCore.Mvc;
  7. using Newtonsoft.Json;
  8. using Sers.Core.Module.Api;
  9. using Sers.Core.Module.Rpc;
  10. using Vit.Core.Util.ComponentModel.Data;
  11. using Vit.Core.Util.ComponentModel.Model;
  12. namespace Did.Serslot.Demo.Controllers
  13. {
  14. [Route("did_serslot/[controller]")]
  15. [Route("did_serslot/v1")]
  16. [ApiController]
  17. public class ValuesController : ControllerBase
  18. {
  19. #region (x.1)route
  20. /// <summary>
  21. /// GET did_serslot/Values
  22. /// </summary>
  23. /// <returns></returns>
  24. [HttpGet]
  25. [HttpPost]
  26. public object Route0([FromQuery]string a)
  27. {
  28. //var requestFeature = Request.HttpContext.Features.Get<IHttpRequestFeature>();
  29. return "GET did_serslot/Values?a=" + a;
  30. }
  31. /// <summary>
  32. /// GET did_serslot/Values/route_x
  33. /// </summary>
  34. /// <returns></returns>
  35. [HttpGet("101/route")]
  36. [HttpGet("102/route")]
  37. [HttpGet("/did_serslot/Values/103/route")]
  38. public object Route1()
  39. {
  40. return new
  41. {
  42. Request.Path,
  43. Request.Method
  44. };
  45. }
  46. /// <summary>
  47. /// GET did_serslot/Values/route104
  48. /// </summary>
  49. /// <returns></returns>
  50. [HttpGet("[action]")]
  51. public object route104()
  52. {
  53. return new
  54. {
  55. name = "GET did_serslot/Values/route104",
  56. Request.Path,
  57. Request.Method
  58. };
  59. }
  60. #endregion
  61. #region (x.2)Name和Desc
  62. /// <summary>
  63. /// 演示 如何使用Name 和 Description。
  64. /// 函数注释和使用SsDescription是一样的效果。
  65. /// </summary>
  66. /// <returns></returns>
  67. [HttpGet("201/NameDesc")]
  68. [SsName("NameDesc1")]
  69. public ApiReturn NameDesc()
  70. {
  71. return new ApiReturn();
  72. }
  73. /// <summary>
  74. ///
  75. /// </summary>
  76. /// <returns></returns>
  77. [HttpGet("202/NameDesc")]
  78. [SsDescription("演示 如何使用Name 和 Description。\n函数注释和使用SsDescription是一样的效果。")]
  79. public ApiReturn NameDesc2()
  80. {
  81. return new ApiReturn();
  82. }
  83. #endregion
  84. #region (x.3) 参数
  85. #region (x.x.1) 从route获取参数
  86. /// <summary>
  87. /// 从route获取参数
  88. /// GET did_serslot/Values/301/arg/{id}/{id2}
  89. /// </summary>
  90. /// <returns></returns>
  91. [HttpGet("301/arg/{name}/{age}")]
  92. public object Arg301(
  93. [SsExample("lith"), SsDefaultValue("NoName"), SsDescription("姓名")]string name,
  94. [SsExample("30"), SsDefaultValue("0"), SsDescription("年龄,请指定在16-50中间的整数")]int age)
  95. {
  96. return new
  97. {
  98. Request.Path,
  99. Request.Method,
  100. request = new { name, age }
  101. };
  102. }
  103. #endregion
  104. #region (x.x.2)从Query String获取参数
  105. /// <summary>
  106. /// 从Query String获取参数
  107. /// GET did_serslot/Values/302/arg?name=lith&amp;age=30
  108. /// </summary>
  109. /// <returns></returns>
  110. [HttpGet("302/arg")]
  111. public object Arg302(
  112. [FromQuery, SsExample("lith"),SsDescription("姓名")]string name,
  113. [FromQuery, SsExample("30"), SsDescription("年龄,请指定在16-50中间的整数")]int age)
  114. {
  115. return new
  116. {
  117. Request.Path,
  118. Request.Method,
  119. request = new { name, age }
  120. };
  121. }
  122. #endregion
  123. #region (x.x.3)从Body获取参数
  124. /// <summary>
  125. /// 从Body获取参数
  126. /// POST did_serslot/Values/303/arg
  127. /// </summary>
  128. /// <returns></returns>
  129. [HttpPost("303/arg")]
  130. public object Arg3([FromBody, SsExample("\"lith\""), SsDescription("姓名,请以双引号开始和结束")]string name)
  131. {
  132. return new
  133. {
  134. Request.Path,
  135. Request.Method,
  136. request = new { name }
  137. };
  138. }
  139. #endregion
  140. #region (x.x.4)从Body获取参数
  141. /// <summary>
  142. /// 从Body获取参数
  143. /// POST did_serslot/Values/304/arg
  144. /// </summary>
  145. /// <returns></returns>
  146. [HttpPost("304/arg")]
  147. public object Arg4([FromBody] ArgModel arg)
  148. {
  149. return new
  150. {
  151. Request.Path,
  152. Request.Method,
  153. request = arg
  154. };
  155. }
  156. public class ArgModel
  157. {
  158. /// <summary>
  159. /// 姓名
  160. /// </summary>
  161. [SsExample("lith"), SsDefaultValue("NoName")]
  162. [JsonProperty("arg")]
  163. public string name { get; set; }
  164. /// <summary>
  165. ///
  166. /// </summary>
  167. [SsExample("20"), SsDefaultValue("0"), SsDescription("年龄,请指定在16-50中间的整数")]
  168. public int age;
  169. }
  170. #endregion
  171. #region (x.x.5)从Form获取参数
  172. /// <summary>
  173. /// 从Form获取参数
  174. /// POST did_serslot/Values/304/arg
  175. /// </summary>
  176. /// <returns></returns>
  177. [HttpPost("305/arg")]
  178. public object Arg5([FromForm]ArgModel arg)
  179. {
  180. return new
  181. {
  182. Request.Path,
  183. Request.Method,
  184. request = arg
  185. };
  186. }
  187. #endregion
  188. #endregion
  189. #region (x.4) 返回值
  190. #region (x.x.1)返回值注释
  191. /// <summary>
  192. ///
  193. /// </summary>
  194. /// <returns></returns>
  195. [HttpGet("401/ret")]
  196. [return: SsExample("test1"), SsDescription("返回test1")]
  197. public string Return4()
  198. {
  199. return "test1";
  200. }
  201. /// <summary>
  202. ///
  203. /// </summary>
  204. /// <returns></returns>
  205. [HttpGet("402/ret")]
  206. [return: SsExample("5"), SsDescription("返回5")]
  207. public int Return5()
  208. {
  209. return 5;
  210. }
  211. /// <summary>
  212. ///
  213. /// </summary>
  214. /// <returns></returns>
  215. [HttpGet("403/ret")]
  216. [return: /*SsExample("{\"name\":\"张三\"}"),*/ SsDescription("返回模型数据")]
  217. public ReturnData Return6()
  218. {
  219. return new ReturnData { name = "张三" };
  220. }
  221. /// <summary>
  222. /// Return注释-FromType
  223. /// </summary>
  224. public class ReturnData
  225. {
  226. /// <summary>
  227. /// 姓名
  228. /// </summary>
  229. [SsExample("lith"), SsDefaultValue("NoName")]
  230. public string name { get; set; }
  231. }
  232. #endregion
  233. #region (x.x.2)异步返回
  234. /// <summary>
  235. /// GET did_serslot/Values/201/result
  236. /// </summary>
  237. /// <returns></returns>
  238. [HttpGet("420/result")]
  239. public object Result1()
  240. {
  241. return Request.Method + " " + Request.Path;
  242. }
  243. /// <summary>
  244. /// GET did_serslot/Values/202/result
  245. /// </summary>
  246. /// <returns></returns>
  247. [HttpGet("421/result")]
  248. public ActionResult<string> Result2()
  249. {
  250. return Request.Method + " " + Request.Path;
  251. }
  252. /// <summary>
  253. /// GET did_serslot/Values/203/result
  254. /// </summary>
  255. /// <returns></returns>
  256. [HttpGet("422/result")]
  257. public ActionResult<IEnumerable<string>> Result3()
  258. {
  259. return new string[] { Request.Method + " " + Request.Path, "" };
  260. }
  261. /// <summary>
  262. /// GET did_serslot/Values/204/result
  263. /// </summary>
  264. /// <returns></returns>
  265. [HttpGet("423/result")]
  266. public async Task<string> Result4()
  267. {
  268. await Task.Run(() => { Thread.Sleep(2000); });
  269. return Request.Method + " " + Request.Path;
  270. }
  271. /// <summary>
  272. /// GET did_serslot/Values/205/result
  273. /// </summary>
  274. /// <returns></returns>
  275. [HttpGet("424/result")]
  276. public async Task<ActionResult<string>> Result5()
  277. {
  278. await Task.Run(() => { Thread.Sleep(2000); });
  279. return Request.Method + " " + Request.Path;
  280. }
  281. #endregion
  282. #endregion
  283. #region (x.5)指定参数或返回值类型
  284. /// <summary>
  285. /// 指定参数或返回值类型
  286. /// </summary>
  287. /// <returns></returns>
  288. [HttpGet("500/type")]
  289. [return: SsType(typeof(List<string>)),SsExample("[5,6]"), SsDescription("返回原值")]
  290. public string Type(
  291. [SsType(typeof(List<string>)), SsExample("[5,6]"), SsDescription("id数组")]string ids
  292. )
  293. {
  294. return ids;
  295. }
  296. #endregion
  297. #region (x.6) HttpMethod
  298. /// <summary>
  299. /// GET did_serslot/Values/600/method
  300. /// </summary>
  301. /// <returns></returns>
  302. [HttpGet("600/method")]
  303. public string Method_Get()
  304. {
  305. return Request.Method + " " + Request.Path;
  306. }
  307. /// <summary>
  308. /// POST did_serslot/Values/600/method
  309. /// </summary>
  310. /// <returns></returns>
  311. [HttpPost("600/method")]
  312. public string Method_Post()
  313. {
  314. return Request.Method + " " + Request.Path;
  315. }
  316. /// <summary>
  317. /// Put did_serslot/Values/600/method
  318. /// </summary>
  319. /// <returns></returns>
  320. [HttpPut("600/method")]
  321. public string Method_Put()
  322. {
  323. return Request.Method + " " + Request.Path;
  324. }
  325. /// <summary>
  326. /// Delete did_serslot/Values/600/method
  327. /// </summary>
  328. /// <returns></returns>
  329. [HttpDelete("600/method")]
  330. public string Method_Delete()
  331. {
  332. return Request.Method + " " + Request.Path;
  333. }
  334. ///// <summary>
  335. ///// Head did_serslot/Values/600/method
  336. ///// </summary>
  337. ///// <returns></returns>
  338. //[HttpHead("600/method")]
  339. //public string Method_Head()
  340. //{
  341. // return Request.Method + " " + Request.Path;
  342. //}
  343. /// <summary>
  344. /// Options did_serslot/Values/600/method
  345. /// </summary>
  346. /// <returns></returns>
  347. [HttpOptions("600/method")]
  348. public string Method_Options()
  349. {
  350. return Request.Method + " " + Request.Path;
  351. }
  352. /// <summary>
  353. /// Patch did_serslot/Values/600/method
  354. /// </summary>
  355. /// <returns></returns>
  356. [HttpPatch("600/method")]
  357. public string Method_Patch()
  358. {
  359. return Request.Method + " " + Request.Path;
  360. }
  361. /// <summary>
  362. /// get|post did_serslot/Values/601/method
  363. /// </summary>
  364. /// <returns></returns>
  365. [Route("601/method")]
  366. [HttpGet, HttpPost]
  367. public string Method2()
  368. {
  369. return Request.Method + " " + Request.Path;
  370. }
  371. #endregion
  372. #region (x.7)ApiClient
  373. #region (x.x.1)ApiClient示例,调用其他接口
  374. /// <summary>
  375. /// ApiClient示例,调用其他接口
  376. /// </summary>
  377. /// <returns></returns>
  378. [HttpPost("700/ApiClient700")]
  379. public ApiReturn<Object> ApiClient700(
  380. [SsExample("/did_serslot/Values")] string apiRoute,
  381. [SsExample("{\"a\":\"aaa111\"}")] dynamic arg)
  382. {
  383. var apiRet = ApiClient.CallRemoteApi<string>((string)arg.apiRoute,(object) arg.arg, "POST");
  384. return new ApiReturn<Object>(new
  385. {
  386. RpcContext.RpcData,
  387. apiRet
  388. });
  389. }
  390. #endregion
  391. #region (x.x.2)ApiClient示例,调用其他接口
  392. /// <summary>
  393. /// ApiClient示例,调用其他接口
  394. /// </summary>
  395. /// <returns></returns>
  396. [HttpPost("702/ApiClient")]
  397. public ApiReturn<Object> ApiClient702()
  398. {
  399. return new ApiReturn<Object>(new
  400. {
  401. RpcContext.RpcData
  402. });
  403. }
  404. [HttpPost("703/ApiClient")]
  405. public string ApiClient703()
  406. {
  407. var rpc=RpcContext.RpcData;
  408. var apiRet = ApiClient.CallRemoteApi<string>("/did_serslot/v1/702/ApiClient", null,"POST");
  409. return apiRet;
  410. }
  411. #endregion
  412. #endregion
  413. }
  414. }