प्रौद्योगिकी साझेदारी

C# exe-आधारितं एम्बेडेड् HTTPS श्रवणसेवाम् कार्यान्वितं करोति तथा च HTTP तः HTTPS back-end windows सेवां प्रति उन्नयनं करोति

2024-07-12

한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina

यतः ग्राहकस्य मूल HTTP पृष्ठभागसेवाम् https समर्थयति इति सेवायां उन्नयनं कर्तुं आवश्यकं भवति, यतः मूल HTTP सेवा WINDOWS सेवायाः अन्तःनिर्मित HTTP श्रवणसेवायाः आधारेण कार्यान्विता भवति, तथा च https समर्थयति न, अन्यवत् अपि नास्ति IIS मध्ये परिनियोजिताः WebAPIs HTTPS प्रमाणपत्रं प्रत्यक्षतया सेवा इव लोड् भवति, अतः अत्र भवद्भिः https समर्थनार्थं मूलसेवा परिवर्तनं करणीयम् अस्ति तथा च सर्वरवातावरणे HTTPS पोर्ट् बाइंडिंग् सेटिंग्स् कर्तुं आवश्यकम् अस्ति, यथा निम्नलिखितम्:

(टिप्पणी: निम्नलिखितक्रियाणां कृते आवश्यकं यत् भवतः समीपे पूर्वमेव HTTPS प्रमाणपत्रं भवति।)

1. प्रमाणपत्रं संस्थापयन्तु, pfx सञ्चिकायां द्विवारं क्लिक् कृत्वा, एतत् संस्थापयन्तु: "स्थानीय सङ्गणक”–>“व्यक्तिगत”;

2. उद्घाटयितुं द्विवारं क्लिक् कुर्वन्तुcrtप्रमाणपत्रं, विस्तृतसूचनायां अङ्गुलिचिह्नसम्बद्धानि सूचनानि (certhash) द्रष्टुं शक्नुवन्ति;

3. पोर्ट् बाइंडिंग् (पूर्वनिर्धारित पोर्ट् 443) कुर्वन्तु ।

netsh http add sslcert ipport=0.0.0.0:8080 certhash=指纹 appid={程序GUID/newguid} clientcertnegotiation=enable

4. सर्वर प्रोग्राम कार्यान्वयनम् : १.

  1. using System;
  2. public class HttpService
  3. {
  4. public MyHttpServer()
  5. {
  6. System.Net.HttpListener httpListener = new System.Net.HttpListener();
  7. httpListener.AuthenticationSchemes = System.Net.AuthenticationSchemes.Anonymous;
  8. httpListener.Prefixes.Add("https://*:8000/"); // 支持https
  9. httpListener.Start();
  10. new System.Threading.Thread(new System.Threading.ThreadStart(delegate
  11. {
  12. while (true)
  13. {
  14. try
  15. {
  16. System.Net.HttpListenerContext httpListenerContext = httpListener.GetContext();
  17. new System.Threading.Thread(new System.Threading.ParameterizedThreadStart((input) =>
  18. {
  19. System.Net.HttpListenerContext ctx = (System.Net.HttpListenerContext)input;
  20. System.Net.HttpListenerRequest request = ctx.Request;
  21. string pram = request.QueryString["Data"];//Get入参
  22. string responseMessage = string.Empty;//返回值
  23. if (!string.IsNullOrEmpty(pram))
  24. {
  25. //Get入参
  26. pramOrg = pram;
  27. pram = System.Web.HttpUtility.UrlDecode(pram);
  28. }
  29. //POST入参
  30. if (request.HttpMethod == "POST")
  31. {
  32. //处理业务请求
  33. StreamReader reader = new StreamReader(request.InputStream, Encoding.UTF8);
  34. pram = reader.ReadToEnd();
  35. reader.Close();
  36. reader.Dispose();
  37. }
  38. #region 业务处理
  39. try
  40. {
  41. //业务处理
  42. responseMessage = "业务结果";
  43. }
  44. catch (Exception ex)
  45. {
  46. //异常处理
  47. responseMessage = ex.Message;
  48. }
  49. #endregion 业务处理
  50. #region 返回给调用者
  51. //输出类型
  52. httpListenerContext.Response.ContentType = "text/html; charset=UTF-8";
  53. //返回状态
  54. httpListenerContext.Response.StatusCode = 200;
  55. //设置授权,尝试解决Jquery跨域问题
  56. //httpListenerContext.Response.Headers["Access-Control-Allow-Origin"] = "*";
  57. //httpListenerContext.Response.Headers["Access-Control-Allow-Methods"] = "GET,POST";
  58. //httpListenerContext.Response.Headers["Access-Control-Max-Age"] = "1000";
  59. try
  60. {
  61. //输出界面内容
  62. if (!string.IsNullOrEmpty(responseMessage))
  63. {
  64. //返回文本内容
  65. using (StreamWriter writer = new StreamWriter(httpListenerContext.Response.OutputStream))
  66. {
  67. writer.Write(responseMessage);
  68. }
  69. }
  70. }
  71. catch
  72. {
  73. //刷新太快异常,不做处理
  74. }
  75. #endregion 返回给调用者
  76. })).Start(httpListenerContext);
  77. }
  78. catch
  79. { }
  80. }
  81. })).Start();
  82. }
  83. }

यदि उपरि पोर्ट् बाइंडिंग् प्रक्रियायाः समये त्रुटिः निवेदिता अस्ति, अथवा परिवर्तनं विफलं भवति, तर्हि भवान् निम्नलिखितप्रक्रियाकरणं सन्दर्भयितुं शक्नोति ।

1. netsh आदेशस्य पैरामीटर्स् सम्यक् सन्ति वा इति पश्यन्तु;

2. SSL प्रमाणपत्रं योजयितुं असफलम्, त्रुटिः: 1312 निर्दिष्टं प्रवेशसत्रं नास्ति । समाप्तं जातं स्यात् । प्रसंस्करणविधिः : १.

कीबोर्ड WIN+R इति कृत्वा mmc.exe इति प्रविष्टं कुर्वन्तु, यथा:

    

'OK' नुदन्तु, ततः निम्नलिखितम् console root node interface pop up भविष्यति:

File->Add/Delete Snap-in इति चिनोतु, अथवा निम्नलिखित-पॉप-अपं पॉप-अप कर्तुं तथा च कार्यं कर्तुं प्रत्यक्षतया शॉर्टकट्-कुंजी ctrl+m इत्यस्य उपयोगं कुर्वन्तु:

ततः व्यक्तिगत आयातप्रमाणपत्रं प्रति गच्छन्तु

अन्ते SSL प्रमाणपत्रं पोर्ट् सङ्ख्यायां बाइण्ड् कुर्वन्तु

netsh http add sslcert ipport=0.0.0.0:8080 certhash=指纹 appid={程序GUID/newguid} clientcertnegotiation=enable