


Asp.Net Core verwendet Middleware, um Bild-Hotlinking zu verhindern
1. Prinzip
Um Anti-Hotlinking zu erreichen, müssen wir zunächst das Implementierungsprinzip von Anti-Hotlinking verstehen Im HTTP-Protokoll gibt es ein Header-Feld namens Referer, das im URL-Format angibt, wo auf die aktuelle Webseite oder Datei verlinkt werden soll. Mit anderen Worten: Über den Referrer kann die Website die von der Zielwebseite besuchte Quellwebseite erkennen und, wenn es sich um eine Ressourcendatei handelt, die Webseitenadresse verfolgen, die sie anzeigt. Wenn der Referrer die Quelle verfolgt, ist die Handhabung zu diesem Zeitpunkt einfacher. Sobald festgestellt wird, dass es sich bei der Quelle nicht um diese Site handelt, wird sie blockiert oder an die angegebene Seite zurückgegeben. Wenn Sie Ihre Website vor Hotlinking schützen möchten, müssen Sie verschiedene Situationen unterschiedlich behandeln.
Wenn der Website-Server Apache verwendet, kann die Verwendung der mit Apache gelieferten URL-Rewrite-Funktion problemlos verschiedene Hotlinks verhindern. Das Prinzip besteht darin, die Verweisinformationen zu überprüfen. Leiten Sie zu einem bestimmten Bild oder einer bestimmten Webseite weiter.
Wenn der Server IIS verwendet, müssen Sie ein Plug-in eines Drittanbieters verwenden, um die Anti-Hotlink-Funktion zu implementieren. Ein häufig verwendetes Produkt heißt ISAPI_Rewrite und kann die Anti-Hotlink-Funktion implementieren. Hotlink-Funktion ähnlich wie Apache. Darüber hinaus können Foren auch die Methode „Login-Verifizierung“ verwenden, um Hotlinking zu verhindern.
2. Anti-Hotlinking implementieren
Lassen Sie uns nun die Anti-Hotlinking-Technologie in ASP.NET Core implementieren, um unsere Anwendungen und Site-Dateien zu schützen. Dies erfordert den Einsatz der Middleware-Technologie in ASP.NET Core, um alle eingehenden Anfragen zu überwachen und zu verarbeiten und zu prüfen, ob diese Anfragen von unserer Anwendung stammen.
Lassen Sie uns dieses Anti-Hotlink-Middleware-Programm erstellen:
public class HotlinkingPreventionMiddleware { private readonly string _wwwrootFolder; private readonly RequestDelegate _next; public HotlinkingPreventionMiddleware(RequestDelegate next, IHostingEnvironment env) { _wwwrootFolder = envWebRootPath; _next = next; } public async Task Invoke(HttpContext context) { var applicationUrl = $"{contextRequestScheme}://{contextRequestHostValue}"; var headersDictionary = contextRequestHeaders; var urlReferrer = headersDictionary[HeaderNamesReferer]ToString(); if(!stringIsNullOrEmpty(urlReferrer) && !urlReferrerStartsWith(applicationUrl)) { var unauthorizedImagePath = PathCombine(_wwwrootFolder,"Images/Unauthorizedpng"); await contextResponseSendFileAsync(unauthorizedImagePath); } await _next(context); } }
In dieser Middleware können wir ASP sehen Core kapselt den Referrer nicht. Um den Referrer zu erhalten, müssen Sie über HTTP-Header darauf zugreifen.
Im Allgemeinen gibt es eine IApplicationBuilder-Erweiterung:
public static class BuilderExtensions { public static IApplicationBuilder UseHotlinkingPreventionMiddleware(this IApplicationBuilder app) { return appUseMiddleware(); } }
Um sie schließlich zu verwenden, müssen Sie sie nur im Konfigurieren aufrufen Funktion. Funktion.
app.UseHotlinkingPreventionMiddleware();
3. Kann es wirklich verteidigt werden?
Wie kann man die Blutegelbekämpfung durchbrechen? Um den Verweis zu überprüfen, können Sie zunächst eine andere Seite der Zieladresse in die Seiten-Middleware eingeben und dann zur Zielseite wechseln. Auf diese Weise ist der Verweis der Seite der eigene der Zielseite. ein Durchbruch gelingt. Es gibt viele Tools, die in dieser Hinsicht verwendet werden können, insbesondere ausgereifte Webprojekt-Testpakete wie HtmlUnit, die direkt in der Anfrage verweisen können.
Wenn die gestohlene Website das https-Protokoll verwendet und der Bildlink http ist, enthält die von https an http initiierte Anfrage aus Sicherheitsgründen keinen Referrer, wodurch Anti-Hotlinking umgangen wird.
Abschließend kann ich nur sagen, dass diese Methode nur bis zu einem gewissen Grad abwehren kann und es unmöglich ist, alle Angriffe zu beseitigen. Es wird weiterhin empfohlen, ausgereifte Serveranwendungslösungen wie Nginx zu verwenden.
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass er zum Lernen aller beiträgt. Ich hoffe auch, dass jeder die PHP-Chinesisch-Website unterstützt.
Weitere verwandte Artikel über die Verwendung von Middleware durch Asp.Net Core zur Verhinderung von Bild-Hotlinks finden Sie auf der chinesischen PHP-Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



