Envoyez des données avec une requête HTTP depuis l'addon Firefox.
background.js
browser.contextMenus.create({
id: "name",
title: "get name",
contexts: ["selection"],
});
var name = "blue";
getting = browser.storage.local.get("name", function (value) {
name = value.name;
});
browser.contextMenus.onClicked.addListener((info, tab) => {
getting = browser.storage.local.get("name", function (value) {
name = value.name;
});
if (info.menuItemId === "name") {
url= "http://sample/?arg0=" + name;
doGet(url);
}
}
function doGet(url) {
console.log(url);
const xhr = new XMLHttpRequest();
xhr.open('GET', url);
xhr.onload = () => {
console.log(xhr.status);
};
xhr.onerror = () => {
console.log(xhr.status);
console.log("error!");
};
xhr.send();
}
Obtenez la valeur avec le paramètre de requête GET.
doGet
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
try {
request.setCharacterEncoding("UTF-8");
response.setHeader("Access-Control-Allow-Origin", "*");
response.setContentType("text/html; charset=UTF-8");
} catch (UnsupportedEncodingException e1) {}
String arg0 = request.getParameter("arg0");
//Pour quand l'encodage ne fonctionnait pas
String query = request.getQueryString();
if (query.indexOf("arg0=")>0) {
arg0 = query.substring(query.indexOf("arg0=")+5);
arg0 = URLDecoder.decode(arg0, "UTF-8");
}
//réduction
}
Sans Access-Control-Allow-Origin, vous verrez le message suivant dans la console Firefox:
console
Demande d'origine croisée bloquée:Avec la même politique d'origine
http://sample/?arg0=Le chargement des ressources distantes au nom est refusé
(Raison:En-tête CORS «Accès-Control-Allow-Origine »est manquante)。
https://developer.mozilla.org/ja/docs/Web/API/XMLHttpRequest https://developer.mozilla.org/ja/docs/Web/HTTP/HTTP_access_control