le mie informazioni di contatto
Posta[email protected]
2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
Poiché il cliente deve aggiornare il servizio backend HTTP originale a un servizio che supporti https, poiché il servizio HTTP originale è implementato in base al servizio di ascolto HTTP integrato del servizio WINDOWS e non supporta https, né è come gli altri API Web distribuite in IIS Il certificato HTTPS viene caricato direttamente come il servizio, quindi in questo caso è necessario modificare il servizio originale per supportare https ed eseguire le impostazioni di associazione della porta HTTPS nell'ambiente del server, come segue:
(Nota: le seguenti operazioni richiedono che tu disponga già di un certificato HTTPS.)
1. Installa il certificato, fai doppio clic sul file pfx e installalo in: "computer locale”–>“personale”;
2. Fare doppio clic per apriretubo catodicoCertificato, è possibile visualizzare le informazioni relative all'impronta digitale (certhash) nelle informazioni dettagliate;
3. Eseguire il collegamento della porta (porta predefinita 443)
netsh http add sslcert ipport=0.0.0.0:8080 certhash=指纹 appid={程序GUID/newguid} clientcertnegotiation=enable
4. Implementazione del programma server:
- using System;
- public class HttpService
- {
- public MyHttpServer()
- {
- System.Net.HttpListener httpListener = new System.Net.HttpListener();
- httpListener.AuthenticationSchemes = System.Net.AuthenticationSchemes.Anonymous;
- httpListener.Prefixes.Add("https://*:8000/"); // 支持https
- httpListener.Start();
- new System.Threading.Thread(new System.Threading.ThreadStart(delegate
- {
- while (true)
- {
- try
- {
- System.Net.HttpListenerContext httpListenerContext = httpListener.GetContext();
- new System.Threading.Thread(new System.Threading.ParameterizedThreadStart((input) =>
- {
- System.Net.HttpListenerContext ctx = (System.Net.HttpListenerContext)input;
- System.Net.HttpListenerRequest request = ctx.Request;
- string pram = request.QueryString["Data"];//Get入参
- string responseMessage = string.Empty;//返回值
- if (!string.IsNullOrEmpty(pram))
- {
- //Get入参
- pramOrg = pram;
- pram = System.Web.HttpUtility.UrlDecode(pram);
- }
- //POST入参
- if (request.HttpMethod == "POST")
- {
- //处理业务请求
- StreamReader reader = new StreamReader(request.InputStream, Encoding.UTF8);
- pram = reader.ReadToEnd();
- reader.Close();
- reader.Dispose();
- }
- #region 业务处理
- try
- {
- //业务处理
- responseMessage = "业务结果";
- }
- catch (Exception ex)
- {
- //异常处理
- responseMessage = ex.Message;
- }
- #endregion 业务处理
- #region 返回给调用者
- //输出类型
- httpListenerContext.Response.ContentType = "text/html; charset=UTF-8";
- //返回状态
- httpListenerContext.Response.StatusCode = 200;
- //设置授权,尝试解决Jquery跨域问题
- //httpListenerContext.Response.Headers["Access-Control-Allow-Origin"] = "*";
- //httpListenerContext.Response.Headers["Access-Control-Allow-Methods"] = "GET,POST";
- //httpListenerContext.Response.Headers["Access-Control-Max-Age"] = "1000";
- try
- {
- //输出界面内容
- if (!string.IsNullOrEmpty(responseMessage))
- {
- //返回文本内容
- using (StreamWriter writer = new StreamWriter(httpListenerContext.Response.OutputStream))
- {
- writer.Write(responseMessage);
- }
- }
- }
- catch
- {
- //刷新太快异常,不做处理
- }
- #endregion 返回给调用者
- })).Start(httpListenerContext);
- }
- catch
- { }
- }
- })).Start();
- }
- }
Se viene segnalato un errore durante il processo di associazione della porta di cui sopra o l'aggiunta non riesce, è possibile fare riferimento alla seguente elaborazione:
1. Controlla se i parametri del comando netsh sono corretti;
2. Impossibile aggiungere il certificato SSL, errore: 1312 La sessione di accesso specificata non esiste. Potrebbe essere stato terminato. Metodo di elaborazione:
Tastiera WIN+R e inserisci mmc.exe, come segue:
Fare clic su "OK" e verrà visualizzata la seguente interfaccia del nodo root della console:
Selezionare File->Aggiungi/Elimina snap-in oppure utilizzare direttamente il tasto di scelta rapida ctrl+m per visualizzare il seguente popup ed eseguire l'operazione:
Quindi vai al certificato di importazione personale
Infine associa il certificato SSL al numero di porta
netsh http add sslcert ipport=0.0.0.0:8080 certhash=指纹 appid={程序GUID/newguid} clientcertnegotiation=enable