![](/img/trans.png)
[英]Cannot retrieve XML from InputStream using Java JSP when submitting from Adobe LC HTML5 form
[英]Cannot read InputStream from HttpListenerRequest
我一直在创建下载管理器,该管理器从chrome扩展名接收文件名和下载链接。
在这种情况下,我决定使用javascript后台页面发送XMLHttpRequest进行环回,并创建一个简单的服务器来接收消息,后台页面如下所示。
background.js
function showMessageBox(info, tab) {
var link = decodeURIComponent(info.linkUrl);
var index = link.search(/[^/\\\?]+\.\w{3,4}(?=([\?&].*$|$))/);
var fileName = link.substring(index);
alert("will download from " + link + " soon\n File name : " + fileName);
SendMessage(fileName,link);
}
function SendMessage(fileName, link) {
var xhr = new XMLHttpRequest();
xhr.open("POST","http://localhost:6230", false);
xhr.setRequestHeader("Content-Type", "application/json; charset=UTF-8");
var JSONstring = JSON.stringify({ FileName: fileName, DownloadLink: link });
xhr.send(JSONstring);
}
和服务器的一部分。
private void StartReciever()
{
while (true)
{
var fileInfo = GetFileInfo();
Execute.OnUIThread(() => WindowManager.ShowDialog(
new NewDownloadViewModel(WindowManager, EventAggregator, fileInfo, Engine)));
}
}
private FileInfo GetFileInfo()
{
using (var listener = new HttpListener())
{
listener.Prefixes.Add("http://localhost:6230/");
listener.Start();
var requestContext = listener.GetContext();
/*var streamReader = new StreamReader(requestContext.Request.InputStream, requestContext.Request.ContentEncoding);
string jsonString = streamReader.ReadToEnd();*/
var stream = requestContext.Request.InputStream;
byte[] buffer = new byte[10240];
var readbyte = stream.Read(buffer, 0, 102400);
string ss = Encoding.UTF8.GetString(buffer, 0, readbyte);
// deserialize string to object
return new FileInfo();
}
}
我想知道为什么发送消息时流读取总是返回0。
终于,我找到了忘记的地方!
根据Same-origin策略 ,我无法将HTTP请求发送到来源不同的服务器。
我必须使用跨域XMLHttpRequest来与来源不同的服务器进行通信。
为此,我需要通过在权限部分添加主机名来请求跨域权限。
就我而言,我看起来像这样。
"permissions": [
"contextMenus",
"http://localhost/",
"nativeMessaging"
]
现在,我可以接收字符串并将其反序列化了。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.