![](/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.