gpt4 book ai didi

jquery - HttpListener 问题

转载 作者:行者123 更新时间:2023-12-01 03:51:07 27 4
gpt4 key购买 nike

我正在编写一个控制台应用程序作为 httplistener 并通过 jquery 使用它,它的工作完全正确,但我想将其转换为 https,但我不知道步骤

这是我的代码希望大家能尽快解决

这是在 JScript.js 文件中编写的 jquery 代码

 $(function () {
//this code is executed when the page's onload event fires
$("#runSample1").click(function () {
var userNameJS = $("#uName").val();
var passwordJS = $("#passw").val();
$.post("http://localhost:80/", { userName: userNameJS, password: passwordJS }, function (data) {
alert(data);
});

});
});

这是html页面

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title></title>
<script type="text/javascript" src="Scripts/jquery-1.4.1.js"> </script>

<script type="text/javascript" src="Scripts/jquery-1.4.1.min.js"> </script>
<script type="text/javascript" src="Scripts/JScript.js"></script>
<script type="text/javascript" src="Scripts/jquery-1.4.1-vsdoc.js"></script>
<style type="text/css">
.style1 {
width: 109px;
}
</style>
</head>
<body>
<table>

<tr>
<td class="style1"><label >User Name</label></td>
<td><input id="uName" type="text" /></td>
</tr>
<tr>
<td class="style1"><label >Password</label></td>
<td><input id="passw" type="password" /></td>
</tr>
<tr>
<td class="style1"><input id="runSample1" type="button" value="Send" style="width: 62px"/> </td>
</tr>
</table>
</body>
</html>

httplistener 代码是

using System;
using System.Collections.Generic;
using System.IO;
using System.Net;
using System.Runtime.Serialization;
using System.Runtime.Serialization.Json;
using System.Threading;
using System.Collections.Specialized;
using System.Collections;
using System.Security.Cryptography.X509Certificates;
namespace TestApplication
{
class Program
{
static void Main(string[] args)
{
if (!HttpListener.IsSupported)
{
Console.WriteLine("Windows XP SP2 or Server 2003 is required to use the HttpListener class.");
return;
}
// Create a listener.
HttpListener listener = new HttpListener();
//listener.AuthenticationSchemes = AuthenticationSchemes.Negotiate;
listener.Prefixes.Add("http://*:8080/");
//listener.AuthenticationSchemes
listener.Start();
Console.WriteLine("Listening...");
for (; ; )
{
HttpListenerContext ctx = listener.GetContext();
new Thread(new Worker(ctx).ProcessRequest).Start();
}
}
}
[DataContract]
internal class Person
{
[DataMember]
internal string name;

[DataMember]
internal int age;
}
class Worker
{
private HttpListenerContext context;
public Worker(HttpListenerContext context)
{
this.context = context;
}

public void ProcessRequest()
{

HttpListenerRequest request = context.Request;
List<Person> eList = new List<Person>();
Hashtable formVars = new Hashtable();
Person person;
for (int i = 0; i <= 10;i++ )
{
person = new Person();
person.name = "Pesron " + i;
person.age = i;
eList.Add(person);
}
HttpListenerResponse response = context.Response;
System.IO.StreamReader reader = new System.IO.StreamReader(request.InputStream, request.ContentEncoding);
// S contain parameters and values
string s = reader.ReadToEnd();
string[] pairs = s.Split('&');
for (int x = 0; x < pairs.Length; x++)
{
string[] item = pairs[x].Split('=');
formVars.Add(item[0],item[1]);
}
String userName = formVars["userName"].ToString();
String password = formVars["password"].ToString();
//To send any object as json to client
DataContractJsonSerializer jsonObject = new DataContractJsonSerializer(typeof(List<Person>));
System.IO.Stream output = response.OutputStream;
MemoryStream ms = new MemoryStream();
jsonObject.WriteObject(ms, eList);
byte[] buffer = ms.ToArray();
response.ContentType = "text/plain";
response.ContentEncoding = System.Text.UTF8Encoding.UTF8;
response.ContentLength64 = buffer.Length;
//These headers to allow all browsers to get the response
response.Headers.Add("Access-Control-Allow-Credentials", "true");
response.Headers.Add("Access-Control-Allow-Origin", "*");
response.Headers.Add("Access-Control-Origin", "*");
//This line to write to the resonse
output.Write(buffer, 0, buffer.Length);
output.Close();
}
}
}

最佳答案

IE 不会对本地主机进行沙箱处理。 FF 和其他浏览器都可以。他们将对 localhost 的调用视为对网络的调用,这是不允许的。

您可以尝试添加

Access-Control-Allow-Credentials: true
Access-Control-Allow-Origin: *
Access-Control-Origin: *

到 HttpListener 的 header 。可以找到一篇关于为什么需要这样做的好论文 here .

关于jquery - HttpListener 问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8505381/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com