Ich träge derzeit in einer Erweiterung bei, und das Hauptproblem ist, dass der CSP auf Firefox ausgelöst wird, was einige Probleme verursacht. Hauptsächlich scheint es die Injektion von dynamischen CSS zu blockieren, von denen ich dachte, ich würde entfernt, obwohl es immer noch ausgelöst wird. Nur als Referenz, die Website, die ich ziele, ist Modrinth. Dies ist das Repo, wenn Sie einen vollständigen Blick auf den Code möchten (es ist wahrscheinlich wirklich schlechter Code) Bluerth, aber das Hauptproblem, das ich vermute, liegt in meinem injizierten.document.onreadystatechange = function () {
const projectRegex =
/^https?:\/\/modrinth\.com\/(?:project|mod|resourcepack|shader|datapack|modpack)\/([^\/]+)/;
const projectIdTest = projectRegex.exec(window.location.href);
const projectId =
projectIdTest != null && projectIdTest.length > 1 ? projectIdTest[1] : null;
if (projectId !== null) {
runBanner(projectId);
return;
}
pageSupportsBanners = false;
};
useNuxtApp()._middleware.global.push(function handleRoute(to, from) {
if (to.name.startsWith("type-id")) {
const { id } = to.params;
console.log("entering project", id);
runBanner(id);
} else if (from.name.startsWith("type-id")) {
const { id } = from.params;
//console.log("leaving project", id);
const containers = document.getElementsByClassName("banner-container");
for (let container of containers) {
document.body.removeChild(container);
}
pageSupportsBanners = false;
}
});
let pageSupportsBanners = false;
const fallbackimage =
"";
let banner = fallbackimage;
async function runBanner(id) {
console.log("runBanner called with id:", id);
pageSupportsBanners = true;
const apibase = "https://api.modrinth.com/v3/project/";
try {
const response = await fetch(apibase + id);
if (!response.ok) {
console.error("blueRinth: Response failed during banner loading.");
return;
}
const data = await response.json();
console.log("Project API data:", data);
console.log("gallery:", data.gallery);
data.gallery.forEach((entry) => {
if (entry.featured === true) {
banner = entry.url;
applyBanners();
}
});
} catch {
console.error(
"blueRinth: Something failed during banner loading. Please contact WorldWidePixel."
);
}
}
function applyBanners() {
console.log("applyBanners called, banner:", banner);
if (pageSupportsBanners) {
const bannerContainer = document.createElement("div");
const bannerStyles = document.createElement("style");
bannerStyles.innerHTML = `
.banner-image {
background-image:
linear-gradient(0deg, var(--color-bg) 0%, rgba(0, 0, 0, 0) 200%),
url(${banner}) !important;
}
`;
document.head.appendChild(bannerStyles);
bannerContainer.classList.add("banner-container");
const bannerImage = document.createElement("div");
bannerImage.classList.add("banner-image");
bannerContainer.appendChild(bannerImage);
const bannerBg = document.createElement("div");
bannerBg.classList.add("banner-bg");
document.body.appendChild(bannerBg);
document.body.appendChild(bannerContainer);
bannerContainer.style.opacity = "100%";
}
}
< /code>
Hier ist der Text der CSP-Fehler, mit denen ich ausgestattet bin. Ich habe wenig Ahnung, was sie wirklich bedeuten. Deshalb bin ich hier: < /p>
Inhalts-Security-Policy: (Berichtsrichtlinie) Die Einstellungen der Seite blockieren einen inline-script-src-src-src-src-src-src-src-src. Erwägen Sie, einen Hash ('Sha256-JBMYBQGA3TPYBG9FUY2ESK5FAFHMVDYH2GUNNHLCVUW =') oder A Nonce zu (Style-Src-Elem) von der Anwendung, weil es gegen die folgende Richtlinie verstößt: „Style-Src https://m.stripe.network“. Erwägen Sie, einen Hash ('sha256-dd4j3unqshsomqcyi4vn5Bt3mgzb/0fowba72rsgukc =' zu verwenden, erfordert 'unsichere Hächen' für Style-Attribute) oder ein Nonce. Content.js, Wechseln von Themen, die auf diesen Dateien baiert sind, dies funktioniert jedoch nicht. Das Problem kann auch in meinem Inhalt auftreten.>
Wie man die strenge Inhaltssicherheitsrichtlinie von Firefox durch meine Erweiterung nicht auslöst ⇐ JavaScript
-
- Similar Topics
- Replies
- Views
- Last post