In der C -Sprache werden Sonderzeichen durch Escape -Sequenzen verarbeitet, wie z. B.: \ n repräsentiert Linienbrüche. \ t bedeutet tab charakter. Verwenden Sie Escape -Sequenzen oder Zeichenkonstanten, um Sonderzeichen darzustellen, wie z. B. char c = '\ n'. Beachten Sie, dass der Backslash zweimal entkommen muss. Verschiedene Plattformen und Compiler haben möglicherweise unterschiedliche Fluchtsequenzen. Bitte wenden Sie sich an die Dokumentation.

In C wird der Zeichenentyp in Saiten verwendet: 1. Speichern Sie ein einzelnes Zeichen; 2. Verwenden Sie ein Array, um eine Zeichenfolge darzustellen und mit einem Null -Terminator zu enden. 3. Durch eine Saitenbetriebsfunktion arbeiten; 4. Lesen oder geben Sie eine Zeichenfolge von der Tastatur aus.

Die Nutzungsmethoden von Symbolen in der C-Sprachabdeckung Arithmetik, Zuordnung, Bedingungen, Logik, Bitoperatoren usw. werden für grundlegende mathematische Operationen verwendet, Zuordnungsoperatoren werden zur Zuordnung und Addition verwendet, Subtraktion, Multiplikationszuordnung und Abteilungszuweisung, Zustandsbetreiber werden für Unterschiede verwendet. Logische Operationen werden verwendet. Logische Operationen werden verwendet. Logische Operationen werden verwendet. Zeiger, Markierungen am Ende der Datei und nicht numerische Werte.

Der Unterschied zwischen Multithreading und Asynchron besteht darin, dass Multithreading gleichzeitig mehrere Threads ausführt, während asynchron Operationen ausführt, ohne den aktuellen Thread zu blockieren. Multithreading wird für rechenintensive Aufgaben verwendet, während asynchron für die Benutzerinteraktion verwendet wird. Der Vorteil des Multi-Threading besteht darin, die Rechenleistung zu verbessern, während der Vorteil von Asynchron nicht darin besteht, UI-Threads zu blockieren. Die Auswahl von Multithreading oder Asynchron ist von der Art der Aufgabe abhängt: Berechnungsintensive Aufgaben verwenden Multithreading, Aufgaben, die mit externen Ressourcen interagieren und die UI-Reaktionsfähigkeit asynchron verwenden müssen.

In der C -Sprache ist der Hauptunterschied zwischen char und wchar_t die Zeichencodierung: char verwendet ASCII oder erweitert ASCII, wchar_t Unicode; char nimmt 1-2 Bytes auf, wchar_t nimmt 2-4 Bytes auf; char ist für englischen Text geeignet. Wchar_t ist für mehrsprachige Text geeignet. char ist weithin unterstützt, wchar_t hängt davon ab, ob der Compiler und das Betriebssystem Unicode unterstützen. char ist in der Charakterbereich begrenzt, WCHAR_T hat einen größeren Charakterbereich und spezielle Funktionen werden für arithmetische Operationen verwendet.

In der C -Sprache kann die char -Typ -Konvertierung direkt in einen anderen Typ konvertiert werden, wenn: Casting: Verwenden von Casting -Zeichen. Automatische Konvertierung des Typs: Wenn ein Datentyp einen anderen Werttyp berücksichtigen kann, wandelt der Compiler diese automatisch um.

Das Char -Array speichert Zeichensequenzen in der C -Sprache und wird als char Array_name [Größe] deklariert. Das Zugriffselement wird durch den Einweisoperator weitergeleitet, und das Element endet mit dem Null -Terminator '\ 0', der den Endpunkt der Zeichenfolge darstellt. Die C -Sprache bietet eine Vielzahl von String -Manipulationsfunktionen wie Strlen (), Strcpy (), Strcat () und strcmp ().

Es gibt keine integrierte Summenfunktion in der C-Sprache, daher muss sie selbst geschrieben werden. Die Summe kann erreicht werden, indem das Array durchquert und Elemente akkumulieren: Schleifenversion: Die Summe wird für die Schleifen- und Arraylänge berechnet. Zeigerversion: Verwenden Sie Zeiger, um auf Array-Elemente zu verweisen, und eine effiziente Summierung wird durch Selbststillstandszeiger erzielt. Dynamisch Array -Array -Version zuweisen: Zuordnen Sie Arrays dynamisch und verwalten Sie selbst den Speicher selbst, um sicherzustellen, dass der zugewiesene Speicher befreit wird, um Speicherlecks zu verhindern.
